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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? iproute.c

?? 這是新華龍(www.xhl.xom.xn)開發(fā)的
?? 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;
					}
				}
			}
		}
	}
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99久久综合狠狠综合久久| 老司机精品视频线观看86| www.av精品| 亚洲欧洲成人精品av97| 91视频精品在这里| 一级女性全黄久久生活片免费| 欧美性猛片aaaaaaa做受| 石原莉奈在线亚洲三区| 欧美videofree性高清杂交| 国内精品伊人久久久久av一坑 | 欧美久久久久久久久| 日本女优在线视频一区二区| 欧美xxxx在线观看| 国产aⅴ综合色| 亚洲永久免费av| 欧美一区二区三区影视| 国产一二三精品| 亚洲精品久久嫩草网站秘色| 日韩欧美国产麻豆| 本田岬高潮一区二区三区| 亚洲一区在线免费观看| 精品动漫一区二区三区在线观看| 成人综合婷婷国产精品久久免费| 亚洲午夜激情av| 精品国产乱码久久久久久夜甘婷婷| 懂色av一区二区三区免费看| 一区二区三区.www| 337p日本欧洲亚洲大胆色噜噜| 91在线免费看| 久久激情五月激情| 亚洲欧美日韩一区| 精品久久久久久久一区二区蜜臀| 91欧美一区二区| 国产一区二区三区国产| 亚洲一区免费观看| 国产亚洲成aⅴ人片在线观看| 欧美在线观看视频在线| 国产一区二区三区最好精华液| 亚洲最新在线观看| 国产女主播一区| 日韩一级完整毛片| 色香蕉成人二区免费| 韩国精品主播一区二区在线观看| 亚洲精品国产成人久久av盗摄| 久久久久97国产精华液好用吗 | 欧美一级欧美三级在线观看| 国产不卡视频在线播放| 日日夜夜免费精品| 一区二区三区在线观看国产| www成人在线观看| 欧美喷水一区二区| 99视频超级精品| 韩国一区二区视频| 日韩成人精品在线观看| 亚洲一区二区免费视频| 国产精品污网站| 精品欧美一区二区三区精品久久 | av中文字幕一区| 韩国女主播一区| 免费视频一区二区| 亚洲成人精品在线观看| 日韩毛片一二三区| 欧美激情在线免费观看| 亚洲精品在线免费观看视频| 日韩午夜在线观看| 9191精品国产综合久久久久久| 在线一区二区三区| 91麻豆精东视频| www.欧美亚洲| 成人av资源下载| 成人aaaa免费全部观看| 国产成人av电影| 国产成人在线电影| 国产精品1024久久| 国产91露脸合集magnet| 国产成人高清在线| 成人一级片网址| 国产91在线|亚洲| 成人性生交大片免费看在线播放| 国产乱子伦视频一区二区三区| 紧缚捆绑精品一区二区| 久久精品国产精品青草| 久久精品二区亚洲w码| 美女视频一区二区| 久久99久久99精品免视看婷婷| 日本美女一区二区三区| 男男视频亚洲欧美| 久久国产精品露脸对白| 国产一区二区三区免费看| 国产精品自在欧美一区| 国产高清精品网站| av电影天堂一区二区在线| 91蜜桃婷婷狠狠久久综合9色| 99r国产精品| 欧美日韩不卡视频| 555www色欧美视频| 精品国产人成亚洲区| 久久久精品免费网站| 中日韩免费视频中文字幕| 中文字幕欧美一区| 亚洲欧美视频在线观看| 午夜精品久久久久久久99水蜜桃| 偷拍自拍另类欧美| 国产精品一区二区在线看| 91在线观看高清| 欧美日韩免费一区二区三区| 欧美一区日本一区韩国一区| 久久久综合激的五月天| 亚洲手机成人高清视频| 亚洲成年人影院| 国产精品88av| 欧美日韩在线精品一区二区三区激情 | 亚洲另类在线视频| 亚洲va欧美va人人爽| 国产精品一区二区在线观看网站| 91色视频在线| 日韩视频中午一区| 中文字幕欧美日本乱码一线二线| 亚洲乱码国产乱码精品精可以看| 欧美日韩国产在线观看| 在线国产亚洲欧美| 日韩一区二区精品葵司在线| 久久国产精品露脸对白| 国产女同互慰高潮91漫画| 7777女厕盗摄久久久| 久久久国产一区二区三区四区小说| 国产精品欧美久久久久无广告 | 国产99久久久精品| 欧美亚洲日本一区| 久久人人爽人人爽| 亚洲成av人片在www色猫咪| 国产美女娇喘av呻吟久久| 欧美日韩专区在线| 久久精品亚洲乱码伦伦中文| 亚洲狠狠爱一区二区三区| 国产激情一区二区三区四区| 欧美日韩精品福利| 亚洲欧洲国产日本综合| 国内精品久久久久影院色 | 日韩高清欧美激情| 91在线一区二区三区| www国产亚洲精品久久麻豆| 亚洲国产精品影院| 不卡的电影网站| 精品国产伦一区二区三区观看体验 | 精品一区二区免费视频| 欧美亚洲免费在线一区| 亚洲色图在线看| 高清在线观看日韩| 精品国产伦一区二区三区观看体验| 午夜精品在线视频一区| 一本一道综合狠狠老| 国产精品嫩草影院av蜜臀| 国产乱子伦视频一区二区三区| 91精品欧美久久久久久动漫| 亚洲一区二区三区中文字幕 | 精品国产成人系列| 日韩av电影天堂| 欧美日韩国产片| 亚洲成a人v欧美综合天堂下载| 91香蕉视频mp4| 中文字幕一区二区在线观看| 成人国产精品免费观看视频| 国产午夜精品一区二区| 国产一区二区精品久久91| 久久这里只精品最新地址| 精品一区二区三区久久久| 日韩色视频在线观看| 免费成人av在线播放| 日韩午夜激情av| 国内精品写真在线观看| 久久尤物电影视频在线观看| 激情文学综合网| 久久精品欧美一区二区三区麻豆| 国产一区二区视频在线| 国产女主播一区| 99久久er热在这里只有精品15 | 国产精品国产精品国产专区不蜜| 成人久久久精品乱码一区二区三区| 国产精品蜜臀在线观看| 9久草视频在线视频精品| 亚洲久草在线视频| 欧美视频中文一区二区三区在线观看| 亚洲夂夂婷婷色拍ww47| 欧美人妖巨大在线| 精品一区二区久久久| 国产女同互慰高潮91漫画| 91在线你懂得| 亚洲图片欧美综合| 日韩写真欧美这视频| 国产成人午夜精品5599| 亚洲男同性恋视频| 91精选在线观看| 国产一区二区h| 亚洲色图在线视频| 欧美人与性动xxxx| 国产一区二区免费看| 亚洲日韩欧美一区二区在线| 欧美写真视频网站| 精品在线视频一区|