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

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

?? tcp.c

?? s3c2410-各個功能模塊開發程序包資料
?? 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一区二区三区免费野_久草精品视频
波多野结衣在线一区| 亚洲影院免费观看| 久久av中文字幕片| 日韩欧美成人一区| 久久99精品久久只有精品| 精品日韩一区二区三区免费视频| 日韩高清在线电影| 欧美精品一区视频| 成人免费高清在线观看| 亚洲综合图片区| 在线播放视频一区| 国产一区二区精品久久| 国产精品美女久久久久aⅴ | 欧美一激情一区二区三区| 免费一级片91| 中文字幕高清不卡| 91国内精品野花午夜精品| 欧美aⅴ一区二区三区视频| 久久精品视频免费| 色综合咪咪久久| 蜜臀精品一区二区三区在线观看| 久久亚洲一级片| 91黄色激情网站| 韩国在线一区二区| 亚洲色图一区二区| 日韩精品自拍偷拍| 91丨porny丨在线| 日韩精品午夜视频| 中文字幕一区av| 日韩美女一区二区三区四区| 成人黄页在线观看| 免费国产亚洲视频| 亚洲综合一区在线| 国产欧美一区二区在线观看| 欧美酷刑日本凌虐凌虐| 国产传媒一区在线| 五月天精品一区二区三区| 欧美高清在线一区| 欧美一区二区三区免费观看视频 | 在线免费不卡电影| 激情六月婷婷综合| 亚洲午夜激情av| 国产欧美一区二区三区在线老狼| 欧美日韩视频不卡| 99久久伊人网影院| 精品影院一区二区久久久| 亚洲综合免费观看高清完整版在线 | 成人综合婷婷国产精品久久蜜臀 | 中文字幕av一区二区三区| 在线不卡欧美精品一区二区三区| 成人av中文字幕| 国内精品伊人久久久久av影院 | 亚洲欧美另类在线| 久久久久99精品一区| 欧美日韩不卡视频| 91久久精品日日躁夜夜躁欧美| 粉嫩aⅴ一区二区三区四区| 久久99国产乱子伦精品免费| 亚洲不卡一区二区三区| 亚洲色图欧美偷拍| 国产精品久久久久久久裸模| 精品国产91乱码一区二区三区 | 亚洲欧美一区二区视频| 精品国产人成亚洲区| 欧美日韩成人综合| 91久久免费观看| 91视频观看免费| 不卡大黄网站免费看| 成人午夜在线免费| 国产成人aaa| 国产精品资源网站| 国产91丝袜在线播放0| 国产在线观看免费一区| 麻豆精品在线播放| 青青草国产精品亚洲专区无| 日本网站在线观看一区二区三区 | 国产盗摄女厕一区二区三区| 国产又粗又猛又爽又黄91精品| 蜜臀av一区二区在线免费观看| 免费人成在线不卡| 久久99国内精品| 国产精品中文欧美| 国产91精品在线观看| 成人精品免费网站| 色天天综合久久久久综合片| 色妞www精品视频| 欧美视频一区二区| 欧美乱妇一区二区三区不卡视频| 欧美男男青年gay1069videost| 7878成人国产在线观看| 欧美一级欧美三级在线观看| 精品对白一区国产伦| 精品国产一区二区精华| 国产精品天天摸av网| 亚洲色图19p| 香蕉久久夜色精品国产使用方法| 午夜伦欧美伦电影理论片| 另类的小说在线视频另类成人小视频在线| 日韩精品乱码免费| 国产精品中文字幕欧美| 99精品国产一区二区三区不卡| 欧美影视一区二区三区| 欧美精品久久天天躁| 精品国产乱码久久久久久免费| 欧美经典一区二区三区| 亚洲乱码日产精品bd| 蜜臀a∨国产成人精品| 高清成人免费视频| 在线免费观看日韩欧美| 欧美v亚洲v综合ⅴ国产v| 国产精品麻豆欧美日韩ww| 亚洲激情自拍偷拍| 美美哒免费高清在线观看视频一区二区 | 7777精品伊人久久久大香线蕉的| 日韩一区二区精品在线观看| 国产午夜一区二区三区| 亚洲一区二区三区中文字幕 | 天天色天天操综合| 国产毛片精品视频| 在线一区二区视频| 国产欧美精品一区二区色综合朱莉| 亚洲男人的天堂在线aⅴ视频| 免费av成人在线| 91婷婷韩国欧美一区二区| 在线91免费看| 日韩久久一区二区| 国内精品久久久久影院薰衣草| 一本久久综合亚洲鲁鲁五月天| 日韩一区二区精品| 亚洲乱码国产乱码精品精小说 | 欧美激情一区在线观看| 亚洲电影你懂得| 岛国精品一区二区| 日韩欧美国产麻豆| 亚洲精品国产一区二区三区四区在线| 蜜臀av一区二区三区| 一本色道久久加勒比精品| 久久综合九色综合97_久久久| 一区二区三区不卡在线观看| 国产精品乡下勾搭老头1| 91精品视频网| 一区二区国产盗摄色噜噜| 国产盗摄精品一区二区三区在线| 91精品欧美一区二区三区综合在| 1000部国产精品成人观看| 国产又黄又大久久| 欧美成人video| 午夜精品一区二区三区三上悠亚| 99久久精品国产一区二区三区| 2023国产精华国产精品| 日韩激情一区二区| 91国产丝袜在线播放| 国产精品国产三级国产a| 国产美女在线精品| 日韩精品一区二区在线| 午夜视频一区在线观看| 色国产综合视频| 中文字幕中文在线不卡住| 国产91对白在线观看九色| 久久久高清一区二区三区| 美女一区二区三区| 欧美一级淫片007| 日本人妖一区二区| 日韩视频中午一区| 美国十次了思思久久精品导航| 欧美电影一区二区三区| 亚洲午夜av在线| 91黄色小视频| 夜夜嗨av一区二区三区四季av| 色呦呦一区二区三区| 亚洲人妖av一区二区| 91香蕉视频污在线| 亚洲裸体在线观看| 欧美专区在线观看一区| 亚洲一区二三区| 欧美日韩国产首页在线观看| 亚洲国产精品精华液网站| 欧美日韩国产在线观看| 午夜激情综合网| 欧美成人精品福利| 国产酒店精品激情| 国产精品久久夜| 在线免费不卡视频| 日本成人超碰在线观看| 日韩欧美视频一区| 国产综合久久久久久久久久久久| 久久嫩草精品久久久精品| 粉嫩av一区二区三区在线播放| 最新中文字幕一区二区三区 | 91精品国产美女浴室洗澡无遮挡| 丝袜美腿亚洲一区二区图片| 日韩免费视频一区| 国产毛片精品国产一区二区三区| 欧美国产日产图区| 一本大道av伊人久久综合| 午夜欧美一区二区三区在线播放| 精品国产乱码久久久久久牛牛| jvid福利写真一区二区三区| 一区二区免费看| 精品国产一区二区三区不卡|