亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? tcp.c

?? tcp,udp程序
?? C
?? 第 1 頁 / 共 2 頁
字號:
#include "GloblDef.h"
#include "RTL8019.h"
#include "NetIntef.h"
#include "IP.h"
#include "ARP.h"
#include "timer.h"
#include "TCP.h"

extern void MemCopy(BYTE xdata * to,BYTE xdata * from,WORD size);
extern BYTE xdata * MemPageToPoint(BYTE page);
extern BYTE MemAllocation(WORD size);
extern void FreePage(BYTE page);
extern BYTE QueueInitial(struct Queue xdata * pq,BYTE size);
extern BYTE WriteQueue(BYTE page,struct Queue xdata *pQueue);
extern BYTE ReadQueue(struct Queue xdata *pQueue,BYTE DeleteOrNot);

extern WORD CheckSum(WORD xdata * buff,WORD size,DWORD InSum);
extern BYTE xdata PageAllocationFlag[SMALL_PAGE_NUM + LARGE_PAGE_NUM];

extern void NetInProcess();
extern void IPProcess();
extern void TCPIn();
extern void TCPOut();
extern void TCPOnReceive(BYTE xdata *buff,WORD size);
extern void RTLReceivePacket();

extern BYTE ARPRetrasmitTime;	          /* arp 重傳時間 */
extern struct s_timer xdata ARPTimer;	  /* arp 時鐘*/

struct s_TCB xdata tcb;
struct s_timer xdata TCPTimer;	        /* tcp 時鐘 */
BYTE TCPRetransmitTime;		              /* tcp包重傳時鐘 */

void TCPStateClosed(struct TCPHeader xdata *pTCPHead,struct IPHeader xdata *pIPHead);
void TCPStateListen(struct TCPHeader xdata *pTCPHead,struct IPHeader xdata *pIPHead);
void TCPStateSynrecvd(struct TCPHeader xdata *pTCPHead,struct IPHeader xdata *pIPHead);
void TCPStateSynSent(struct TCPHeader xdata *pTCPHead,struct IPHeader xdata *pIPHead);
void TCPStateEstablished(struct TCPHeader xdata *pTCPHead,struct IPHeader xdata *pIPHead);
void TCPStateClosewait(struct TCPHeader xdata *pTCPHead,struct IPHeader xdata *pIPHead);
void TCPStateFinwait1(struct TCPHeader xdata *pTCPHead,struct IPHeader xdata *pIPHead);
void TCPStateClosing(struct TCPHeader xdata *pTCPHead,struct IPHeader xdata *pIPHead);
void TCPStateFinwait2(struct TCPHeader xdata *pTCPHead,struct IPHeader xdata *pIPHead);

typedef void (code *StateTrasType)(struct TCPHeader xdata *pTCPHead,struct IPHeader xdata *pIPHead);

StateTrasType xdata StateTransformFunc[]={
	TCPStateClosed,
	TCPStateListen,
	TCPStateSynrecvd,
	TCPStateSynSent,
	TCPStateEstablished,
	TCPStateClosewait,
	TCPStateFinwait1,
	TCPStateClosing,
	TCPStateFinwait2
	};

/* tcp 校驗和 */
WORD TCPCheckSum(struct IPHeader xdata *pIPHead,WORD TCPSize)
{
	DWORD sum = 0;
	WORD xdata * p;
	int i;

	/* 
	   源 ip, 目的 ip,  8 bits, 協議, TCP包長 */
	sum = 0;

	/* 源 ip, 目的 ip */
	p = (WORD xdata *)(&(pIPHead->SourceIP));
	for(i=0; i < sizeof(DWORD)/sizeof(WORD)*2; i++,p++)
		sum += *p;
	
	/* 協議 */
	sum += pIPHead->Protocol;

	/* TCP包長 */
	sum += TCPSize;

	return CheckSum((WORD xdata *)((BYTE xdata *)pIPHead + (pIPHead->Version_HeadLength & 0x0f)*4),TCPSize,sum);
}


/*分配一個tcp 包為空 */
BYTE TCPAllocateWithoutData()
{
	BYTE page;
	struct MemHeader xdata *pMemHead;

	/* 分配 */
	page = MemAllocation(sizeof(struct TCPHeader)+sizeof(struct IPHeader)+sizeof(struct MACHeader));
	if(page == PAGE_NOT_FOUND)
		return page;
	
	/* 設置pos */
	pMemHead = (struct MemHeader xdata *)MemPageToPoint(page);
	pMemHead->StartPos = (BYTE xdata *)pMemHead + sizeof(struct TCPHeader)+sizeof(struct IPHeader)+sizeof(struct MACHeader)+sizeof(struct MemHeader);
	pMemHead->StopPos = pMemHead->StartPos;

	return page;
	
}

/* 這些情況下釋放buffer, 包括:
   1.TCPConnection 失敗
   2.TCPClose 結束
   3.TCPPeerClosing 發現問題 */
void TCPReleaseBuffer()
{
	BYTE page;


	while((page = ReadQueue(&(tcb.QueueRetransmit),READ_AND_DELETE)) != PAGE_NOT_FOUND)
	{
		FreePage(page);
	}

	
	ARPTimer.enable = FALSE;
	TCPTimer.enable = FALSE;
}

/*填充 tcp 頭*/
void TCPFillHead(struct TCPHeader xdata *pTCPHead,BYTE TCPFlag)
{
	/* 填充*/
	pTCPHead->AckSequence = tcb.AckSequence;
	pTCPHead->CheckSum = 0;
	pTCPHead->DestinationPort = tcb.DestinationPort;
	pTCPHead->flag = TCPFlag;
	pTCPHead->Sequence = tcb.Sequence;
	pTCPHead->SourcePort = tcb.SourcePort;
	pTCPHead->TCPHeadLength = (BYTE)(((BYTE)sizeof(struct TCPHeader)/4)<<4);
	pTCPHead->UrgentPoint = 0;
	pTCPHead->WindowSize = tcb.SourceWindowSize;


}

/* 發送包. 發送成功返回 TRUE. */
BYTE TCPSendPacket(BYTE page,BYTE TCPFlag)
{
	struct MemHeader xdata *pMemHead;
	struct IPHeader xdata *pIPHead;
	struct TCPHeader xdata *pTCPHead;
	WORD DataSize;
	BYTE WritePosition;

	/*內存不足 */
	if(page == PAGE_NOT_FOUND)
		return SEND_STATE_MEM_INSUFFICIENT;

	/* 獲得 pHead */
	pMemHead = (struct MemHeader xdata *)MemPageToPoint(page);
	pTCPHead = (struct TCPHeader xdata *)(pMemHead->StartPos - sizeof(struct TCPHeader));
	pIPHead = (struct IPHeader xdata *)(pMemHead->StartPos - sizeof(struct TCPHeader) - sizeof(struct IPHeader));
	DataSize = pMemHead->StopPos - pMemHead->StartPos;


	if(WriteQueue(page,&(tcb.QueueRetransmit)) == PAGE_NOT_FOUND)
		return SEND_STATE_RETRANSMIT_FULL;
	if(tcb.QueueRetransmit.WritePos == 0)
		WritePosition = tcb.QueueRetransmit.QueueSize - 1;
	else
		WritePosition = tcb.QueueRetransmit.WritePos - 1;
	tcb.SequenceOfRetransmit[WritePosition] = tcb.Sequence;	
	tcb.QueueRetransmitLength++;	/


	if(DataSize != 0 || (TCPFlag & (TCP_SYN | TCP_FIN)) != 0)
	{
		tcb.FlagOfRetransmit[WritePosition] = TRUE;

		if(TCPTimer.enable == FALSE)
		{
			TCPTimer.enable = TRUE;
			TCPTimer.value = TCP_RETRNSMIT_TIME_OUT;
		}
	}
	else
	{
		tcb.FlagOfRetransmit[WritePosition] = FALSE;
	}

	/* 填充tcp 頭*/
	TCPFillHead(pTCPHead,TCPFlag);


	tcb.Sequence += DataSize;
	if((pTCPHead->flag & TCP_SYN) != 0 || (pTCPHead->flag & TCP_FIN))
		tcb.Sequence++;	

	/* 設置 ip*/
	pIPHead->DestinationIP = tcb.DestinationIP;


	pMemHead->StartPos -= sizeof(struct TCPHeader) + sizeof(struct IPHeader);
	

	if(WriteQueue(page,&(tcb.QueueTCPOut)) == PAGE_NOT_FOUND)
	{
		return SEND_STATE_TCP_OUT_FULL;
	}
	else
	{
		return SEND_STATE_SUCCESS;
	}
}

BYTE TCPPortOK(struct TCPHeader xdata * pTCPHead,struct IPHeader xdata *pIPHead)
{

	if(pTCPHead->flag == TCP_SYN)
	{

		if(tcb.TCP_state == TCP_STATE_LISTEN)
		{
			if(tcb.SourcePort == pTCPHead->DestinationPort)
				return TRUE;
		}
	}
	else
	{

		if(tcb.TCP_state != TCP_STATE_CLOSED && tcb.TCP_state != TCP_STATE_LISTEN)
		{

			if(tcb.SourcePort == pTCPHead->DestinationPort &&
				tcb.DestinationPort == pTCPHead->SourcePort &&
				tcb.DestinationIP == pIPHead->SourceIP)
				return TRUE;
		}
	}
	return FALSE;
}


BYTE TCPExpectedPacket(struct TCPHeader xdata *pTCPHead)
{

	if(pTCPHead->flag & TCP_SYN)
		return TRUE;

	/* sequence ok */
	if(tcb.AckSequence == pTCPHead->Sequence)
		return TRUE;
	else
	{

		if(tcb.TCP_state > TCP_STATE_SYNSENT || tcb.TCP_state == TCP_STATE_SYNRECVD)
		{
			TCPSendPacket(TCPAllocateWithoutData(),TCP_ACK);
		}
		return FALSE;
	}
}



/* TCP state closed */
void TCPStateClosed(struct TCPHeader xdata *pTCPHead,struct IPHeader xdata *pIPHead)
{
}
/* TCP state listen */
void TCPStateListen(struct TCPHeader xdata *pTCPHead,struct IPHeader xdata *pIPHead)
{

	if(pTCPHead->flag == TCP_SYN)
	{
		tcb.TCP_state = TCP_STATE_SYNRECVD;
		tcb.DestinationIP = pIPHead->SourceIP;
		tcb.DestinationPort = pTCPHead->SourcePort;
		
	
		tcb.AckSequence = pTCPHead->Sequence + 1;	/* syn is use 1 sequence */

	
		TCPSendPacket(TCPAllocateWithoutData(),TCP_SYN | TCP_ACK);
	}
}

void TCPStateSynrecvd(struct TCPHeader xdata *pTCPHead,struct IPHeader xdata *pIPHead)
{

	if((pTCPHead->flag & TCP_RST) != 0)
		tcb.TCP_state = TCP_STATE_LISTEN;


	if((pTCPHead->flag & TCP_ACK) != 0)
		tcb.TCP_state = TCP_STATE_ESTABLISHED;
}

void TCPStateSynSent(struct TCPHeader xdata *pTCPHead,struct IPHeader xdata *pIPHead)
{

	if(pTCPHead->flag == TCP_SYN)
	{
		tcb.TCP_state = TCP_STATE_SYNRECVD;

		/* 響應初始化 */
		tcb.AckSequence = pTCPHead->Sequence + 1;	/* syn is use 1 sequence */

		TCPSendPacket(TCPAllocateWithoutData(),TCP_SYN | TCP_ACK);
	}

	
	if(pTCPHead->flag == (TCP_SYN | TCP_ACK))
	{
		tcb.TCP_state = TCP_STATE_ESTABLISHED;

		
		tcb.AckSequence = pTCPHead->Sequence + 1;	

		TCPSendPacket(TCPAllocateWithoutData(),TCP_ACK);
	}


	if((pTCPHead->flag & TCP_RST) != 0)
	{
		tcb.TCP_state = TCP_STATE_CLOSED;
		return;
	}
}
/* 建立 */
void TCPStateEstablished(struct TCPHeader xdata *pTCPHead,struct IPHeader xdata *pIPHead)
{
	WORD DataSize;
	BYTE IPHeadSize,TCPHeadSize;

	
	if((pTCPHead->flag & TCP_FIN) != 0)
	{
		tcb.TCP_state = TCP_STATE_CLOSEWAIT;
		TCPSendPacket(TCPAllocateWithoutData(),TCP_ACK);
	}


	IPHeadSize = (pIPHead->Version_HeadLength & 0x0f)*4;
	TCPHeadSize = ((pTCPHead->TCPHeadLength & 0xf0)>>4)*4;
	DataSize = pIPHead->TotalLength - IPHeadSize - TCPHeadSize;
	if(DataSize != 0)
		TCPSendPacket(TCPAllocateWithoutData(),TCP_ACK);
}

void TCPStateClosewait(struct TCPHeader xdata *pTCPHead,struct IPHeader xdata *pIPHead)
{
}

void TCPStateFinwait1(struct TCPHeader xdata *pTCPHead,struct IPHeader xdata *pIPHead)
{

	if(pTCPHead->flag == TCP_FIN)
	{
		tcb.TCP_state = TCP_STATE_CLOSING;
		TCPSendPacket(TCPAllocateWithoutData(),TCP_ACK);
		return;
	}


	if(pTCPHead->flag == (TCP_FIN | TCP_ACK))
	{
		tcb.TCP_state = TCP_STATE_CLOSED;
		TCPSendPacket(TCPAllocateWithoutData(),TCP_ACK);
		return;
	}
	

	if(pTCPHead->flag == TCP_ACK)
	{
		tcb.TCP_state = TCP_STATE_FINWAIT2;
	}

}

void TCPStateClosing(struct TCPHeader xdata *pTCPHead,struct IPHeader xdata *pIPHead)
{
	
	if((pTCPHead->flag & TCP_ACK) != 0)
	{
		tcb.TCP_state = TCP_STATE_CLOSED;
	}
}

void TCPStateFinwait2(struct TCPHeader xdata *pTCPHead,struct IPHeader xdata *pIPHead)
{
	if((pTCPHead->flag & TCP_FIN) != 0)
	{
		tcb.TCP_state = TCP_STATE_CLOSED;
		TCPSendPacket(TCPAllocateWithoutData(),TCP_ACK);
	}
}

/* 接收一個包, tcb 需要更新. */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一级免费大片| 国产午夜精品福利| 中文字幕高清一区| 日本午夜精品视频在线观看| 韩国欧美国产1区| 日本高清不卡视频| 久久精品一区二区三区不卡牛牛| 亚洲午夜羞羞片| 国产91在线看| 欧美精品一区二区三区很污很色的| 日韩理论在线观看| 国产高清在线观看免费不卡| 欧美日韩电影在线播放| 亚洲欧洲三级电影| 国产精品一区二区男女羞羞无遮挡 | 亚洲一线二线三线视频| 韩国成人精品a∨在线观看| 色偷偷久久人人79超碰人人澡| 久久一日本道色综合| 三级在线观看一区二区| 91片黄在线观看| 国产精品乱人伦| 国产成人综合亚洲91猫咪| 日韩精品一区在线| 免费在线观看成人| 91精品国产品国语在线不卡| 亚洲国产综合在线| 欧美日韩国产综合视频在线观看| 亚洲视频资源在线| 色综合久久天天综合网| 中文字幕在线一区免费| 成人免费视频播放| 亚洲欧美综合另类在线卡通| 国产呦精品一区二区三区网站 | 欧美色精品在线视频| 亚洲精品成人天堂一二三| jvid福利写真一区二区三区| 国产网站一区二区| 国产黄色成人av| 国产精品美女久久久久久久网站| 国产精品99久久不卡二区| 久久久美女毛片| 国产成人在线观看免费网站| 久久久午夜精品理论片中文字幕| 国产精品1024| 中文字幕日本不卡| 一本大道久久a久久综合| 一区二区在线免费观看| 欧美丰满高潮xxxx喷水动漫| 久久99国产精品麻豆| 日本一区二区三区国色天香| 91女神在线视频| 日韩不卡在线观看日韩不卡视频| 日韩欧美国产综合| 成人一区在线看| 亚洲一区二区三区激情| 日韩一区二区三区观看| 国产主播一区二区| 亚洲三级久久久| 欧美乱妇20p| 国产激情视频一区二区在线观看 | 久久久美女毛片| 99这里只有久久精品视频| 一区二区在线观看视频| 欧美一卡2卡3卡4卡| 成人一级黄色片| 亚洲一区二区三区四区五区中文| 日韩美女视频在线| 不卡av免费在线观看| 亚洲国产精品久久久久婷婷884| 日韩一区二区在线免费观看| 成人激情av网| 美女精品自拍一二三四| 亚洲欧美日本韩国| 欧美成人欧美edvon| 日本道色综合久久| 国产精品一区二区三区99| 亚洲一区二区三区不卡国产欧美| 久久久久久免费| 欧美性色黄大片| 大陆成人av片| 蜜臀av性久久久久蜜臀aⅴ四虎| 国产精品久久久久aaaa樱花| 日韩午夜激情电影| 日本道色综合久久| 国产91精品欧美| 美女尤物国产一区| 亚洲综合图片区| 国产精品久99| 久久久久久久久久美女| 日本一二三不卡| 日韩午夜激情视频| 欧美在线观看禁18| www.欧美色图| 国产精品自在在线| 秋霞成人午夜伦在线观看| 有坂深雪av一区二区精品| 国产精品免费观看视频| 久久亚洲一区二区三区明星换脸 | 成人永久aaa| 国产米奇在线777精品观看| 亚洲福利视频一区二区| 国产精品国产三级国产三级人妇| 欧美不卡一区二区三区| 91精品国产麻豆国产自产在线| 色综合天天综合网天天狠天天 | 蜜桃av一区二区在线观看| 夜夜亚洲天天久久| 亚洲卡通欧美制服中文| 中文字幕一区二区三区av| 久久综合五月天婷婷伊人| 91精品免费观看| 91超碰这里只有精品国产| 在线观看成人小视频| 91社区在线播放| 91国在线观看| 91成人国产精品| 欧美日韩国产高清一区二区| 欧美日韩亚洲高清一区二区| 91国产丝袜在线播放| 色嗨嗨av一区二区三区| 91网页版在线| 欧美色视频在线观看| 欧美日韩国产首页| 欧美一三区三区四区免费在线看| 欧美日韩大陆一区二区| 日韩一区二区在线观看视频播放| 欧美一二三四在线| 精品国产乱码久久久久久闺蜜 | 欧美mv和日韩mv国产网站| 日韩欧美高清一区| 久久综合久久鬼色| 国产精品狼人久久影院观看方式| 国产精品久久久久久久久动漫| 亚洲色图视频网| 亚洲国产日韩a在线播放| 亚洲va欧美va人人爽| 日本视频一区二区三区| 精品一区二区三区免费观看| 国产suv精品一区二区883| 99精品视频在线免费观看| 欧美三级电影一区| 欧美成人综合网站| 国产精品久久久久婷婷二区次| 亚洲免费成人av| 蜜臀av在线播放一区二区三区| 韩国女主播成人在线| 一道本成人在线| 日韩欧美久久久| 亚洲嫩草精品久久| 激情欧美一区二区三区在线观看| 播五月开心婷婷综合| 欧美视频在线播放| 国产亚洲欧美日韩俺去了| 一区二区三区在线高清| 美腿丝袜在线亚洲一区| 99久久精品国产观看| 欧美一区二区视频观看视频| 久久精品欧美一区二区三区麻豆 | 加勒比av一区二区| 91在线观看高清| 欧美精品一区二区三区四区| 一区二区三区中文在线观看| 美女视频一区在线观看| 95精品视频在线| 精品蜜桃在线看| 亚洲一区在线播放| 国产成人aaa| 欧美一区二区三区在线看| 亚洲三级免费电影| 国产一区二区电影| 欧美一区二区三区啪啪| 亚洲欧美色图小说| 国产91精品久久久久久久网曝门| 欧美二区三区的天堂| 亚洲精品欧美综合四区| 国产精品一区不卡| 欧美一区二区三区免费| 亚洲精选视频在线| 国产成人欧美日韩在线电影| 欧美一区二区三级| 亚洲图片欧美视频| 91久久香蕉国产日韩欧美9色| 久久精品综合网| 久久99在线观看| 91精品国产综合久久香蕉的特点 | 免费观看在线色综合| 欧美天堂亚洲电影院在线播放| 国产精品青草久久| 国产一区二区三区综合| 日韩欧美国产不卡| 日韩va亚洲va欧美va久久| 欧美性受xxxx黑人xyx性爽| 亚洲欧美日韩国产另类专区| av一区二区三区| 亚洲欧洲日韩女同| 97久久精品人人做人人爽50路| 国产精品毛片高清在线完整版| 高清不卡一区二区| 国产精品欧美极品|