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

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

?? iproute.c

?? 很好的TCP_IP協議源代碼分析,很適用很好
?? C
?? 第 1 頁 / 共 2 頁
字號:
	qhdr.gateway = gateway;

	if(iface->outq == NULL){
		/* Queue empty, no priority decisions to be made
		 * This is the usual case for fast networks like Ethernet,
		 * so we can avoid some time-consuming stuff
		 */
		pushdown(bpp,&qhdr,sizeof(qhdr));
		iface->outq = *bpp;
		*bpp = NULL;
	} else {
		/* See if this packet references a "priority" TCP port number */
		if(ip->protocol == TCP_PTCL && ip->offset == 0){
			/* Extract a copy of the TCP header */
			if(dup_p(&tbp,*bpp,sizeof(struct qhdr)+IPLEN+
			 ip->optlen,TCPLEN+TCP_MAXOPT) >= TCPLEN){
				ntohtcp(&tcp,&tbp);

				for(i=0;Tcp_interact[i] != -1;i++){
					if(tcp.source == Tcp_interact[i]
					 || tcp.dest == Tcp_interact[i]){
						qhdr.tos |= 1;
						break;
					}
				}
			}
			free_p(&tbp);
		}
		pushdown(bpp,&qhdr,sizeof(qhdr));
		/* Search the queue looking for the first packet with precedence
		 * lower than our packet
		 */
		tlast = NULL;
		for(tbp = iface->outq;tbp != NULL;tlast=tbp,tbp = tbp->anext){
			memcpy(&qtmp,tbp->data,sizeof(qtmp));
			if(qhdr.tos > qtmp.tos){
				break;	/* Add it just before tbp */
			}
		}
		(*bpp)->anext = tbp;
		if(tlast == NULL){
			/* First on queue */
			iface->outq = *bpp;
		} else {
			tlast->anext = *bpp;
		}
		*bpp = NULL;
	}
	ksignal(&iface->outq,1);
	if(iface->outlim != 0 && len_q(iface->outq) >= iface->outlim){
		/* Output queue is at limit; return source quench to
		 * the sender of a randomly selected packet on the queue
		 */
		rquench(iface,0);
	}
	return 0;
}
int
ip_encap(
struct mbuf **bpp,
struct iface *iface,
int32 gateway,
uint8 tos
){
	struct ip ip;

	dump(iface,IF_TRACE_OUT,*bpp);
	iface->rawsndcnt++;
	iface->lastsent = secclock();
	if(gateway == 0L){
		/* Gateway must be specified */
		ntohip(&ip,bpp);
		icmp_output(&ip,*bpp,ICMP_DEST_UNREACH,ICMP_HOST_UNREACH,NULL);
		free_p(bpp);
		ipOutNoRoutes++;
		return -1;
	}
	/* Encapsulate in an IP packet from us to the gateway.
	 * The outer source address is taken from the encap interface
	 * structure. This defaults to INADDR_ANY, so unless it is
	 * changed (with iface encap ipaddr ...), the IP address
	 * of the physical interface used to reach the encap gateway
	 * will be used.
	 */
	return ip_send(Encap.addr,gateway,IP_PTCL,tos,0,bpp,0,0,0);
}
/* Add an entry to the IP routing table. Returns 0 on success, -1 on failure */
struct route *
rt_add(
int32 target,		/* Target IP address prefix */
unsigned int bits,	/* Size of target address prefix in bits (0-32) */
int32 gateway,		/* Optional gateway to be reached via interface */
struct iface *iface,	/* Interface to which packet is to be routed */
int32 metric,		/* Metric for this route entry */
int32 ttl,		/* Lifetime of this route entry in sec */
uint8 private		/* Inhibit advertising this entry ? */
){
	struct route *rp,**hp;
	int i;

	if(iface == NULL)
		return NULL;

	if(bits > 32)
		bits = 32;		/* Bulletproofing */

	if(bits == 32 && ismyaddr(target))
		return NULL;	/* Don't accept routes to ourselves */

	/* Mask off don't-care bits of target */
	target &= ~0L << (32-bits);

	/* Encapsulated routes must specify gateway, and it can't be
	 *  ourselves
	 */
	if(iface == &Encap && (gateway == 0 || ismyaddr(gateway)))
		return NULL;

	for(i=0;i<HASHMOD;i++)
		Rt_cache[i].route = NULL;	/* Flush cache */

	/* Zero bits refers to the default route */
	if(bits == 0){
		rp = &R_default;
	} else {
		rp = rt_blookup(target,bits);
	}
	if(rp == NULL){
		/* The target is not already in the table, so create a new
		 * entry and put it in.
		 */
		rp = (struct route *)callocw(1,sizeof(struct route));
		/* Insert at head of table */
		rp->prev = NULL;
		hp = &Routes[bits-1][hash_ip(target)];
		rp->next = *hp;
		if(rp->next != NULL)
			rp->next->prev = rp;
		*hp = rp;
		rp->uses = 0;
	}
	rp->target = target;
	rp->bits = bits;
	rp->gateway = gateway;
	rp->metric = metric;
	rp->iface = iface;
	rp->flags.rtprivate = private;	/* Should anyone be told of this route? */
	rp->timer.func = rt_timeout;  /* Set the timer field */
	rp->timer.arg = (void *)rp;
	set_timer(&rp->timer,ttl*1000L);
	stop_timer(&rp->timer);
	start_timer(&rp->timer); /* start the timer if appropriate */

	return rp;
}

/* Remove an entry from the IP routing table. Returns 0 on success, -1
 * if entry was not in table.
 */
int
rt_drop(
int32 target,
unsigned int bits
){
	register struct route *rp;
	int i;

	for(i=0;i<HASHMOD;i++)
		Rt_cache[i].route = NULL;	/* Flush the cache */

	if(bits == 0){
		/* Nail the default entry */
		stop_timer(&R_default.timer);
		R_default.iface = NULL;
		return 0;
	}
	if(bits > 32)
		bits = 32;

	/* Mask off target according to width */
	target &= ~0L << (32-bits);

	/* Search appropriate chain for existing entry */
	for(rp = Routes[bits-1][hash_ip(target)];rp != NULL;rp = rp->next){
		if(rp->target == target)
			break;
	}
	if(rp == NULL)
		return -1;	/* Not in table */

	stop_timer(&rp->timer);
	if(rp->next != NULL)
		rp->next->prev = rp->prev;
	if(rp->prev != NULL)
		rp->prev->next = rp->next;
	else
		Routes[bits-1][hash_ip(target)] = rp->next;

	free(rp);
	return 0;
}
#ifdef	notdef

/* Compute hash function on IP address */
static uint16
hash_ip(
int32 addr
){
	register uint16 ret;

	ret = hiword(addr);
	ret ^= loword(addr);
	return (uint16)(ret % HASHMOD);
}
#endif
#ifndef	GWONLY
/* Given an IP address, return the MTU of the local interface used to
 * reach that destination. This is used by TCP to avoid local fragmentation
 */
uint16
ip_mtu(
int32 addr
){
	register struct route *rp;
	struct iface *iface;

	rp = rt_lookup(addr);
	if(rp == NULL || rp->iface == NULL)
		return 0;
	if(rp->iface == &Encap){
		/* Recurse to the actual hardware interface */
		return ip_mtu(rp->gateway) - IPLEN;	/* no options? */
	}
	iface = rp->iface;
#ifdef	IPSEC
	if(iface->forw != NULL)
		return iface->forw->mtu - sec_overhead(addr);
	else
		return iface->mtu - sec_overhead(addr);
#else
	if(iface->forw != NULL)
		return iface->forw->mtu;
	else
		return iface->mtu;
#endif
}
/* Given a destination address, return the IP address of the local
 * interface that will be used to reach it. If there is no route
 * to the destination, pick the first non-loopback address.
 */
int32
locaddr(addr)
int32 addr;
{
	register struct route *rp;
	struct iface *ifp;

	if(ismyaddr(addr) != NULL)
		return addr;	/* Loopback case */

	if((rp = rt_lookup(addr)) != NULL)
		ifp = rp->iface;
	else
		ifp = NULL;

	if(ifp == &Encap){
		if((rp = rt_lookup(rp->gateway)) != NULL)
			ifp = rp->iface;
		else
			ifp = NULL;
	}
	if(ifp == NULL){
		/* No route currently exists, so just pick the first real
		 * interface and use its address
		 */
		for(ifp = Ifaces;ifp != NULL;ifp = ifp->next){
			if(ifp != &Loopback && ifp != &Encap)
				break;
		}
	}
	if(ifp == NULL || ifp == &Loopback)
		return 0;	/* No dice */

	if(ifp->forw != NULL)
		return ifp->forw->addr;
	else
		return ifp->addr;
}
#endif
/* Look up target in hash table, matching the entry having the largest number
 * of leading bits in common. Return default route if not found;
 * if default route not set, return NULL
 */
struct route *
rt_lookup(target)
int32 target;
{
	register struct route *rp;
	int bits;
	int32 tsave;
	int32 mask;
	struct rt_cache *rcp;

	Rtlookups++;
	/* Examine cache first */
	rcp = &Rt_cache[hash_ip(target)];
	if(target == rcp->target && (rp = rcp->route) != NULL){
		Rtchits++;
		return rp;
	}
	tsave = target;

	mask = ~0;	/* All ones */
	for(bits = 31;bits >= 0; bits--){
		target &= mask;
		for(rp = Routes[bits][hash_ip(target)];rp != NULL;rp = rp->next){
			if(rp->target != target
			 || (rp->iface == &Encap && rp->gateway == tsave))
				continue;
			/* Stash in cache and return */
			rcp->target = tsave;
			rcp->route = rp;
			return rp;
		}
		mask <<= 1;
	}
	if(R_default.iface != NULL){
		rcp->target = tsave;
		rcp->route = &R_default;
		return &R_default;
	} else
		return NULL;
}
/* Search routing table for entry with specific width */
struct route *
rt_blookup(target,bits)
int32 target;
unsigned int bits;
{
	register struct route *rp;

	if(bits == 0){
		if(R_default.iface != NULL)
			return &R_default;
		else
			return NULL;
	}
	/* Mask off target according to width */
	target &= ~0L << (32-bits);

	for(rp = Routes[bits-1][hash_ip(target)];rp != NULL;rp = rp->next){
		if(rp->target == target){
			return rp;
		}
	}
	return NULL;
}
/* Scan the routing table. For each entry, see if there's a less-specific
 * one that points to the same interface and gateway. If so, delete
 * the more specific entry, since it is redundant.
 */
void
rt_merge(
int trace
){
	int bits,i,j;
	struct route *rp,*rpnext,*rp1;

	for(bits=32;bits>0;bits--){
		for(i = 0;i<HASHMOD;i++){
			for(rp = Routes[bits-1][i];rp != NULL;rp = rpnext){
				rpnext = rp->next;
				for(j=bits-1;j >= 0;j--){
					if((rp1 = rt_blookup(rp->target,j)) != NULL
					 && rp1->iface == rp->iface
					 && rp1->gateway == rp->gateway){
						if(trace > 1)
							printf("merge %s %d\n",
							 inet_ntoa(rp->target),
							 rp->bits);
						rt_drop(rp->target,rp->bits);
						break;
					}
				}
			}
		}
	}
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美优质美女网站| 国产一区二区三区综合| 欧日韩精品视频| 亚洲影视在线播放| 欧美巨大另类极品videosbest | 亚洲视频每日更新| 91麻豆免费视频| 亚洲香蕉伊在人在线观| 欧美一区二区三区公司| 国产一区二区三区四区五区入口| 中文文精品字幕一区二区| 91麻豆精品一区二区三区| 亚洲丰满少妇videoshd| 精品少妇一区二区三区日产乱码 | 成人国产精品免费| 亚洲综合男人的天堂| 欧美一级搡bbbb搡bbbb| 国产99久久久国产精品免费看| 国产精品久久久久影视| 欧美日韩亚洲高清一区二区| 国产一区二区三区在线看麻豆| 中文字幕制服丝袜成人av| 欧美色网站导航| 国产一区二区三区香蕉| 亚洲一区二区三区四区在线观看| 日韩一区二区三区四区| 不卡的av电影| 日韩高清在线一区| 国产精品护士白丝一区av| 欧美日韩aaaaa| 波多野结衣欧美| 免费在线看成人av| 亚洲欧洲日韩av| 精品理论电影在线观看| 色婷婷久久久综合中文字幕| 久久国产免费看| 亚洲一区中文在线| 国产欧美一区视频| 欧美日本不卡视频| 一本到一区二区三区| 国产传媒一区在线| 日韩精品国产欧美| 亚洲精品免费在线播放| 久久久久久久综合日本| 8v天堂国产在线一区二区| 99麻豆久久久国产精品免费| 国内外成人在线视频| 午夜电影网亚洲视频| 亚洲免费伊人电影| 国产精品全国免费观看高清| 精品少妇一区二区三区| 91精品在线麻豆| 欧美日韩在线直播| 在线亚洲欧美专区二区| 粉嫩绯色av一区二区在线观看| 久久国产尿小便嘘嘘| 日本怡春院一区二区| 亚洲一区二区黄色| 洋洋av久久久久久久一区| 日韩理论电影院| 国产精品国产精品国产专区不片| 欧美精品一区在线观看| 欧美一级久久久| 67194成人在线观看| 欧美色视频在线观看| 91国偷自产一区二区开放时间| 岛国精品在线播放| 成人一区在线观看| 丁香激情综合国产| 成人性生交大片免费看视频在线 | 国产精品18久久久久久久久久久久 | 三级在线观看一区二区| 亚洲国产精品久久久久婷婷884| 亚洲精品中文字幕在线观看| 国产精品久久三| 亚洲天堂福利av| 亚洲欧美偷拍另类a∨色屁股| 国产精品国产三级国产| 亚洲靠逼com| 亚洲国产精品精华液网站| 亚洲午夜久久久久久久久电影院| 亚洲一区二区三区自拍| 天堂影院一区二区| 久久国产成人午夜av影院| 久久爱www久久做| 国产成人免费视频精品含羞草妖精 | 精品视频在线免费看| 欧美一卡二卡在线| 精品国产露脸精彩对白| 中文字幕第一区二区| 亚洲色图欧美偷拍| 亚洲妇熟xx妇色黄| 免费观看久久久4p| 国产精品一线二线三线| av不卡在线观看| 欧美色视频一区| 精品久久久久久久人人人人传媒| 久久九九全国免费| 亚洲视频一二三| 舔着乳尖日韩一区| 国产精品91一区二区| 日本精品裸体写真集在线观看| 欧美日韩视频一区二区| 久久综合色鬼综合色| 国产精品福利影院| 五月综合激情婷婷六月色窝| 极品瑜伽女神91| 99久久精品免费观看| 欧美日韩电影在线| 国产视频911| 亚洲第一成年网| 国精产品一区一区三区mba视频| 成人动漫视频在线| 欧美卡1卡2卡| 日韩理论片在线| 免费看黄色91| 91麻豆6部合集magnet| 日韩一区二区免费在线观看| 亚洲欧洲在线观看av| 精品亚洲成a人| 在线中文字幕一区二区| 久久天天做天天爱综合色| 一区二区三区欧美日韩| 精品在线播放免费| 欧美系列日韩一区| 国产精品网站一区| 久久99久久久久| 欧美性感一类影片在线播放| 国产香蕉久久精品综合网| 日韩av在线免费观看不卡| 波多野结衣中文一区| 欧美成人a∨高清免费观看| 亚洲乱码日产精品bd | 色美美综合视频| 国产无人区一区二区三区| 肉色丝袜一区二区| 97精品久久久午夜一区二区三区| 精品欧美乱码久久久久久 | 亚洲成av人影院| 99久久久精品免费观看国产蜜| 精品国产一区久久| 婷婷综合另类小说色区| 91免费精品国自产拍在线不卡| 久久久不卡网国产精品一区| 免费精品视频在线| 欧美日韩亚洲高清一区二区| 玉足女爽爽91| 色天天综合色天天久久| 国产精品你懂的在线欣赏| 国内外成人在线视频| 欧美不卡激情三级在线观看| 天堂精品中文字幕在线| 欧美色偷偷大香| 亚洲成人免费影院| 欧美色网一区二区| 亚洲第一精品在线| 欧美日韩亚洲国产综合| 亚洲一区二区三区影院| 欧美体内she精高潮| 亚洲欧美日本韩国| 91美女片黄在线观看| 亚洲丝袜自拍清纯另类| 成人av在线一区二区| 日本一区二区三区久久久久久久久不| 国产尤物一区二区| 久久久影视传媒| 国产91丝袜在线观看| 欧美经典一区二区| 顶级嫩模精品视频在线看| 国产性色一区二区| av在线不卡电影| 亚洲精品菠萝久久久久久久| 91国产福利在线| 日韩和欧美的一区| 精品国精品国产| 国产91精品在线观看| 国产精品丝袜黑色高跟| 99精品国产91久久久久久| 亚洲精品成人天堂一二三| 欧美性感一类影片在线播放| 日韩av中文字幕一区二区| 久久综合色8888| 99久久精品情趣| 亚洲午夜av在线| 日韩一卡二卡三卡四卡| 国产成人精品www牛牛影视| 国产精品毛片高清在线完整版| 99re热这里只有精品免费视频| 一区二区三区国产精品| 3d动漫精品啪啪一区二区竹菊| 黄色成人免费在线| 亚洲日本一区二区| 欧美伦理电影网| 国产精品一线二线三线| 玉足女爽爽91| 久久人人爽爽爽人久久久| 99久久婷婷国产综合精品电影| 日韩国产欧美一区二区三区| 国产日韩欧美电影| 欧美精品一卡二卡|