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

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

?? radix.c

?? vxworks下的實現網絡TCPIP協議的原代碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
			b++;		if (*cp != normal_chars[b] || cp != (cplim - 1))			isnormal = 0;	}	b += (cp - netmask) << 3;	x->rn_b = -1 - b;	if (isnormal)		x->rn_flags |= RNF_NORMAL;	return (x);}static int	/* XXX: arbitrary ordering for non-contiguous masks */rn_lexobetter(m_arg, n_arg)	void *m_arg, *n_arg;{	register u_char *mp = m_arg, *np = n_arg, *lim;	if (*mp > *np)		return 1;  /* not really, but need to check longer one first */	if (*mp == *np) 		for (lim = mp + *mp; mp < lim;)			if (*mp++ > *np++)				return 1;	return 0;}static struct radix_mask *rn_new_radix_mask(tt, next)	register struct radix_node *tt;	register struct radix_mask *next;{	register struct radix_mask *m;	MKGet(m);	if (m == 0) {		logMsg("Mask for route not entered\n",0,0,0,0,0,0);		return (0);	}	Bzero(m, sizeof *m);	m->rm_b = tt->rn_b;	m->rm_flags = tt->rn_flags;	if (tt->rn_flags & RNF_NORMAL)		m->rm_leaf = tt;	else		m->rm_mask = tt->rn_mask;	m->rm_mklist = next;	tt->rn_mklist = m;	return m;}struct radix_node *rn_addroute(v_arg, n_arg, head, treenodes)	void *v_arg, *n_arg;	struct radix_node_head *head;	struct radix_node treenodes[2];{	caddr_t v = (caddr_t)v_arg, netmask = (caddr_t)n_arg;	register struct radix_node *t, *x = 0, *tt;	struct radix_node *saved_tt, *top = head->rnh_treetop;	short b = 0, b_leaf = 0;	int keyduplicated;	caddr_t mmask;	struct radix_mask *m, **mp;	/*	 * In dealing with non-contiguous masks, there may be	 * many different routes which have the same mask.	 * We will find it useful to have a unique pointer to	 * the mask to speed avoiding duplicate references at	 * nodes and possibly save time in calculating indices.	 */	if (netmask)  {		if ((x = rn_addmask(netmask, 0, top->rn_off)) == 0)			return (0);		b_leaf = x->rn_b;		b = -1 - x->rn_b;		netmask = x->rn_key;	}	/*	 * Deal with duplicated keys: attach node to previous instance	 */	saved_tt = tt = rn_insert(v, head, &keyduplicated, treenodes);	if (keyduplicated) {		for (t = tt; tt; t = tt, tt = tt->rn_dupedkey) {			if (tt->rn_mask == netmask)				return (0);			if (netmask == 0 ||			    (tt->rn_mask &&			     ((b_leaf < tt->rn_b) || /* index(netmask) > node */			       rn_refines(netmask, tt->rn_mask) ||			       rn_lexobetter(netmask, tt->rn_mask))))				break;		}		/*		 * If the mask is not duplicated, we wouldn't		 * find it among possible duplicate key entries		 * anyway, so the above test doesn't hurt.		 *		 * We sort the masks for a duplicated key the same way as		 * in a masklist -- most specific to least specific.		 * This may require the unfortunate nuisance of relocating		 * the head of the list.		 *		 * We also reverse, or doubly link the list through the		 * parent pointer.		 */		if (tt == saved_tt) {			struct	radix_node *xx = x;			/* link in at head of list */			(tt = treenodes)->rn_dupedkey = t;			tt->rn_flags = t->rn_flags;			tt->rn_p = x = t->rn_p;			t->rn_p = tt;			if (x->rn_l == t) x->rn_l = tt; else x->rn_r = tt;			saved_tt = tt; x = xx;		} else {			(tt = treenodes)->rn_dupedkey = t->rn_dupedkey;			t->rn_dupedkey = tt;			tt->rn_p = t;			if (tt->rn_dupedkey)				tt->rn_dupedkey->rn_p = tt;		}#ifdef RN_DEBUG		t=tt+1; tt->rn_info = rn_nodenum++; t->rn_info = rn_nodenum++;		tt->rn_twin = t; tt->rn_ybro = rn_clist; rn_clist = tt;#endif		tt->rn_key = (caddr_t) v;		tt->rn_b = -1;		tt->rn_flags = RNF_ACTIVE;	}	/*	 * Put mask in tree.	 */	if (netmask) {		tt->rn_mask = netmask;		tt->rn_b = x->rn_b;		tt->rn_flags |= x->rn_flags & RNF_NORMAL;	}	t = saved_tt->rn_p;	if (keyduplicated)		goto on2;	b_leaf = -1 - t->rn_b;	if (t->rn_r == saved_tt) x = t->rn_l; else x = t->rn_r;	/* Promote general routes from below */	if (x->rn_b < 0) { 	    for (mp = &t->rn_mklist; x; x = x->rn_dupedkey)		if (x->rn_mask && (x->rn_b >= b_leaf) && x->rn_mklist == 0) {			*mp = m = rn_new_radix_mask(x, 0);			if (m)				mp = &m->rm_mklist;		}	} else if (x->rn_mklist) {		/*		 * Skip over masks whose index is > that of new node		 */		for (mp = &x->rn_mklist; (m = *mp); mp = &m->rm_mklist)			if (m->rm_b >= b_leaf)				break;		t->rn_mklist = m; *mp = 0;	}on2:	/* Add new route to highest possible ancestor's list */	if ((netmask == 0) || (b > t->rn_b ))		return tt; /* can't lift at all */	b_leaf = tt->rn_b;	do {		x = t;		t = t->rn_p;	} while (b <= t->rn_b && x != top);	/*	 * Search through routes associated with node to	 * insert new route according to index.	 * Need same criteria as when sorting dupedkeys to avoid	 * double loop on deletion.	 */	for (mp = &x->rn_mklist; (m = *mp); mp = &m->rm_mklist) {		if (m->rm_b < b_leaf)			continue;		if (m->rm_b > b_leaf)			break;		if (m->rm_flags & RNF_NORMAL) {			mmask = m->rm_leaf->rn_mask;			if (tt->rn_flags & RNF_NORMAL) {				logMsg (				"Non-unique normal route, mask not entered",				0,0,0,0,0,0);				return tt;			}		} else			mmask = m->rm_mask;		if (mmask == netmask) {			m->rm_refs++;			tt->rn_mklist = m;			return tt;		}		if (rn_refines(netmask, mmask) || rn_lexobetter(netmask, mmask))			break;	}	*mp = rn_new_radix_mask(tt, *mp);	return tt;}struct radix_node *rn_delete(v_arg, netmask_arg, head)	void *v_arg, *netmask_arg;	struct radix_node_head *head;{	register struct radix_node *t, *p, *x, *tt;	struct radix_mask *m, *saved_m, **mp;	struct radix_node *dupedkey, *saved_tt, *top;	caddr_t v, netmask;	int b, head_off, vlen;	v = v_arg;	netmask = netmask_arg;	x = head->rnh_treetop;	tt = rn_search(v, x);	head_off = x->rn_off;	vlen =  *(u_char *)v;	saved_tt = tt;	top = x;	if (tt == 0 ||	    Bcmp(v + head_off, tt->rn_key + head_off, vlen - head_off))		return (0);	/*	 * Delete our route from mask lists.	 */	if (netmask) {		if ((x = rn_addmask(netmask, 1, head_off)) == 0)			return (0);		netmask = x->rn_key;		while (tt->rn_mask != netmask)			if ((tt = tt->rn_dupedkey) == 0)				return (0);	}	if (tt->rn_mask == 0 || (saved_m = m = tt->rn_mklist) == 0)		goto on1;	if (tt->rn_flags & RNF_NORMAL) {		if (m->rm_leaf != tt || m->rm_refs > 0) {			logMsg("rn_delete: inconsistent annotation\n",			       0,0,0,0,0,0);			return 0;  /* dangling ref could cause disaster */		}	} else { 		if (m->rm_mask != tt->rn_mask) {			logMsg("rn_delete: inconsistent annotation\n",			       0,0,0,0,0,0);			goto on1;		}		if (--m->rm_refs >= 0)			goto on1;	}	b = -1 - tt->rn_b;	t = saved_tt->rn_p;	if (b > t->rn_b)		goto on1; /* Wasn't lifted at all */	do {		x = t;		t = t->rn_p;	} while (b <= t->rn_b && x != top);	for (mp = &x->rn_mklist; (m = *mp); mp = &m->rm_mklist)		if (m == saved_m) {			*mp = m->rm_mklist;			MKFree(m);			break;		}	if (m == 0) {		logMsg("rn_delete: couldn't find our annotation\n", 		       0,0,0,0,0,0);		if (tt->rn_flags & RNF_NORMAL)			return (0); /* Dangling ref to us */	}on1:	/*	 * Eliminate us from tree	 */	if (tt->rn_flags & RNF_ROOT)		return (0);#ifdef RN_DEBUG	/* Get us out of the creation list */	for (t = rn_clist; t && t->rn_ybro != tt; t = t->rn_ybro) {}	if (t) t->rn_ybro = tt->rn_ybro;#endif	t = tt->rn_p;	dupedkey = saved_tt->rn_dupedkey;	if (dupedkey) {		/*		 * Here, tt is the deletion target, and		 * saved_tt is the head of the dupedkey chain.		 */		if (tt == saved_tt) {			x = dupedkey; x->rn_p = t;			if (t->rn_l == tt) t->rn_l = x; else t->rn_r = x;		} else {			/* find node in front of tt on the chain */			for (x = p = saved_tt; p && p->rn_dupedkey != tt;)				p = p->rn_dupedkey;			if (p) {				p->rn_dupedkey = tt->rn_dupedkey;				if (tt->rn_dupedkey)					tt->rn_dupedkey->rn_p = p;			} else logMsg("rn_delete: couldn't find us\n",				      0,0,0,0,0,0);		}		t = tt + 1;		if  (t->rn_flags & RNF_ACTIVE) {#ifndef RN_DEBUG			*++x = *t; p = t->rn_p;#else			b = t->rn_info; *++x = *t; t->rn_info = b; p = t->rn_p;#endif			if (p->rn_l == t) p->rn_l = x; else p->rn_r = x;			x->rn_l->rn_p = x; x->rn_r->rn_p = x;		}		goto out;	}	if (t->rn_l == tt) x = t->rn_r; else x = t->rn_l;	p = t->rn_p;	if (p->rn_r == t) p->rn_r = x; else p->rn_l = x;	x->rn_p = p;	/*	 * Demote routes attached to us.	 */	if (t->rn_mklist) {		if (x->rn_b >= 0) {			for (mp = &x->rn_mklist; (m = *mp);)				mp = &m->rm_mklist;			*mp = t->rn_mklist;		} else {			/* If there are any key,mask pairs in a sibling			   duped-key chain, some subset will appear sorted			   in the same order attached to our mklist */			for (m = t->rn_mklist; m && x; x = x->rn_dupedkey)				if (m == x->rn_mklist) {					struct radix_mask *mm = m->rm_mklist;					x->rn_mklist = 0;					if (--(m->rm_refs) < 0)						MKFree(m);					m = mm;				}			if (m)				logMsg("%s %x at %x\n",				       (int)"rn_delete: Orphaned Mask", 				       (int)m, (int)x,0,0,0);		}	}	/*	 * We may be holding an active internal node in the tree.	 */	x = tt + 1;	if (t != x) {#ifndef RN_DEBUG		*t = *x;#else		b = t->rn_info; *t = *x; t->rn_info = b;#endif		t->rn_l->rn_p = t; t->rn_r->rn_p = t;		p = x->rn_p;		if (p->rn_l == x) p->rn_l = t; else p->rn_r = t;	}out:	tt->rn_flags &= ~RNF_ACTIVE;	tt[1].rn_flags &= ~RNF_ACTIVE;	return (tt);}intrn_walktree(h, f, w)	struct radix_node_head *h;	register int (*f)();	void *w;{	int error;	struct radix_node *base, *next;	register struct radix_node *rn = h->rnh_treetop;	/*	 * This gets complicated because we may delete the node	 * while applying the function f to it, so we need to calculate	 * the successor node in advance.	 */	/* First time through node, go left */	while (rn->rn_b >= 0)		rn = rn->rn_l;	for (;;) {		base = rn;		/* If at right child go back up, otherwise, go right */		while (rn->rn_p->rn_r == rn && (rn->rn_flags & RNF_ROOT) == 0)			rn = rn->rn_p;		/* Find the next *leaf* since next node might vanish, too */		for (rn = rn->rn_p->rn_r; rn->rn_b >= 0;)			rn = rn->rn_l;		next = rn;		/* Process leaves */		while ((rn = base)) {			base = rn->rn_dupedkey;			if (!(rn->rn_flags & RNF_ROOT) && (error = (*f)(rn, w)))				return (error);		}		rn = next;		if (rn->rn_flags & RNF_ROOT)			return (0);	}	/* NOTREACHED */}intrn_inithead(head, off)	void **head;	int off;{	register struct radix_node_head *rnh;	register struct radix_node *t, *tt, *ttt;	if (*head)		return (1);	R_Malloc(rnh, struct radix_node_head *, sizeof (*rnh));	if (rnh == 0)		return (0);	Bzero(rnh, sizeof (*rnh));	*head = rnh;	t = rn_newpair(rn_zeros, off, rnh->rnh_nodes);	ttt = rnh->rnh_nodes + 2;	t->rn_r = ttt;	t->rn_p = t;	tt = t->rn_l;	tt->rn_flags = t->rn_flags = RNF_ROOT | RNF_ACTIVE;	tt->rn_b = -1 - off;	*ttt = *tt;	ttt->rn_key = rn_ones;	rnh->rnh_addaddr = rn_addroute;	rnh->rnh_deladdr = rn_delete;	rnh->rnh_matchaddr = rn_match;	rnh->rnh_lookup = rn_lookup;	rnh->rnh_walktree = rn_walktree;	rnh->rnh_treetop = t;	return (1);}voidrn_init(){	char *cp, *cplim;	struct domain *dom;	for (dom = domains; dom; dom = dom->dom_next)		if (dom->dom_maxrtkey > max_keylen)			max_keylen = dom->dom_maxrtkey;	if (max_keylen == 0) {		logMsg(		"rn_init: radix functions require max_keylen be set\n",		0,0,0,0,0,0);		return;	}	R_Malloc(rn_zeros, char *, 3 * max_keylen);	if (rn_zeros == NULL)		panic("rn_init");	Bzero(rn_zeros, 3 * max_keylen);	rn_ones = cp = rn_zeros + max_keylen;	addmask_key = cplim = rn_ones + max_keylen;	while (cp < cplim)		*cp++ = -1;	if (rn_inithead((void **)&mask_rnhead, 0) == 0)		panic("rn_init 2"); }

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品久久久久久户外露出| 欧美亚洲综合一区| 久久久青草青青国产亚洲免观| 日韩二区三区四区| 日韩一区二区在线观看视频 | 成人av在线观| 136国产福利精品导航| 日韩精品中文字幕一区| 免费成人在线网站| 精品国一区二区三区| 国产精品一区二区黑丝| 国产精品久久久久永久免费观看| 成人av在线资源网| 亚洲一区二区精品久久av| 精品视频1区2区3区| 亚洲成在人线在线播放| 日韩精品一区二区三区视频播放| 国产精品资源网站| 亚洲精品美国一| 日韩一级高清毛片| 国产精品亚洲人在线观看| 国产精品国产三级国产a| 欧美视频中文字幕| 国产精品99久久久久久有的能看 | 亚洲人成伊人成综合网小说| 欧美性极品少妇| 国内精品伊人久久久久av一坑 | 国产精品天天看| 欧美自拍偷拍一区| 久久精品国产亚洲aⅴ| 欧美国产日韩a欧美在线观看 | 国产三级欧美三级| 91免费版在线看| 免费成人在线播放| 综合久久国产九一剧情麻豆| 欧美卡1卡2卡| 波多野结衣精品在线| 午夜电影一区二区| 国产精品久久久久久亚洲伦| 欧美午夜一区二区三区免费大片| 裸体健美xxxx欧美裸体表演| 亚洲欧洲日产国码二区| 日韩欧美黄色影院| 在线亚洲精品福利网址导航| 国产一区二区毛片| 青娱乐精品视频在线| 亚洲欧美电影院| 国产午夜精品一区二区| 欧美高清视频不卡网| 成人app在线| 国产伦精品一区二区三区免费迷| 依依成人精品视频| 中文字幕欧美国产| 26uuu国产一区二区三区| 欧美日高清视频| 欧洲亚洲精品在线| 色婷婷av久久久久久久| 国产91富婆露脸刺激对白| 免费在线观看日韩欧美| 亚洲成在线观看| 亚洲一区二区三区美女| 亚洲免费av在线| 国产精品久久久久aaaa樱花| 国产亚洲精品久| 久久综合九色综合欧美就去吻| 欧美情侣在线播放| 欧美系列在线观看| 在线亚洲人成电影网站色www| 丰满岳乱妇一区二区三区| 国产在线播精品第三| 九一九一国产精品| 美女视频黄频大全不卡视频在线播放| 亚洲午夜一区二区三区| 亚洲美女免费在线| 亚洲激情中文1区| 亚洲人123区| 亚洲免费成人av| 亚洲国产日韩精品| 偷拍日韩校园综合在线| 日韩在线观看一区二区| 男女男精品视频| 精品一区二区三区免费观看| 九色|91porny| 大白屁股一区二区视频| 成人激情免费视频| 在线视频观看一区| 欧美日韩国产片| 欧美一区二区视频免费观看| 欧美一区二区在线视频| 日韩欧美一区二区视频| 26uuu久久天堂性欧美| 久久久www成人免费无遮挡大片 | 国产精品视频第一区| 亚洲欧美在线视频观看| 亚洲卡通欧美制服中文| 亚洲一区二区三区四区在线免费观看 | 精品日韩一区二区| 国产欧美一区二区精品婷婷| 亚洲色欲色欲www| 亚洲午夜羞羞片| 国产综合色产在线精品| 成人的网站免费观看| 欧美色网站导航| 精品国产凹凸成av人导航| 中文字幕av一区二区三区| 亚洲精品大片www| 久久国产尿小便嘘嘘| 成人午夜av电影| 欧美三级乱人伦电影| 精品国产在天天线2019| 一区在线观看免费| 午夜影院在线观看欧美| 国产综合色在线视频区| 色美美综合视频| 欧美不卡一区二区三区四区| 中文字幕在线一区| 日产欧产美韩系列久久99| 国产精品自在欧美一区| 欧美中文字幕一二三区视频| 欧美不卡123| 悠悠色在线精品| 国产在线麻豆精品观看| 欧美综合久久久| 国产日韩欧美制服另类| 日韩在线a电影| 91浏览器在线视频| 久久久精品国产免费观看同学| 一区二区三区成人| 国产精品自拍网站| 欧美一级专区免费大片| 中文字幕一区二区三区精华液 | 国产精品久久久久影院色老大 | 国产成人精品免费看| 欧美精品粉嫩高潮一区二区| 国产性色一区二区| 七七婷婷婷婷精品国产| 日本道精品一区二区三区| 久久久久久久久久久99999| 午夜视频在线观看一区| 97se狠狠狠综合亚洲狠狠| 精品美女一区二区| 丝袜美腿高跟呻吟高潮一区| 99精品国产热久久91蜜凸| 久久久国产一区二区三区四区小说| 亚洲 欧美综合在线网络| 一本色道久久加勒比精品| 久久久久久久精| 免费人成在线不卡| 欧美日韩久久不卡| 亚洲国产aⅴ天堂久久| 91麻豆视频网站| 最新日韩av在线| fc2成人免费人成在线观看播放| 精品福利一区二区三区 | 亚洲欧美日韩一区| 91片黄在线观看| 国产精品灌醉下药二区| 国产69精品久久久久毛片| 久久久久久久久久久久久久久99 | 成人黄色小视频在线观看| 久久精品亚洲乱码伦伦中文| 国产在线精品免费| 久久久久9999亚洲精品| 韩国毛片一区二区三区| 精品对白一区国产伦| 开心九九激情九九欧美日韩精美视频电影| 欧美色视频在线| 五月天久久比比资源色| 欧美精品vⅰdeose4hd| 日韩精品福利网| 日韩你懂的在线观看| 激情偷乱视频一区二区三区| 久久久高清一区二区三区| 国产成人在线看| 国产精品久久久久影院老司| 99久久久久免费精品国产| 亚洲精品菠萝久久久久久久| 在线视频你懂得一区| 天堂蜜桃一区二区三区| 日韩三级.com| 国产成人精品免费在线| 中文字幕av一区 二区| 色国产综合视频| 日韩精品免费专区| 欧美成人女星排行榜| 国产成人亚洲综合a∨婷婷图片| 国产精品狼人久久影院观看方式| 成人av免费在线观看| 亚洲综合在线观看视频| 欧美精三区欧美精三区| 精品一区二区三区视频| 国产精品美女久久久久久2018 | 成人久久视频在线观看| 亚洲丝袜自拍清纯另类| 欧美精选在线播放| 国产成人鲁色资源国产91色综| 1024精品合集| 日韩精品影音先锋| 91在线高清观看| 日本大胆欧美人术艺术动态|