亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
日韩亚洲国产中文字幕欧美| www.亚洲免费av| 欧美电影免费观看高清完整版在| 亚洲成人精品影院| 在线综合+亚洲+欧美中文字幕| 亚洲第一久久影院| 日韩欧美一区二区在线视频| 美腿丝袜亚洲一区| 国产日韩欧美在线一区| 波多野结衣欧美| 午夜日韩在线观看| 日韩美女主播在线视频一区二区三区| 黑人巨大精品欧美黑白配亚洲| 国产校园另类小说区| jvid福利写真一区二区三区| 亚洲一二三区在线观看| 91精品国产全国免费观看| 国产一本一道久久香蕉| 亚洲乱码日产精品bd| 日韩一区二区三区视频| 丰满亚洲少妇av| 天天亚洲美女在线视频| 国产调教视频一区| 在线观看日产精品| 精品一区二区三区av| 中文字幕亚洲区| 欧美一区二区黄| 成人福利电影精品一区二区在线观看| 亚洲一区二区视频在线观看| 日韩欧美一区二区久久婷婷| 91在线视频在线| 日本系列欧美系列| 中文字幕视频一区| 日韩欧美电影在线| 一本到高清视频免费精品| 久久精品久久综合| 亚洲国产成人av好男人在线观看| 精品国产电影一区二区| 欧美午夜一区二区三区| 国产成人综合亚洲91猫咪| 亚洲h在线观看| 国产精品久久久久久久第一福利| 欧美一级理论片| 色综合久久综合网| 国产福利一区二区三区在线视频| 亚洲综合清纯丝袜自拍| 国产精品欧美久久久久一区二区 | 婷婷成人综合网| 中文字幕精品—区二区四季| 7777精品久久久大香线蕉| 97久久人人超碰| 国产91丝袜在线播放九色| 奇米影视一区二区三区小说| 亚洲一区二区欧美激情| 国产精品免费网站在线观看| 精品国产乱码久久久久久闺蜜| 欧美日韩的一区二区| 色94色欧美sute亚洲线路二| 国产98色在线|日韩| 韩国欧美国产1区| 日欧美一区二区| 亚洲午夜私人影院| 一区二区不卡在线视频 午夜欧美不卡在| 国产欧美日韩三区| 久久人人97超碰com| 欧美一区二区二区| 日韩一区二区三区四区| 91精品欧美综合在线观看最新| 欧美性猛片xxxx免费看久爱| 欧美亚洲国产怡红院影院| 91啪亚洲精品| 91黄色小视频| 欧美性三三影院| 欧美日韩和欧美的一区二区| 欧美日韩五月天| 欧美性感一类影片在线播放| 91官网在线免费观看| 欧洲一区二区三区免费视频| 欧美日韩在线观看一区二区| 国产一区二区毛片| 国产成人亚洲综合a∨猫咪 | 99精品在线观看视频| 处破女av一区二区| av电影一区二区| 91黄色小视频| 欧美一区国产二区| 精品免费视频一区二区| 国产肉丝袜一区二区| 国产欧美日韩另类视频免费观看 | 91精品在线观看入口| 欧美一区二区三区四区五区| 日韩欧美区一区二| 久久精品男人天堂av| 国产精品免费丝袜| 亚洲国产色一区| 久久99精品视频| av在线不卡电影| 欧美日韩免费不卡视频一区二区三区| 91麻豆精品国产自产在线观看一区 | 紧缚捆绑精品一区二区| 成人午夜短视频| 色婷婷综合中文久久一本| 欧美色综合网站| 精品99一区二区三区| **网站欧美大片在线观看| 午夜久久久影院| 国模娜娜一区二区三区| 91麻豆蜜桃一区二区三区| 欧美电影一区二区三区| 2023国产一二三区日本精品2022| 亚洲视频狠狠干| 老司机午夜精品| 色猫猫国产区一区二在线视频| 日韩一区二区免费在线观看| 亚洲欧洲精品天堂一级| 六月丁香综合在线视频| 色综合色狠狠天天综合色| 精品日韩在线一区| 怡红院av一区二区三区| 国产精品亚洲视频| 欧美精品成人一区二区三区四区| 精品国产乱码久久久久久图片| 一区二区在线观看免费| 国产麻豆视频一区二区| 在线不卡的av| 亚洲精品中文在线影院| 国产精品主播直播| 欧美电影一区二区三区| 亚洲欧洲成人自拍| 加勒比av一区二区| 欧美日韩国产一二三| 中文字幕一区二区不卡| 国产一区二区三区免费在线观看| 在线观看免费一区| 国产精品久久久久aaaa| 激情综合一区二区三区| 欧美精品精品一区| 亚洲精品视频在线观看网站| 国产69精品久久久久毛片| 日韩一区二区三区在线视频| 亚洲宅男天堂在线观看无病毒| 粗大黑人巨茎大战欧美成人| 久久综合久久综合九色| 日韩精品一二区| 欧美亚洲国产怡红院影院| 中文字幕亚洲成人| 成人黄页在线观看| 久久久噜噜噜久久中文字幕色伊伊 | 成人黄页毛片网站| 久久综合九色欧美综合狠狠 | 一区二区三区欧美日韩| 国产成人一区在线| 久久蜜桃一区二区| 久久99热这里只有精品| 日韩一卡二卡三卡| 亚洲mv在线观看| 欧美日韩黄色一区二区| 亚洲国产日韩一区二区| 欧美性生活一区| 亚洲国产成人av| 欧美日韩国产片| 午夜伦理一区二区| 欧美高清精品3d| 日本不卡的三区四区五区| 3atv在线一区二区三区| 日本在线不卡视频| 欧美大片一区二区| 久久99精品久久久| www精品美女久久久tv| 国产剧情在线观看一区二区| 精品国产91洋老外米糕| 国产精品一区在线观看你懂的| 精品动漫一区二区三区在线观看 | 成人久久久精品乱码一区二区三区| 久久综合久久综合亚洲| 国产一区二区三区免费在线观看| 久久新电视剧免费观看| 国产电影一区二区三区| 中文字幕在线观看一区| 99re热这里只有精品视频| 亚洲一区二区3| 欧美丰满少妇xxxbbb| 极品销魂美女一区二区三区| 国产欧美日韩不卡| av亚洲产国偷v产偷v自拍| 亚洲国产成人精品视频| 欧美一区二区福利视频| 国产成人av网站| 亚洲人精品一区| 这里只有精品免费| 国产aⅴ综合色| 一区二区三区四区国产精品| 欧美日韩mp4| 国产一区不卡视频| 一区二区三区在线播| 日韩一区二区免费视频| 成人av午夜影院| 三级影片在线观看欧美日韩一区二区| 日韩视频免费直播| 91麻豆视频网站|