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

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

?? tcpsubr.c

?? TCPIP協議包
?? C
字號:
/* Low level TCP routines:
 *  control block management
 *  sequence number logical operations
 *  state transitions
 *  RTT cacheing
 *  garbage collection
 *
 */
#include <stdio.h>
#include "global.h"
#include "timer.h"
#include "mbuf.h"
#include "netuser.h"
#include "internet.h"
#include "tcp.h"
#include "ip.h"

/* TCP connection states */
char *Tcpstates[] = {
	"",
	"Closed",
	"Listen",
	"SYN sent",
	"SYN recv",
	"Estab",
	"FINwait1",
	"FINwait2",
	"Closewait",
	"Last ACK",
	"Closing",
	"Timewait"
};

/* TCP closing reasons */
char *Tcpreasons[] = {
	"Normal",
	"Reset/Refused",
	"Timeout",	/* Not actually used */
	"ICMP"		/* Not actually used */
};
struct tcb *Tcbs;		/* Head of control block list */
uint16 Tcp_mss = DEF_MSS;	/* Maximum segment size to be sent with SYN */
int32 Tcp_irtt = DEF_RTT;	/* Initial guess at round trip time */
int Tcp_trace;			/* State change tracing flag */
int Tcp_syndata;
struct tcp_rtt Tcp_rtt[RTTCACHE];
struct mib_entry Tcp_mib[] = {
	NULL,		0,
	"tcpRtoAlgorithm",	4,	/* Van Jacobsen's algorithm */
	"tcpRtoMin",		0,	/* No lower bound */
	"tcpRtoMax",		MAXINT32,	/* No upper bound */
	"tcpMaxConn",		-1L,	/* No limit */
	"tcpActiveOpens",	0,
	"tcpPassiveOpens",	0,
	"tcpAttemptFails",	0,
	"tcpEstabResets",	0,
	"tcpCurrEstab",		0,
	"tcpInSegs",		0,
	"tcpOutSegs",		0,
	"tcpRetransSegs",	0,
	NULL,		0,	/* Connection state goes here */
	"tcpInErrs",		0,
	"tcpOutRsts",		0,
};


/* Look up TCP connection
 * Return TCB pointer or NULL if nonexistant.
 * Also move the entry to the top of the list to speed future searches.
 */
struct tcb *
lookup_tcb(conn)
register struct connection *conn;
{
	register struct tcb *tcb;
	struct tcb *tcblast = NULL;

	for(tcb=Tcbs;tcb != NULL;tcblast = tcb,tcb = tcb->next){
		/* Yet another structure compatibility hack */
		if(conn->remote.port == tcb->conn.remote.port
		 && conn->local.port == tcb->conn.local.port
		 && conn->remote.address == tcb->conn.remote.address
		 && conn->local.address == tcb->conn.local.address){
			if(tcblast != NULL){
				/* Move to top of list */
				tcblast->next = tcb->next;
				tcb->next = Tcbs;
				Tcbs = tcb;
			}
			return tcb;
		}

	}
	return NULL;
}

/* Create a TCB, return pointer. Return pointer if TCB already exists. */
struct tcb *
create_tcb(conn)
struct connection *conn;
{
	register struct tcb *tcb;
	struct tcp_rtt *tp;

	if((tcb = lookup_tcb(conn)) != NULL)
		return tcb;
	tcb = (struct tcb *)callocw(1,sizeof (struct tcb));
	ASSIGN(tcb->conn,*conn);

	tcb->state = TCP_CLOSED;
	tcb->cwind = tcb->mss = Tcp_mss;
	tcb->ssthresh = 65535;
	if((tp = rtt_get(tcb->conn.remote.address)) != NULL){
		tcb->srtt = tp->srtt;
		tcb->mdev = tp->mdev;
	} else {
		tcb->srtt = Tcp_irtt;	/* mdev = 0 */
	}
	/* Initialize timer intervals */
	set_timer(&tcb->timer,tcb->srtt);
	tcb->timer.func = tcp_timeout;
	tcb->timer.arg = tcb;

	tcb->next = Tcbs;
	Tcbs = tcb;		
	return tcb;
}

/* Close our TCB */
void
close_self(tcb,reason)
register struct tcb *tcb;
int reason;
{
	struct reseq *rp1;
	register struct reseq *rp;

	if(tcb == NULL)
		return;

	stop_timer(&tcb->timer);
	tcb->reason = reason;

	/* Flush reassembly queue; nothing more can arrive */
	for(rp = tcb->reseq;rp != NULL;rp = rp1){
		rp1 = rp->next;
		free_p(&rp->bp);
		free(rp);
	}
	tcb->reseq = NULL;
	settcpstate(tcb,TCP_CLOSED);
}

/* Sequence number comparisons
 * Return true if x is between low and high inclusive,
 * false otherwise
 */
int
seq_within(x,low,high)
register int32 x,low,high;
{
	if(low <= high){
		if(low <= x && x <= high)
			return 1;
	} else {
		if(low >= x && x >= high)
			return 1;
	}
	return 0;
}
int
seq_lt(x,y)
register int32 x,y;
{
	return (long)(x-y) < 0;
}
#ifdef	notdef
int
seq_le(x,y)
register int32 x,y;
{
	return (long)(x-y) <= 0;
}
#endif	/* notdef */
int
seq_gt(x,y)
register int32 x,y;
{
	return (long)(x-y) > 0;
}
int
seq_ge(x,y)
register int32 x,y;
{
	return (long)(x-y) >= 0;
}

void
settcpstate(tcb,newstate)
register struct tcb *tcb;
enum tcp_state newstate;
{
	enum tcp_state oldstate;

	oldstate = tcb->state;
	tcb->state = newstate;
	if(Tcp_trace)
		printf("TCB %p %s -> %s\n",tcb,
		 Tcpstates[oldstate],Tcpstates[newstate]);

	/* Update MIB variables */
	switch(oldstate){
	case TCP_CLOSED:
		if(newstate == TCP_SYN_SENT)
			tcpActiveOpens++;
		break;
	case TCP_LISTEN:
		if(newstate == TCP_SYN_RECEIVED)
			tcpPassiveOpens++;
		break;
	case TCP_SYN_SENT:
		if(newstate == TCP_CLOSED)
			tcpAttemptFails++; 
		break;
	case TCP_SYN_RECEIVED:
		switch(newstate){
		case TCP_CLOSED:
		case TCP_LISTEN:
			tcpAttemptFails++; 
			break;
		}
		break;
	case TCP_ESTABLISHED:
	case TCP_CLOSE_WAIT:
		switch(newstate){
		case TCP_CLOSED:
		case TCP_LISTEN:
			tcpEstabResets++;
			break;
		}
		tcpCurrEstab--;
		break;
	}
	if(newstate == TCP_ESTABLISHED || newstate == TCP_CLOSE_WAIT)
		tcpCurrEstab++;

	if(tcb->s_upcall)
		(*tcb->s_upcall)(tcb,oldstate,newstate);

	switch(newstate){
	case TCP_SYN_RECEIVED:	/***/
	case TCP_ESTABLISHED:
		/* Notify the user that he can begin sending data */
		if(tcb->t_upcall)
			(*tcb->t_upcall)(tcb,tcb->window - tcb->sndcnt);
		break;
	}
}
/* Round trip timing cache routines.
 * These functions implement a very simple system for keeping track of
 * network performance for future use in new connections.
 * The emphasis here is on speed of update (rather than optimum cache hit
 * ratio) since rtt_add is called every time a TCP connection updates
 * its round trip estimate.
 */
void
rtt_add(addr,rtt)
int32 addr;		/* Destination IP address */
int32 rtt;
{
	register struct tcp_rtt *tp;
	int32 abserr;

	if(addr == 0)
		return;
	tp = &Tcp_rtt[(unsigned short)addr % RTTCACHE];
	if(tp->addr != addr){
		/* New entry */
		tp->addr = addr;
		tp->srtt = rtt;
		tp->mdev = 0;
	} else {
		/* Run our own SRTT and MDEV integrators, with rounding */
		abserr = (rtt > tp->srtt) ? rtt - tp->srtt : tp->srtt - rtt;
		tp->srtt = ((AGAIN-1)*tp->srtt + rtt + (AGAIN/2)) >> LAGAIN;
		tp->mdev = ((DGAIN-1)*tp->mdev + abserr + (DGAIN/2)) >> LDGAIN;
	}
}
struct tcp_rtt *
rtt_get(addr)
int32 addr;
{
	register struct tcp_rtt *tp;

	if(addr == 0)
		return NULL;
	tp = &Tcp_rtt[(unsigned short)addr % RTTCACHE];
	if(tp->addr != addr)
		return NULL;
	return tp;
}

/* TCP garbage collection - called by storage allocator when free space
 * runs low. The send and receive queues are crunched. If the situation
 * is red, the resequencing queue is discarded; otherwise it is
 * also crunched.
 */
void
tcp_garbage(red)
int red;
{
	register struct tcb *tcb;
	struct reseq *rp,*rp1;

	for(tcb = Tcbs;tcb != NULL;tcb = tcb->next){
		mbuf_crunch(&tcb->rcvq);
		mbuf_crunch(&tcb->sndq);
		for(rp = tcb->reseq;rp != NULL;rp = rp1){
			rp1 = rp->next;
			if(red){
				free_p(&rp->bp);
				free(rp);
			} else {
				mbuf_crunch(&rp->bp);
			}
		}
		if(red)
			tcb->reseq = NULL;
	}
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩欧美电影一二三| 成人午夜电影小说| 亚洲视频免费在线观看| 久久男人中文字幕资源站| 51精品久久久久久久蜜臀| 欧美视频完全免费看| 日本韩国一区二区三区| 色悠悠久久综合| 色婷婷国产精品久久包臀| 色94色欧美sute亚洲线路一久| 97aⅴ精品视频一二三区| 97超碰欧美中文字幕| 91美女在线看| 欧美男女性生活在线直播观看| 色婷婷av一区二区三区gif| 91玉足脚交白嫩脚丫在线播放| 欧美一激情一区二区三区| 欧美精品免费视频| 日韩情涩欧美日韩视频| www日韩大片| 国产精品嫩草99a| 亚洲免费观看高清在线观看| 亚洲人成网站影音先锋播放| 亚洲国产欧美日韩另类综合| 日韩精品亚洲专区| 国产在线播放一区三区四| 国产999精品久久久久久绿帽| 国产99久久久国产精品潘金| av欧美精品.com| 欧美撒尿777hd撒尿| 日韩欧美国产精品一区| 国产日本欧洲亚洲| 一区二区三区在线免费观看| 日本欧美久久久久免费播放网| 精品在线一区二区三区| 不卡的看片网站| 欧美日韩免费观看一区二区三区 | 美女视频网站黄色亚洲| 国产一区欧美二区| 91麻豆精东视频| 欧美一级艳片视频免费观看| 国产色产综合产在线视频| 亚洲线精品一区二区三区八戒| 久久精品国产精品青草| 97精品久久久午夜一区二区三区| 在线成人av网站| 中文字幕精品在线不卡| 日韩高清不卡一区二区三区| 国产999精品久久久久久 | 亚洲国产一二三| 国产一区二区不卡在线| 欧美综合一区二区| 国产日本亚洲高清| 欧美aaaaaa午夜精品| 色婷婷综合久色| 久久久美女艺术照精彩视频福利播放| 亚洲精品国产无套在线观| 国内精品久久久久影院一蜜桃| 在线视频一区二区免费| 国产精品美女一区二区三区| 久久精品国产精品亚洲精品| 欧美三级在线看| 怡红院av一区二区三区| 成人教育av在线| 久久久不卡影院| 美女视频网站久久| 欧美一区午夜精品| 午夜视黄欧洲亚洲| 欧美日韩一卡二卡| 亚洲免费视频中文字幕| 欧美日韩视频在线观看一区二区三区 | 欧美大白屁股肥臀xxxxxx| 亚洲综合视频网| 成人av手机在线观看| 国产精品三级av| 国产91精品一区二区| 精品动漫一区二区三区在线观看| 日韩一区精品字幕| 欧美精品乱码久久久久久| 亚洲一区二区三区在线| 在线观看国产日韩| 亚洲一区欧美一区| 欧美人狂配大交3d怪物一区| 亚洲国产成人av| 欧美精品v国产精品v日韩精品| 亚洲va欧美va国产va天堂影院| 一本大道av伊人久久综合| 亚洲毛片av在线| 色综合久久综合中文综合网| 一区二区三区丝袜| 欧美群妇大交群的观看方式| 五月激情综合网| 日韩精品一区二区三区在线播放| 麻豆成人免费电影| 国产调教视频一区| 91在线精品一区二区| 亚洲在线中文字幕| 日韩小视频在线观看专区| 蜜桃91丨九色丨蝌蚪91桃色| 精品久久国产字幕高潮| 国产成人h网站| 依依成人精品视频| 67194成人在线观看| 韩国成人精品a∨在线观看| 亚洲国产精品t66y| 日本丶国产丶欧美色综合| 国产99久久久久| 中文字幕综合网| 在线观看91精品国产麻豆| 国产剧情在线观看一区二区| 国产精品久久久久久久久久久免费看| 色综合一区二区| 天天色 色综合| 欧美激情一区不卡| 欧美三级视频在线播放| 国产一区二区三区免费观看| 中文字幕日本乱码精品影院| 6080日韩午夜伦伦午夜伦| 国产精品一区二区91| 亚洲一区二区成人在线观看| 精品成人一区二区三区| 91亚洲精品乱码久久久久久蜜桃 | 91福利视频久久久久| 视频一区在线视频| 中文字幕不卡三区| 91精品国产综合久久久久久久| 国产精品资源站在线| 亚洲h在线观看| 欧美国产日韩精品免费观看| 精品视频1区2区| 成人一区在线看| 久久精品国产一区二区| 亚洲欧美一区二区久久| 久久精品一区二区三区av| 欧美少妇xxx| 99久久伊人网影院| 国产一区二区三区免费看| 日韩成人av影视| 亚洲免费av观看| 亚洲欧洲精品一区二区精品久久久| 91精品国产色综合久久不卡电影| 一本色道a无线码一区v| 国产成人在线网站| 国产一区三区三区| 极品少妇一区二区三区精品视频| 亚洲国产日日夜夜| 一区二区三区美女| 1024精品合集| 日本不卡一区二区| 一级中文字幕一区二区| 国产精品美女久久久久久| 精品999在线播放| 日韩一级免费观看| 91精品国产手机| 欧美高清一级片在线| 欧美日韩一区在线| 欧美视频一区二区| 欧美日韩高清一区| 欧美日韩国产综合草草| 欧美日韩在线免费视频| 欧美精品乱码久久久久久按摩 | 欧美在线观看你懂的| 91香蕉视频在线| 91老师片黄在线观看| 色网综合在线观看| 精品视频一区二区不卡| 欧美丰满美乳xxx高潮www| 欧美精品高清视频| 欧美mv日韩mv国产网站app| 日韩精品一区二| 日本一区二区三区久久久久久久久不 | 91免费视频网址| 欧美这里有精品| 7777精品伊人久久久大香线蕉的 | 久久久久久久久一| 欧美国产亚洲另类动漫| 国产精品护士白丝一区av| 亚洲精品亚洲人成人网| 亚洲国产精品嫩草影院| 热久久一区二区| 国产精品88888| 91丨九色丨国产丨porny| 色先锋aa成人| 欧美一区二区视频网站| 久久久久久久久久电影| 亚洲美女区一区| 丝袜亚洲精品中文字幕一区| 激情综合色播五月| 91色porny蝌蚪| 欧美一卡在线观看| 国产精品你懂的在线欣赏| 一区二区高清免费观看影视大全| 免费观看成人鲁鲁鲁鲁鲁视频| 国产成人精品影视| 欧美精品久久天天躁| 久久精品夜夜夜夜久久| 亚洲在线一区二区三区| 黄页视频在线91| 欧美日韩情趣电影| 国产精品拍天天在线|