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

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

?? route.generic

?? VRRP雙機熱備份協議源嗎
?? GENERIC
?? 第 1 頁 / 共 3 頁
字號:
 			fib_disable_ip(ifa->ifa_dev->dev, 1); 		} else {+			printk("fib_inetaddr_event: dev down, fib_del_ifaddr\n"); 			fib_del_ifaddr(ifa); 			rt_cache_flush(-1); 		}@@ -606,11 +665,10 @@ 	struct net_device *dev = ptr; 	struct in_device *in_dev = __in_dev_get(dev); -	if (!in_dev)-		return NOTIFY_DONE;- 	switch (event) { 	case NETDEV_UP:+		if (!in_dev)+			break; 		for_ifa(in_dev) { 			fib_add_ifaddr(ifa); 		} endfor_ifa(in_dev);@@ -620,9 +678,18 @@ 		rt_cache_flush(-1); 		break; 	case NETDEV_DOWN:+		printk("fib_netdev_event: dev down, fib_disable_ip(0)\n"); 		fib_disable_ip(dev, 0); 		break; 	case NETDEV_UNREGISTER:+		/* Routes pointing to dev may still exists even when IP has+		 * been shut down.  It may happen because routes of local type+		 * has special nexthop (see fib_create_info() and+		 * fib_sync_dev_down()).  I don't know if this state is valid.+		 * Now I call fib_disable_ip() independently from if the device+		 * has IP because otherwise stale device references are left.+		 * 1999/11/28  SAW */+		printk("fib_netdev_event: dev unregister, fib_disable_ip(1)\n"); 		fib_disable_ip(dev, 1); 		break; 	case NETDEV_CHANGEMTU:diff -ru -x*~ linux-lt-2.3.99-pre3.prev/net/ipv4/fib_semantics.c linux-lt-2.3.99-pre3/net/ipv4/fib_semantics.c--- linux-lt-2.3.99-pre3.prev/net/ipv4/fib_semantics.c	Tue Aug 24 01:01:02 1999+++ linux-lt-2.3.99-pre3/net/ipv4/fib_semantics.c	Tue Mar 28 19:39:50 2000@@ -345,14 +345,15 @@ { 	int err; +	if (nh->nh_flags&RTNH_F_PERVASIVE) {+		fi->fib_flags |= RTCF_PERVASIVE;+		return 0;+	}+ 	if (nh->nh_gw) { 		struct rt_key key; 		struct fib_result res; -#ifdef CONFIG_IP_ROUTE_PERVASIVE-		if (nh->nh_flags&RTNH_F_PERVASIVE)-			return 0;-#endif 		if (nh->nh_flags&RTNH_F_ONLINK) { 			struct net_device *dev; @@ -389,7 +390,7 @@ 	} else { 		struct in_device *in_dev; -		if (nh->nh_flags&(RTNH_F_PERVASIVE|RTNH_F_ONLINK))+		if (nh->nh_flags&RTNH_F_ONLINK) 			return -EINVAL;  		in_dev = inetdev_by_index(nh->nh_oif);@@ -528,7 +529,7 @@ 		} endfor_nexthops(fi) 	} -	if (fi->fib_prefsrc) {+	if (fi->fib_prefsrc && !(fi->fib_flags&RTCF_PERVASIVE)) { 		if (r->rtm_type != RTN_LOCAL || rta->rta_dst == NULL || 		    memcmp(&fi->fib_prefsrc, rta->rta_dst, 4)) 			if (inet_addr_type(fi->fib_prefsrc) != RTN_LOCAL)@@ -857,19 +858,34 @@    - device went down -> we must shutdown all nexthops going via it.  */ -int fib_sync_down(u32 local, struct net_device *dev, int force)+int fib_sync_addr_down(u32 local)+{+	int ret = 0;++	if (!local)+		goto out;++	for_fib_info() {+		if (fi->fib_prefsrc == local &&+				!(fi->fib_flags&RTCF_PERVASIVE)) {+			fi->fib_flags |= RTCF_DEAD;+			ret++;+		}+	} endfor_fib_info();+out:+	return ret;+}++int fib_sync_dev_down(struct net_device *dev, int force) { 	int ret = 0; 	int scope = RT_SCOPE_NOWHERE;-	+ 	if (force) 		scope = -1;  	for_fib_info() {-		if (local && fi->fib_prefsrc == local) {-			fi->fib_flags |= RTNH_F_DEAD;-			ret++;-		} else if (dev && fi->fib_nhs) {+		if (fi->fib_nhs) { 			int dead = 0;  			change_nexthops(fi) {@@ -886,7 +902,7 @@ 				} 			} endfor_nexthops(fi) 			if (dead == fi->fib_nhs) {-				fi->fib_flags |= RTNH_F_DEAD;+				fi->fib_flags |= RTCF_DEAD; 				ret++; 			} 		}@@ -947,6 +963,10 @@ 		int power = 0; 		change_nexthops(fi) { 			if (!(nh->nh_flags&RTNH_F_DEAD)) {+				if (nh->nh_flags&RTNH_F_USEFIRST) {+					res->nh_sel = nhsel;+					return;+				} 				power += nh->nh_weight; 				nh->nh_power = nh->nh_weight; 			}diff -ru -x*~ linux-lt-2.3.99-pre3.prev/net/ipv4/route.c linux-lt-2.3.99-pre3/net/ipv4/route.c--- linux-lt-2.3.99-pre3.prev/net/ipv4/route.c	Mon Mar 27 18:25:56 2000+++ linux-lt-2.3.99-pre3/net/ipv4/route.c	Tue Mar 28 19:57:19 2000@@ -711,22 +711,28 @@ 	struct rtable *rth, **rthp; 	u32  skeys[2] = { saddr, 0 }; 	int  ikeys[2] = { dev->ifindex, 0 };+	char *reason;  	tos &= IPTOS_TOS_MASK;  	if (!in_dev) 		return; +	reason = "bad gateway"; 	if (new_gw == old_gw || !IN_DEV_RX_REDIRECTS(in_dev) 	    || MULTICAST(new_gw) || BADCLASS(new_gw) || ZERONET(new_gw)) 		goto reject_redirect;  	if (!IN_DEV_SHARED_MEDIA(in_dev)) {-		if (!inet_addr_onlink(in_dev, new_gw, old_gw))+		reason = "gateway not onlink";+		if (!inet_addr_onlink(dev, new_gw, saddr, tos)) 			goto reject_redirect;-		if (IN_DEV_SEC_REDIRECTS(in_dev) && ip_fib_check_default(new_gw, dev))+		reason = "insecure gateway";+		if (IN_DEV_SEC_REDIRECTS(in_dev) &&+				ip_fib_check_default(new_gw, dev)) 			goto reject_redirect; 	} else {+		reason = "unacceptable gateway"; 		if (inet_addr_type(new_gw) != RTN_UNICAST) 			goto reject_redirect; 	}@@ -816,9 +822,9 @@ reject_redirect: #ifdef CONFIG_IP_ROUTE_VERBOSE 	if (IN_DEV_LOG_MARTIANS(in_dev) && net_ratelimit())-		printk(KERN_INFO "Redirect from %X/%s to %X ignored."+		printk(KERN_INFO "Redirect from %X/%s to %X ignored (%s). " 		       "Path = %X -> %X, tos %02x\n",-		       ntohl(old_gw), dev->name, ntohl(new_gw),+		       ntohl(old_gw), dev->name, ntohl(new_gw), reason, 		       ntohl(saddr), ntohl(daddr), tos); #endif 	in_dev_put(in_dev);@@ -836,7 +842,7 @@ 		if ((rt->rt_flags&RTCF_REDIRECTED) || rt->u.dst.expires) { 			unsigned hash = rt_hash_code(rt->key.dst, rt->key.src^(rt->key.oif<<5), rt->key.tos); #if RT_CACHE_DEBUG >= 1-			printk(KERN_DEBUG "ip_rt_advice: redirect to %d.%d.%d.%d/%02x dropped\n", NIPQUAD(rt->rt_dst), rt->key.tos);+			printk(KERN_DEBUG "ip_rt_advice: cache entry to %d.%d.%d.%d/%02x dropped\n", NIPQUAD(rt->rt_dst), rt->key.tos); #endif 			rt_del(hash, rt); 			return NULL;@@ -1106,6 +1112,10 @@ } #endif +/*********************************************************************+			 Input/output routing+ *********************************************************************/+ static void rt_set_nexthop(struct rtable *rt, struct fib_result *res, u32 itag) { 	struct fib_info *fi = res->fi;@@ -1145,6 +1155,10 @@         rt->rt_type = res->type; } +/*********************************************************************+				Input+ *********************************************************************/+ static int ip_route_input_mc(struct sk_buff *skb, u32 daddr, u32 saddr, 		  u8 tos, struct net_device *dev, int our)@@ -1362,9 +1376,7 @@ 	if (err) 		flags |= RTCF_DIRECTSRC; -	if (out_dev == in_dev && err && !(flags&(RTCF_NAT|RTCF_MASQ)) &&-	    (IN_DEV_SHARED_MEDIA(out_dev)-	     || inet_addr_onlink(out_dev, saddr, FIB_RES_GW(res))))+	if (out_dev == in_dev && err && !(flags&(RTCF_NAT|RTCF_MASQ))) 		flags |= RTCF_DOREDIRECT;  	if (skb->protocol != __constant_htons(ETH_P_IP)) {@@ -1592,22 +1604,183 @@ 	return ip_route_input_slow(skb, daddr, saddr, tos, dev); } +/*********************************************************************+				Output+ *********************************************************************/++/* TODO:+    - Check if CONFIG_IP_MROUTE ifdef makes any sense.+ */++/* User supplied source address verification for output packets.+   Such a verification can't be considered as a security measure.+   It's rather an additional Internet protection against bugs in applications+   (like using an uninitialized garbage as a source for UDP packets).+ */+static int outrt_check_src(u32 saddr, u32 daddr, u32 tos, struct net_device *dev_out)+{+	struct in_device	*in_dev;+	int			src_check;++	if (MULTICAST(saddr) || BADCLASS(saddr) || ZERONET(saddr))+		return -EINVAL;+	if (saddr == htonl(INADDR_BROADCAST))+		return -EINVAL;++	in_dev = in_dev_get(dev_out);+	src_check = IN_DEV_SRC_CHECK(in_dev);+	in_dev_put(in_dev);+	if (!src_check)+		return 0;++	if (LOOPBACK(saddr) && !(dev_out->flags&IFF_LOOPBACK))+		return -EINVAL;++	return fib_local_source(saddr, daddr, tos, dev_out);+}++static int outrt_make_route(struct rtable **rp,+	/* route lookup key */+	struct rt_key *key,+	/* path */+	u32 daddr, u32 saddr, struct net_device *dev_out,+	/* FIB lookup results (type, fi, nh.gw, nh.scope) */+	struct fib_result *res+	)+{+	struct rtable *rth;+	unsigned hash;+	unsigned flags;++	rth = dst_alloc(&ipv4_dst_ops);+	if (!rth)+		return -ENOBUFS;++	atomic_set(&rth->u.dst.__refcnt, 1);+	rth->u.dst.flags= DST_HOST;+	rth->key	= *key;+	rth->key.iif	= 0; /* output route */+	rth->rt_dst	= daddr;+	rth->rt_src	= saddr;+#ifdef CONFIG_IP_ROUTE_NAT+	rth->rt_dst_map	= daddr;+	rth->rt_src_map	= saddr;+#endif++	/* Set input, output ROUTINES and rt_spec_dst */+	switch (res->type) {+		case RTN_LOCAL:+			/* Use loopback interface for unicast local traffic */+			fib_res_put(res);+			res->fi = NULL;+#ifdef CONFIG_IP_MULTIPLE_TABLES+			res->r = NULL;+#endif+			dev_out = &loopback_dev;+			flags = RTCF_LOCAL;+			rth->u.dst.input  = ip_local_deliver;+			rth->u.dst.output = ip_output;+			rth->rt_spec_dst  = daddr; /* local side of the path */+			break;+		case RTN_UNICAST:+			flags = 0;+			rth->u.dst.output = ip_output;+			rth->rt_spec_dst  = saddr;+#ifdef CONFIG_IP_ROUTE_MULTIPATH+			if (res->fi->fib_nhs > 1 && key->oif == 0)+				/* Set the proper res->nh_sel. */+				fib_select_multipath(key, res);+			else+#endif+			if (res->prefixlen == 0 && res->type == RTN_UNICAST &&+					key->oif == 0)+				fib_select_default(key, res);+			break;+		case RTN_BROADCAST:+			flags = RTCF_BROADCAST|RTCF_LOCAL;+			rth->u.dst.input  = ip_local_deliver;+			if (!(dev_out->flags&IFF_LOOPBACK))+				rth->u.dst.output = ip_mc_output;+			else+				rth->u.dst.output = ip_output;+			rth->rt_spec_dst  = saddr;+			break;+		case RTN_MULTICAST:+			{+			/* Please note that all ancient band-aids were removed.+			   I don't try to catch route table deficient for+			   multicast or 255.255.255.255 routes and "smartly"+			   replace a gatewayed default by the corresponding+			   route.  1999/11/06  SAW+			 */+			struct in_device *in_dev = in_dev_get(dev_out);+			rth->u.dst.input  = ip_local_deliver;+			rth->u.dst.output = ip_output;+			flags = RTCF_MULTICAST;+			if (in_dev && ip_check_mc(in_dev, daddr)) {+				/* Note: I preserve the original behaviour+				   here.  It means that users after joining and+				   leaving a multicast group have to flush+				   the route cache.  I hope they know about it+				   :-)  1999/11/06  SAW+				 */+				flags = RTCF_MULTICAST|RTCF_LOCAL;+				if (!(dev_out->flags&IFF_LOOPBACK))+					rth->u.dst.output = ip_mc_output;+			}+#ifdef CONFIG_IP_MROUTE+			if (in_dev && !(dev_out->flags&IFF_LOOPBACK)) {+				if (IN_DEV_MFORWARD(in_dev) &&+						!LOCAL_MCAST(daddr))+				{+					rth->u.dst.input = ip_mr_input;+					rth->u.dst.output = ip_mc_output;+				}+			}+#endif+			if (in_dev)+				in_dev_put(in_dev);+			rth->rt_spec_dst  = saddr;+			}+			break;+		case RTN_NAT:+			dst_free(&rth->u.dst);+			return -EINVAL;+		default:+			printk(KERN_CRIT "bad lookup result type in route output\n");

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品久久久久三级| 成人一区在线观看| 欧美在线免费观看亚洲| 欧美在线小视频| 国产日韩欧美高清在线| 午夜私人影院久久久久| 岛国一区二区三区| 欧美大片在线观看| 亚洲成人激情社区| 91免费视频观看| 国产三级欧美三级| 久久国产精品72免费观看| 日本道色综合久久| 国产精品久线在线观看| 国产一区二区精品在线观看| 777色狠狠一区二区三区| 国产精品久久777777| 国产黄色91视频| 久久―日本道色综合久久| 免费看黄色91| 日韩色视频在线观看| 日日噜噜夜夜狠狠视频欧美人| 99久久婷婷国产综合精品电影| 久久久精品欧美丰满| 狠狠色狠狠色综合日日91app| 在线播放亚洲一区| 亚洲 欧美综合在线网络| 欧美在线免费播放| 亚洲一区二区中文在线| 91久久线看在观草草青青 | 最新日韩av在线| 国产激情视频一区二区三区欧美 | 日韩国产欧美三级| 欧美美女黄视频| 天天操天天色综合| 在线不卡免费av| 免费成人av资源网| 日韩视频在线一区二区| 日韩**一区毛片| 欧美成人一区二区三区在线观看| 麻豆精品一区二区综合av| 51精品秘密在线观看| 久久精品国产澳门| 久久久久久久久岛国免费| 国产精品主播直播| 中文字幕av一区二区三区免费看| 成人性生交大片免费| 综合久久国产九一剧情麻豆| 色综合一个色综合| 亚洲成av人片观看| 精品国产网站在线观看| 国产一区不卡视频| 亚洲色图色小说| 欧美老人xxxx18| 麻豆精品国产91久久久久久| 久久综合九色综合97_久久久 | 国产在线日韩欧美| 中文字幕一区av| 欧美日韩国产片| 寂寞少妇一区二区三区| 中文字幕的久久| 欧美日韩午夜在线| 国产在线视视频有精品| 亚洲三级免费观看| 日韩一区二区三区在线| 成人黄色a**站在线观看| 亚洲777理论| 欧美国产综合色视频| 91黄色免费观看| 国产精品一区二区在线观看网站| 亚洲六月丁香色婷婷综合久久| 日韩一区二区三区四区| 99re热这里只有精品免费视频| 日韩精品电影在线| 中文字幕一区二区三区不卡 | 色婷婷久久一区二区三区麻豆| 亚洲国产另类av| 国产日韩欧美制服另类| 欧美日韩激情在线| 国产福利精品一区| 日韩电影在线观看电影| 中文字幕制服丝袜成人av| 7777精品伊人久久久大香线蕉经典版下载 | 高清视频一区二区| 亚洲成av人在线观看| 国产精品丝袜在线| 欧美一区二区三区成人| 99vv1com这只有精品| 国产麻豆日韩欧美久久| 日本不卡在线视频| 一区二区三区四区亚洲| 国产日韩v精品一区二区| 欧美精品777| 色婷婷香蕉在线一区二区| 国产在线精品一区二区三区不卡 | 欧美三级日韩三级| 不卡在线视频中文字幕| 久久国产精品免费| 日日夜夜精品免费视频| 亚洲精选视频免费看| 中文字幕欧美激情| 国产午夜亚洲精品午夜鲁丝片| 91麻豆精品国产91| 欧美日韩在线精品一区二区三区激情 | 中文字幕一区免费在线观看| 久久青草欧美一区二区三区| 精品少妇一区二区三区| 欧美精品久久99久久在免费线| 色婷婷亚洲综合| 91.麻豆视频| 欧美日韩黄色影视| 欧美三级电影在线看| 欧美视频你懂的| 精品视频一区二区不卡| 色综合久久中文字幕| 99国产精品久| 在线免费亚洲电影| 在线日韩av片| 欧美精品乱人伦久久久久久| 欧美乱妇一区二区三区不卡视频| 欧美日本在线观看| 欧美一二三四区在线| 欧美mv日韩mv国产网站app| 日韩丝袜美女视频| 久久久欧美精品sm网站| 国产欧美一区视频| 亚洲欧美视频在线观看视频| 亚洲精品视频在线观看网站| 一个色综合av| 日韩高清中文字幕一区| 精品午夜一区二区三区在线观看 | 成人深夜在线观看| 一本一道久久a久久精品| 欧美在线free| 欧美成人综合网站| 国产精品久久久久毛片软件| 亚洲另类在线视频| 午夜欧美在线一二页| 麻豆精品视频在线观看视频| 国产一区二区三区免费| 99精品久久免费看蜜臀剧情介绍| 91成人国产精品| 欧美一区二区视频在线观看2022| 久久老女人爱爱| 一区二区在线观看免费视频播放| 亚洲成人777| 国产美女一区二区三区| 色婷婷国产精品久久包臀 | 美美哒免费高清在线观看视频一区二区 | 日韩视频永久免费| 国产精品久久久久影院老司 | 一区二区三区四区在线免费观看| 日本va欧美va精品发布| 国产寡妇亲子伦一区二区| 91国产精品成人| 久久久99精品免费观看不卡| 亚洲精品国产一区二区精华液| 蜜臀av一区二区在线免费观看| 成人免费看视频| 日韩小视频在线观看专区| 国产精品久久久久久亚洲伦| 日本sm残虐另类| 欧美怡红院视频| 国产精品网站一区| 麻豆极品一区二区三区| 91成人看片片| 国产精品美女久久福利网站| 日韩主播视频在线| 91国产成人在线| 国产精品毛片大码女人| 韩国女主播成人在线观看| 欧美日韩精品三区| 亚洲精品成人a在线观看| 国产高清成人在线| 精品久久国产字幕高潮| 丝袜美腿成人在线| 欧美在线短视频| 亚洲人成亚洲人成在线观看图片| 国产一区二区三区不卡在线观看 | 久久蜜桃av一区精品变态类天堂 | 日韩欧美一级二级三级久久久| 亚洲欧美一区二区三区国产精品| 国产成人丝袜美腿| 精品国产91乱码一区二区三区| 午夜成人免费电影| 欧美影院一区二区| 一区二区视频在线看| 成人性生交大片| 中文无字幕一区二区三区| 国内一区二区视频| 欧美tickling挠脚心丨vk| 日韩精品电影一区亚洲| 欧美电影一区二区三区| 亚洲国产日日夜夜| 91福利在线看| 一区二区三区四区不卡视频| 一本大道av一区二区在线播放| 亚洲日本va午夜在线电影| 91美女片黄在线观看| 亚洲黄色小视频|