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

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

?? ip.c

?? 提供TCP/IP的詳細信息
?? C
?? 第 1 頁 / 共 2 頁
字號:
		nextfrag->buf = *bpp;
		bpp = NULL;
		append(&nextfrag->buf,&tbp);
		nextfrag->offset = ip->offset;	/* Extend backward */
		break;
	case (APPEND|PREPEND):
		/* Consolidate by appending this fragment and nextfrag
		 * to lastfrag and removing the nextfrag descriptor
		 */
		append(&lastfrag->buf,bpp);
		append(&lastfrag->buf,&nextfrag->buf);
		nextfrag->buf = NULL;
		lastfrag->last = nextfrag->last;

		/* Finally unlink and delete the now unneeded nextfrag */
		lastfrag->next = nextfrag->next;
		if(nextfrag->next != NULL)
			nextfrag->next->prev = lastfrag;
		freefrag(nextfrag);
		break;
	}
	if(rp->fraglist->offset == 0 && rp->fraglist->next == NULL 
		&& rp->length != 0){

		/* We've gotten a complete datagram, so extract it from the
		 * reassembly buffer and pass it on.
		 */
		*bpp = rp->fraglist->buf;
		rp->fraglist->buf = NULL;
		/* Tell IP the entire length */
		ip->length = rp->length + (IPLEN + ip->optlen);
		free_reasm(rp);
		ipReasmOKs++;
		ip->offset = 0;
		ip->flags.mf = 0;
		return ip->length;
	} else
		return -1;
}
/* Arrange for receipt of raw IP datagrams */
struct raw_ip *
raw_ip(
int protocol,
void (*r_upcall)()
){
	register struct raw_ip *rp;

	rp = (struct raw_ip *)callocw(1,sizeof(struct raw_ip));
	rp->protocol = protocol;
	rp->r_upcall = r_upcall;
	rp->next = Raw_ip;
	Raw_ip = rp;
	return rp;
}
/* Free a raw IP descriptor */
void
del_ip(
struct raw_ip *rpp
){
	struct raw_ip *rplast = NULL;
	register struct raw_ip *rp;

	/* Do sanity check on arg */
	for(rp = Raw_ip;rp != NULL;rplast=rp,rp = rp->next)
		if(rp == rpp)
			break;
	if(rp == NULL)
		return;	/* Doesn't exist */

	/* Unlink */
	if(rplast != NULL)
		rplast->next = rp->next;
	else
		Raw_ip = rp->next;
	/* Free resources */
	free_q(&rp->rcvq);
	free(rp);
}

static struct reasm *
lookup_reasm(
struct ip *ip
){
	register struct reasm *rp;
	struct reasm *rplast = NULL;

	for(rp = Reasmq;rp != NULL;rplast=rp,rp = rp->next){
		if(ip->id == rp->id && ip->source == rp->source
		 && ip->dest == rp->dest && ip->protocol == rp->protocol){
			if(rplast != NULL){
				/* Move to top of list for speed */
				rplast->next = rp->next;
				rp->next = Reasmq;
				Reasmq = rp;
			}
			return rp;
		}

	}
	return NULL;
}
/* Create a reassembly descriptor,
 * put at head of reassembly list
 */
static struct reasm *
creat_reasm(
struct ip *ip
){
	register struct reasm *rp;

	if((rp = (struct reasm *)calloc(1,sizeof(struct reasm))) == NULL)
		return rp;	/* No space for descriptor */
	rp->source = ip->source;
	rp->dest = ip->dest;
	rp->id = ip->id;
	rp->protocol = ip->protocol;
	set_timer(&rp->timer,ipReasmTimeout * 1000L);
	rp->timer.func = ip_timeout;
	rp->timer.arg = rp;

	rp->next = Reasmq;
	Reasmq = rp;
	return rp;
}

/* Free all resources associated with a reassembly descriptor */
static void
free_reasm(
struct reasm *r
){
	register struct reasm *rp;
	struct reasm *rplast = NULL;
	register struct frag *fp;

	for(rp = Reasmq;rp != NULL;rplast = rp,rp=rp->next)
		if(r == rp)
			break;
	if(rp == NULL)
		return;	/* Not on list */

	stop_timer(&rp->timer);
	/* Remove from list of reassembly descriptors */
	if(rplast != NULL)
		rplast->next = rp->next;
	else
		Reasmq = rp->next;

	/* Free any fragments on list, starting at beginning */
	while((fp = rp->fraglist) != NULL){
		rp->fraglist = fp->next;
		free_p(&fp->buf);
		free(fp);
	}
	free(rp);
}

/* Handle reassembly timeouts by deleting all reassembly resources */
static void
ip_timeout(
void *arg
){
	free_reasm((struct reasm *)arg);
	ipReasmFails++;
}
/* Create a fragment */
static struct frag *
newfrag(
uint16 offset,
uint16 last,
struct mbuf **bpp
){
	struct frag *fp;

	if((fp = (struct frag *)calloc(1,sizeof(struct frag))) == NULL){
		/* Drop fragment */
		free_p(bpp);
		return NULL;
	}
	fp->buf = *bpp;
	*bpp = NULL;
	fp->offset = offset;
	fp->last = last;
	return fp;
}
/* Delete a fragment, return next one on queue */
static void
freefrag(
struct frag *fp
){
	free_p(&fp->buf);
	free(fp);
}

/* In red alert mode, blow away the whole reassembly queue. Otherwise crunch
 * each fragment on each reassembly descriptor
 */
void
ip_garbage(
int red
){
	struct reasm *rp,*rp1;
	struct frag *fp;
	struct raw_ip *rwp;
	struct iface *ifp;

	/* Run through the reassembly queue */
	for(rp = Reasmq;rp != NULL;rp = rp1){
		rp1 = rp->next;
		if(red){
			free_reasm(rp);
		} else {
			for(fp = rp->fraglist;fp != NULL;fp = fp->next){
				mbuf_crunch(&fp->buf);
			}
		}
	}
	/* Run through the raw IP queue */
	for(rwp = Raw_ip;rwp != NULL;rwp = rwp->next)
		mbuf_crunch(&rwp->rcvq);

	/* Walk through interface output queues and decrement IP TTLs.
	 * Discard and return ICMP TTL exceeded messages for any that
	 * go to zero. (Some argue that this ought to be done all the
	 * time, but it would probably break a lot of machines with
	 * small IP TTL settings using amateur packet radio paths.)
	 *
	 * Also send an ICMP source quench message to one
	 * randomly chosen packet on each queue. If in red mode,
	 * also drop the packet.
	 */
	for(ifp=Ifaces;ifp != NULL;ifp = ifp->next){
		ttldec(ifp);
		rquench(ifp,red);
	}
}
/* Decrement the IP TTL field in each packet on the send queue. If
 * a TTL goes to zero, discard the packet.
 */
void
ttldec(
struct iface *ifp
){
	struct mbuf *bp,*bpprev,*bpnext;
	struct qhdr qhdr;
	struct ip ip;

	bpprev = NULL;
	for(bp = ifp->outq; bp != NULL;bpprev = bp,bp = bpnext){
		bpnext = bp->anext;
		pullup(&bp,&qhdr,sizeof(qhdr));
		ntohip(&ip,&bp);
		if(--ip.ttl == 0){
			/* Drop packet */
			icmp_output(&ip,bp,ICMP_TIME_EXCEED,0,NULL);
			if(bpprev == NULL)	/* First on queue */
				ifp->outq = bpnext;
			else
				bpprev->anext = bpnext;
			free_p(&bp);
			bp = bpprev; 
			continue;
		}
		/* Put IP and queue headers back, restore to queue */
		htonip(&ip,&bp,0);
		pushdown(&bp,&qhdr,sizeof(qhdr));
		if(bpprev == NULL)	/* First on queue */
			ifp->outq = bp;
		else
			bpprev->anext = bp;
		bp->anext = bpnext;
	}
}

/* Execute random quench algorithm on an interface's output queue */
void
rquench(
struct iface *ifp,
int drop
){
	struct mbuf *bp,*bplast;
	int i;
	struct qhdr qhdr;
	struct ip ip;
	struct mbuf *bpdup;

	if((i = len_q(ifp->outq)) == 0)
		return;	/* Queue is empty */

	i = urandom(i);	/* Select a victim */

	/* Search for i-th message on queue */
	bplast = NULL;
	for(bp = ifp->outq;bp != NULL && i>0;i--,bplast=bp,bp=bp->anext)
		;
	if(bp == NULL)
		return;	/* "Can't happen" */

	/* Send a source quench */
	dup_p(&bpdup,bp,0,len_p(bp));
	pullup(&bpdup,&qhdr,sizeof(qhdr));
	ntohip(&ip,&bpdup);
	icmp_output(&ip,bpdup,ICMP_QUENCH,0,NULL);
	free_p(&bpdup);
	if(!drop)
		return;	/* All done */

	/* Drop the packet */
	if(bplast != NULL)
		bplast->anext = bp->anext;
	else
		ifp->outq = bp->anext;	/* First on list */
	free_p(&bp);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久99精品视频| 欧美午夜理伦三级在线观看| 一区二区欧美视频| 精品美女在线观看| 91久久精品午夜一区二区| av福利精品导航| 国产成人亚洲综合a∨婷婷| 首页综合国产亚洲丝袜| 亚洲自拍偷拍欧美| 欧美国产精品v| 国产精品久久免费看| 国产亚洲欧洲997久久综合 | 精品在线视频一区| 精品亚洲成av人在线观看| 国产精一品亚洲二区在线视频| 欧美精品一区二区三区蜜臀| 国产高清精品在线| 99精品在线免费| 国产伦精品一区二区三区免费迷 | 综合色中文字幕| 国产午夜精品一区二区三区嫩草| 中日韩免费视频中文字幕| 亚洲高清免费观看| 国产成人av电影在线| 精品国产一区久久| 蜜臀av性久久久久蜜臀aⅴ四虎 | 国产传媒日韩欧美成人| 91香蕉视频在线| 色哟哟精品一区| 欧美亚洲日本一区| 欧美大片一区二区| 91精品国产综合久久久久久| 亚洲精品视频一区| 亚洲视频一区在线| 久久99精品久久久久| 欧美视频一区二区三区四区| 亚洲欧美一区二区视频| 色一情一乱一乱一91av| 国产精品久久三区| 色素色在线综合| 一区二区三区不卡在线观看| 91久久人澡人人添人人爽欧美| 亚洲欧美日本在线| 欧美少妇xxx| 偷拍一区二区三区四区| 欧美喷水一区二区| 国产成人8x视频一区二区| 国产精品国产三级国产有无不卡| 久久综合色之久久综合| 亚洲品质自拍视频| 美女网站在线免费欧美精品| 91视频国产资源| 欧美一卡二卡三卡| 亚洲综合清纯丝袜自拍| 日韩三级免费观看| 国产99久久精品| 性做久久久久久久免费看| 日韩一二三区不卡| 精品视频一区二区不卡| 午夜精品久久久久久久久久| 国产精品123| 色香蕉成人二区免费| 精品国产乱码久久久久久牛牛| 久久不见久久见免费视频7| 欧美在线不卡视频| 亚洲色图色小说| 91精品国产高清一区二区三区| 韩国精品免费视频| 日韩影院免费视频| 亚洲品质自拍视频| 欧美激情一区二区| 欧美电影免费提供在线观看| 成人黄色片在线观看| 同产精品九九九| 综合av第一页| 国产精品理论片在线观看| 欧美精品久久一区二区三区| 成人动漫中文字幕| 国产一区二区三区蝌蚪| 日本美女一区二区| 日韩专区欧美专区| 青青草伊人久久| 久久99精品久久久| 日韩激情视频在线观看| 日韩—二三区免费观看av| 亚洲国产美女搞黄色| 亚洲精品自拍动漫在线| 中文字幕一区二区在线播放| 亚洲视频精选在线| 一区二区免费看| 免费精品视频在线| 久久99精品国产.久久久久久| 麻豆一区二区在线| 国产精品综合二区| 91麻豆文化传媒在线观看| 在线观看三级视频欧美| 91麻豆精品国产自产在线| 日韩视频国产视频| 久久蜜桃av一区精品变态类天堂| 国产视频在线观看一区二区三区| 国产精品美女久久久久久久| 亚洲制服欧美中文字幕中文字幕| 亚洲超丰满肉感bbw| 精品在线观看免费| 91捆绑美女网站| 欧美老肥妇做.爰bbww视频| 久久综合久久久久88| 国产欧美精品一区二区三区四区| 中文字幕一区在线观看视频| 日本午夜精品一区二区三区电影| 国产一区二区网址| 在线综合+亚洲+欧美中文字幕| 久久久久久久久一| 日本va欧美va欧美va精品| 色噜噜狠狠一区二区三区果冻| jiyouzz国产精品久久| 天天av天天翘天天综合网| 极品少妇一区二区三区精品视频| av不卡免费在线观看| 久久久五月婷婷| 日本aⅴ精品一区二区三区| 一本久久a久久精品亚洲| 国产精品五月天| 国产伦精品一区二区三区免费| 日韩欧美国产麻豆| 婷婷中文字幕综合| 91精品国产免费| 日韩精品一级二级| 日韩一卡二卡三卡| 卡一卡二国产精品| 久久精品日产第一区二区三区高清版| 奇米影视在线99精品| 日韩午夜精品视频| 激情深爱一区二区| 久久综合色综合88| 激情综合一区二区三区| 亚洲精品一区二区三区99| 国产麻豆精品一区二区| 国产校园另类小说区| 成人黄色国产精品网站大全在线免费观看 | 亚洲香肠在线观看| 欧美精品色一区二区三区| 精品一区二区影视| 国产精品丝袜在线| 欧美日韩午夜在线视频| 免费成人在线播放| 久久久久国产精品免费免费搜索| www.日本不卡| 青青草国产精品97视觉盛宴| 国产无人区一区二区三区| 色老综合老女人久久久| 极品美女销魂一区二区三区免费| 欧美韩日一区二区三区四区| 欧美视频一区二区三区四区| 久久99国产精品尤物| 曰韩精品一区二区| 欧美高清在线精品一区| 91精品国产综合久久小美女| 成人黄色综合网站| 蜜臀久久久久久久| 亚洲大片免费看| 最新高清无码专区| 日本一区二区三区dvd视频在线| 欧亚一区二区三区| 95精品视频在线| 国产美女视频91| 毛片不卡一区二区| 石原莉奈在线亚洲三区| 亚洲一区二区三区四区中文字幕| 中文字幕一区日韩精品欧美| 国产亚洲综合色| 久久免费午夜影院| 日韩免费电影一区| 精品国产百合女同互慰| 日韩欧美中文字幕一区| 精品国产乱码久久久久久免费 | 免费高清在线视频一区·| 一区二区欧美国产| 日韩精品视频网| 久久电影网电视剧免费观看| 美女一区二区久久| 国产精品一区二区果冻传媒| 国产一区二区主播在线| 91小视频免费观看| 欧美精品第一页| 欧美国产一区二区在线观看 | 国产91高潮流白浆在线麻豆| 国产suv一区二区三区88区| 色综合色狠狠综合色| 欧美久久久久久蜜桃| 久久久久久久久伊人| 亚洲自拍都市欧美小说| 黄一区二区三区| 欧美在线免费观看视频| 日韩一区二区三区高清免费看看| 精品国产一区a| 一区二区三区欧美激情| 国产一区二区不卡在线| 欧美性猛交一区二区三区精品| 日韩欧美精品在线视频|