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

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

?? simple-beet-and-interfamily-2.6.17.14.patch

?? HIP:Host Identity Protocol
?? PATCH
?? 第 1 頁 / 共 4 頁
字號:
--	if (!x->props.mode) {-		skb->h.raw += iph->ihl*4;-		memmove(top_iph, iph, iph->ihl*4);-		return;-	}--	top_iph->ihl = 5;-	top_iph->version = 4;--	/* DS disclosed */-	top_iph->tos = INET_ECN_encapsulate(iph->tos, iph->tos);--	flags = x->props.flags;-	if (flags & XFRM_STATE_NOECN)-		IP_ECN_clear(top_iph);--	top_iph->frag_off = (flags & XFRM_STATE_NOPMTUDISC) ?-		0 : (iph->frag_off & htons(IP_DF));-	if (!top_iph->frag_off)-		__ip_select_ident(top_iph, dst->child, 0);--	top_iph->ttl = dst_metric(dst->child, RTAX_HOPLIMIT);--	top_iph->saddr = x->props.saddr.a4;-	top_iph->daddr = x->id.daddr.a4;-	top_iph->protocol = IPPROTO_IPIP;--	memset(&(IPCB(skb)->opt), 0, sizeof(struct ip_options));+        struct dst_entry *dst = skb->dst;+        struct xfrm_state *x = dst->xfrm;+        struct iphdr *iph, *top_iph;+        int flags;+        int hdrlen, optlen;++        iph = skb->nh.iph;+        skb->h.ipiph = iph;++        hdrlen = x->props.header_len;+        optlen = iph->ihl * 4 - sizeof(*iph);+        if (x->props.mode == XFRM_MODE_BEET) {+                if (!optlen) {+                        hdrlen -= IPV4_BEET_PHMAXLEN;+                }+                else {+                        skb->h.raw -= (IPV4_BEET_PHMAXLEN - (optlen & 4));+                        hdrlen -= optlen & 4;+                }+        }++        skb->nh.raw = skb_push(skb, hdrlen);+        top_iph = skb->nh.iph;++        hdrlen = iph->ihl * 4 - optlen;+        switch (x->props.mode) {+        case XFRM_MODE_TRANSPORT:+                skb->h.raw += hdrlen;+                memmove(top_iph, iph, hdrlen);+                return;+        case XFRM_MODE_BEET:+                skb->h.raw += hdrlen;+                if (x->props.family == AF_INET) {+                        memmove(top_iph, iph, hdrlen);+                }++                if (unlikely(optlen)) {+                        struct ip_beet_phdr *ph;++                        BUG_ON(optlen < 0);++                        ph = (struct ip_beet_phdr *)skb->h.raw;+                        ph->padlen = 4 - (optlen & 4);+                        ph->hdrlen = (optlen + ph->padlen + sizeof(*ph)) / 8;+                        ph->nexthdr = iph->protocol;+                        top_iph->protocol = IPPROTO_BEETPH;+                        top_iph->ihl = sizeof(struct iphdr) / 4;+                }++                break;+        default:+        case XFRM_MODE_TUNNEL:+                if (x->props.family == AF_INET) {+                        top_iph->ihl = 5;+                        top_iph->version = 4;++                        /* DS disclosed */+                        top_iph->tos = INET_ECN_encapsulate(iph->tos, iph->tos);+                        flags = x->props.flags;+                        if (flags & XFRM_STATE_NOECN)+                                IP_ECN_clear(top_iph);++                        top_iph->frag_off = (flags & XFRM_STATE_NOPMTUDISC) ?+                                0 : (iph->frag_off & htons(IP_DF));+                        if (!top_iph->frag_off)+                                __ip_select_ident(top_iph, dst, 0);++                        top_iph->ttl = dst_metric(dst->child, RTAX_HOPLIMIT);++                        top_iph->protocol = IPPROTO_IPIP;+                        memset(&(IPCB(skb)->opt), 0, sizeof(struct ip_options)); }+                break;+        }++        if (x->props.family == AF_INET) {+                top_iph->saddr = x->props.saddr.a4;+                top_iph->daddr = x->id.daddr.a4;+        } else if (x->props.family == AF_INET6) {+                /* Inner = 4, Outer = 6*/+                struct ipv6hdr *top_iph6;+                int dsfield;+                u8 protocol = top_iph->protocol;++                if (unlikely(optlen))+                        protocol = top_iph->protocol;+                else+                        protocol = iph->protocol;+                if (x->props.mode == XFRM_MODE_BEET) {+                        int delta = sizeof(struct ipv6hdr) - sizeof(struct iphdr);++                        if (skb_headroom(skb) <=  2*delta){+                                if (pskb_expand_head(skb, delta,0, GFP_ATOMIC))+                                        return;+                        }++                        skb->nh.raw = skb_push(skb, delta);+                }++                top_iph6 = skb->nh.ipv6h;+                skb->h.ipv6h = top_iph6 + 1;+                /* DS disclosed */+                top_iph6->version = 6;+                top_iph6->priority = 0;+                top_iph6->flow_lbl[0] = 0;+                top_iph6->flow_lbl[1] = 0;+                top_iph6->flow_lbl[2] = 0;+                dsfield = ipv6_get_dsfield(top_iph6);+                dsfield = INET_ECN_encapsulate(dsfield, dsfield);+                flags = x->props.flags;+                if (flags & XFRM_STATE_NOECN)+                        dsfield &= ~INET_ECN_MASK;+                ipv6_change_dsfield(top_iph6, 0, dsfield);++                if (x->props.mode == XFRM_MODE_TUNNEL)+                        top_iph6->nexthdr = IPPROTO_IPIP;+                else+                        top_iph6->nexthdr = protocol;+                top_iph6->hop_limit = dst_metric(dst->child, RTAX_HOPLIMIT);+                top_iph6->payload_len = htons(skb->len - sizeof(struct ipv6hdr));+                ipv6_addr_copy(&top_iph6->saddr,(struct in6_addr *)&x->props.saddr);+                ipv6_addr_copy(&top_iph6->daddr, (struct in6_addr *)&x->id.daddr);+                skb->nh.raw = &top_iph6->nexthdr;+                //skb->nh.raw = &skb->nh.ipv6h->nexthdr;+        } else+                BUG_ON(1); }  static int xfrm4_tunnel_check_size(struct sk_buff *skb)@@ -109,7 +195,7 @@ 			goto error_nolock; 	} -	if (x->props.mode) {+	if (x->props.mode == XFRM_MODE_TUNNEL) { 		err = xfrm4_tunnel_check_size(skb); 		if (err) 			goto error_nolock;diff -urN linux-2.6.17.9/net/ipv4/xfrm4_policy.c linux-2.6.17.9.hipl/net/ipv4/xfrm4_policy.c--- linux-2.6.17.9/net/ipv4/xfrm4_policy.c	2006-08-18 19:26:24.000000000 +0300+++ linux-2.6.17.9.hipl/net/ipv4/xfrm4_policy.c	2006-12-18 15:01:04.000000000 +0200@@ -19,6 +19,8 @@  static struct xfrm_type_map xfrm4_type_map = { .lock = RW_LOCK_UNLOCKED }; +static void xfrm4_update_pmtu(struct dst_entry *dst, u32 mtu);+ static int xfrm4_dst_lookup(struct xfrm_dst **dst, struct flowi *fl) { 	return __ip_route_output_key((struct rtable**)dst, fl);@@ -56,17 +58,20 @@ 	struct dst_entry *dst, *dst_prev; 	struct rtable *rt0 = (struct rtable*)(*dst_p); 	struct rtable *rt = rt0;-	u32 remote = fl->fl4_dst;-	u32 local  = fl->fl4_src; 	struct flowi fl_tunnel = { 		.nl_u = { 			.ip4_u = {-				.saddr = local,-				.daddr = remote,+				.saddr = fl->fl4_dst,+				.daddr = fl->fl4_src, 				.tos = fl->fl4_tos 			} 		} 	};+	union {+		struct in6_addr *in6;+		struct in_addr *in;+	} remote, local;+	unsigned short outer_family = 0, beet = 0; 	int i; 	int err; 	int header_len = 0;@@ -78,7 +83,6 @@ 	for (i = 0; i < nx; i++) { 		struct dst_entry *dst1 = dst_alloc(&xfrm4_dst_ops); 		struct xfrm_dst *xdst;-		int tunnel = 0;  		if (unlikely(dst1 == NULL)) { 			err = -ENOBUFS;@@ -99,21 +103,45 @@  		dst1->next = dst_prev; 		dst_prev = dst1;-		if (xfrm[i]->props.mode) {-			remote = xfrm[i]->id.daddr.a4;-			local  = xfrm[i]->props.saddr.a4;-			tunnel = 1;++		if (xfrm[i]->props.mode == XFRM_MODE_TUNNEL || xfrm[i]->props.mode == XFRM_MODE_BEET) {+			outer_family = xfrm[i]->props.family;+			beet = (xfrm[i]->props.mode == XFRM_MODE_BEET);++			if(outer_family == AF_INET6){+				remote.in6 = (struct in6_addr*)&xfrm[i]->id.daddr;+				local.in6 = (struct in6_addr*)&xfrm[i]->props.saddr;+			} else if(outer_family == AF_INET){+				remote.in = (struct in_addr*)&xfrm[i]->id.daddr;+				local.in = (struct in_addr*)&xfrm[i]->props.saddr;+			} else+				BUG_ON(1); 		} 		header_len += xfrm[i]->props.header_len; 		trailer_len += xfrm[i]->props.trailer_len; -		if (tunnel) {-			fl_tunnel.fl4_src = local;-			fl_tunnel.fl4_dst = remote;+		if (outer_family) {+			switch(outer_family) {+			case AF_INET:+				fl_tunnel.fl4_dst = remote.in->s_addr;+				fl_tunnel.fl4_src = local.in->s_addr;+				break;+			case AF_INET6:+				ipv6_addr_copy(&fl_tunnel.fl6_dst, remote.in6);+				ipv6_addr_copy(&fl_tunnel.fl6_src, local.in6);+				break;+			default:+				BUG_ON(1);+			} 			err = xfrm_dst_lookup((struct xfrm_dst **)&rt,-					      &fl_tunnel, AF_INET);+					      &fl_tunnel, outer_family); 			if (err) 				goto error;+			/* Without this, the atomic inc below segfaults */+			if (outer_family == AF_INET6) {+				rt->peer = NULL;+				rt_bind_peer(rt,1);+			} 		} else 			dst_hold(&rt->u.dst); 	}@@ -163,6 +191,11 @@ 	}  	xfrm_init_pmtu(dst);+	if (beet && outer_family == AF_INET6) {+		int delta = sizeof(struct ipv6hdr) - sizeof(struct iphdr);+		u32 mtu = dst_mtu(dst);+		xfrm4_update_pmtu(dst, mtu - delta);+	} 	return 0;  error:diff -urN linux-2.6.17.9/net/ipv4/xfrm4_tunnel.c linux-2.6.17.9.hipl/net/ipv4/xfrm4_tunnel.c--- linux-2.6.17.9/net/ipv4/xfrm4_tunnel.c	2006-08-18 19:26:24.000000000 +0300+++ linux-2.6.17.9.hipl/net/ipv4/xfrm4_tunnel.c	2006-12-18 15:01:04.000000000 +0200@@ -28,13 +28,20 @@  static int ipip_init_state(struct xfrm_state *x) {-	if (!x->props.mode)-		return -EINVAL;- 	if (x->encap) 		return -EINVAL; -	x->props.header_len = sizeof(struct iphdr);+	switch (x->props.mode) {+	case XFRM_MODE_TRANSPORT:+		return -EINVAL;+	default:+	case XFRM_MODE_TUNNEL:+		x->props.header_len = sizeof(struct iphdr);+		break;+	case XFRM_MODE_BEET:+		x->props.header_len += IPV4_BEET_PHMAXLEN;+		break;+	}  	return 0; }diff -urN linux-2.6.17.9/net/ipv6/ah6.c linux-2.6.17.9.hipl/net/ipv6/ah6.c--- linux-2.6.17.9/net/ipv6/ah6.c	2006-08-18 19:26:24.000000000 +0300+++ linux-2.6.17.9.hipl/net/ipv6/ah6.c	2006-12-18 15:01:04.000000000 +0200@@ -392,8 +392,10 @@ 		goto error; 	 	x->props.header_len = XFRM_ALIGN8(sizeof(struct ipv6_auth_hdr) + ahp->icv_trunc_len);-	if (x->props.mode)+	if (x->props.mode == XFRM_MODE_TUNNEL) 		x->props.header_len += sizeof(struct ipv6hdr);+	else if (x->props.mode == XFRM_MODE_BEET)+		x->props.header_len += IPV4_BEET_PHMAXLEN; 	x->data = ahp;  	return 0;diff -urN linux-2.6.17.9/net/ipv6/esp6.c linux-2.6.17.9.hipl/net/ipv6/esp6.c--- linux-2.6.17.9/net/ipv6/esp6.c	2006-08-18 19:26:24.000000000 +0300+++ linux-2.6.17.9.hipl/net/ipv6/esp6.c	2006-12-18 15:01:04.000000000 +0200@@ -357,8 +357,10 @@ 	if (crypto_cipher_setkey(esp->conf.tfm, esp->conf.key, esp->conf.key_len)) 		goto error; 	x->props.header_len = sizeof(struct ipv6_esp_hdr) + esp->conf.ivlen;-	if (x->props.mode)+	if (x->props.mode == XFRM_MODE_TUNNEL) 		x->props.header_len += sizeof(struct ipv6hdr);+	else if (x->props.mode == XFRM_MODE_BEET)+		x->props.header_len += IPV4_BEET_PHMAXLEN; 	x->data = esp; 	return 0; diff -urN linux-2.6.17.9/net/ipv6/ipcomp6.c linux-2.6.17.9.hipl/net/ipv6/ipcomp6.c--- linux-2.6.17.9/net/ipv6/ipcomp6.c	2006-08-18 19:26:24.000000000 +0300+++ linux-2.6.17.9.hipl/net/ipv6/ipcomp6.c	2006-12-18 15:01:04.000000000 +0200@@ -438,8 +438,10 @@ 		goto out;  	x->props.header_len = 0;-	if (x->props.mode)+	if (x->props.mode == XFRM_MODE_TUNNEL) 		x->props.header_len += sizeof(struct ipv6hdr);+	else if (x->props.mode == XFRM_MODE_BEET)+		x->props.header_len += IPV4_BEET_PHMAXLEN; 	 	mutex_lock(&ipcomp6_resource_mutex); 	if (!ipcomp6_alloc_scratches())@@ -450,7 +452,7 @@ 		goto error; 	mutex_unlock(&ipcomp6_resource_mutex); -	if (x->props.mode) {+	if (x->props.mode == XFRM_MODE_TUNNEL) { 		err = ipcomp6_tunnel_attach(x); 		if (err) 			goto error_tunnel;diff -urN linux-2.6.17.9/net/ipv6/xfrm6_input.c linux-2.6.17.9.hipl/net/ipv6/xfrm6_input.c--- linux-2.6.17.9/net/ipv6/xfrm6_input.c	2006-08-18 19:26:24.000000000 +0300+++ linux-2.6.17.9.hipl/net/ipv6/xfrm6_input.c	2006-12-18 15:01:04.000000000 +0200@@ -81,16 +81,34 @@  		xfrm_vec[xfrm_nr++] = x; -		if (x->props.mode) { /* XXX */-			if (nexthdr != IPPROTO_IPV6)-				goto drop;-			if (!pskb_may_pull(skb, sizeof(struct ipv6hdr)))-				goto drop;-			if (skb_cloned(skb) &&-			    pskb_expand_head(skb, 0, 0, GFP_ATOMIC))-				goto drop;-			if (x->props.flags & XFRM_STATE_DECAP_DSCP)-				ipv6_copy_dscp(skb->nh.ipv6h, skb->h.ipv6h);+		if (x->props.mode == XFRM_MODE_TUNNEL) {+			if (x->sel.family == AF_INET6) {++				if (nexthdr != IPPROTO_IPV6)+					goto drop;+				if (!pskb_may_pull(skb, sizeof(struct ipv6hdr)))+					goto drop;+				if (skb_cloned(skb) &&+				    pskb_expand_head(skb, 0, 0, GFP_ATOMIC))+					goto drop;+				if (x->props.flags & XFRM_STATE_DECAP_DSCP)+					ipv6_copy_dscp(skb->nh.ipv6h, skb->h.ipv6h);+			} else if (x->sel.family == AF_INET) {++				if (nexthdr != IPPROTO_IPIP)+					goto drop;+				if (!pskb_may_pull(skb, sizeof(struct iphdr)))+					goto drop;+				if (skb_cloned(skb) &&+				    pskb_expand_head(skb, 0, 0, GFP_ATOMIC))

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
在线视频一区二区三区| 亚洲人午夜精品天堂一二香蕉| 国产高清视频一区| 一区二区三区久久| 97久久超碰国产精品电影| 久久综合视频网| 久久精品国产久精国产| 色94色欧美sute亚洲线路二| 最新热久久免费视频| 成人黄色免费短视频| 91精品国产麻豆国产自产在线| 夜夜爽夜夜爽精品视频| 99久久精品国产网站| 亚洲欧美另类小说视频| 欧美视频精品在线观看| 色综合久久天天| 91丨九色丨尤物| 久久这里都是精品| 欧美二区三区的天堂| 91免费视频观看| 成人性视频网站| 黄色日韩三级电影| 午夜精品aaa| 亚洲综合激情另类小说区| 国产精品入口麻豆原神| 久久香蕉国产线看观看99| 4438x亚洲最大成人网| 欧美日韩一区三区四区| 91高清视频免费看| 在线日韩av片| 在线观看不卡一区| 91福利视频久久久久| 91蜜桃免费观看视频| 国产 日韩 欧美大片| 国产精品性做久久久久久| 国产自产v一区二区三区c| 久久不见久久见中文字幕免费| 日韩二区在线观看| 美女一区二区视频| 免费欧美日韩国产三级电影| 美女在线观看视频一区二区| 免费成人你懂的| 韩国精品一区二区| 国产精品1区二区.| 粉嫩高潮美女一区二区三区| 高清在线不卡av| 91在线免费视频观看| 在线视频欧美精品| 欧美日韩久久一区| 欧美电视剧在线观看完整版| 久久久久久久久久久久电影 | 蜜臀av国产精品久久久久| 日韩激情av在线| 美美哒免费高清在线观看视频一区二区 | 亚洲成人7777| 免费人成精品欧美精品| 国产一区二区三区在线观看免费视频 | 亚洲少妇屁股交4| 亚洲午夜精品网| 麻豆91在线看| 国产精品一品二品| 色综合久久88色综合天天免费| 色婷婷综合久久久久中文| 欧美三电影在线| 欧美一级日韩一级| 中文字幕高清一区| 伊人性伊人情综合网| 日韩中文字幕一区二区三区| 久久不见久久见免费视频7| 懂色一区二区三区免费观看| 色www精品视频在线观看| 欧美二区三区的天堂| 国产片一区二区| 亚洲综合av网| 国产最新精品精品你懂的| 波多野结衣中文字幕一区| 欧美日韩一本到| 欧美精品一区二区在线播放| 亚洲人快播电影网| 久久成人久久鬼色| 91麻豆国产福利在线观看| 欧美一区二视频| 亚洲人成人一区二区在线观看| 日韩av电影一区| 白白色 亚洲乱淫| 欧美一区二区视频在线观看| 国产精品国产自产拍高清av| 五月婷婷久久丁香| 国产.精品.日韩.另类.中文.在线.播放| 在线免费精品视频| 久久精品男人的天堂| 午夜欧美视频在线观看| 成人午夜激情影院| 91精品免费观看| 亚洲图片另类小说| 国产美女娇喘av呻吟久久| 欧美性猛交xxxx黑人交| 久久人人爽爽爽人久久久| 亚洲成a人片在线观看中文| 国产福利一区二区三区视频| 欧美精品色综合| 日韩毛片视频在线看| 色综合久久综合| 精品少妇一区二区三区视频免付费| 亚洲精品一二三区| 国产精品一品视频| 欧美大肚乱孕交hd孕妇| 亚洲精品成人精品456| 懂色一区二区三区免费观看| 日韩区在线观看| 水野朝阳av一区二区三区| 91福利国产精品| 亚洲婷婷综合久久一本伊一区| 国产精品91一区二区| 欧美成人aa大片| 日韩成人免费电影| 欧美日韩在线一区二区| 一区二区成人在线视频 | 国产性色一区二区| 久草这里只有精品视频| 欧美巨大另类极品videosbest | 国产精品主播直播| 精品成人一区二区| 琪琪久久久久日韩精品| 欧美丰满一区二区免费视频| 亚洲午夜在线视频| 在线观看91视频| 亚洲私人黄色宅男| 97成人超碰视| 亚洲欧美日韩系列| 色婷婷综合久色| 亚洲精品视频观看| 99精品在线免费| 亚洲乱码一区二区三区在线观看| www.日韩av| 国产精品二三区| 91小视频免费看| 亚洲情趣在线观看| 在线看日本不卡| 亚洲影视资源网| 在线不卡免费av| 琪琪久久久久日韩精品| 精品欧美一区二区在线观看| 国产最新精品免费| 国产精品午夜电影| 91蜜桃网址入口| 午夜在线电影亚洲一区| 欧美一区二区美女| 国产专区欧美精品| 国产片一区二区| 91麻豆国产精品久久| 亚洲一区二区在线观看视频 | 精品国产一二三区| 国产精品88888| 最新热久久免费视频| 在线精品视频一区二区三四| 日韩精彩视频在线观看| 日韩欧美综合一区| 岛国精品在线播放| 尤物av一区二区| 欧美精品第1页| 狠狠色狠狠色综合系列| 国产精品久久久久久久岛一牛影视| 91在线视频免费观看| 日韩专区一卡二卡| 国产欧美一区二区精品性色| 99久久精品久久久久久清纯| 亚洲一区二区欧美| 精品国产乱码久久久久久1区2区| 丁香六月综合激情| 午夜国产精品一区| 久久久亚洲午夜电影| 99精品欧美一区二区蜜桃免费| 亚洲bt欧美bt精品777| 久久综合av免费| 色综合天天综合给合国产| 免费观看成人av| 国产精品久久久久久久久晋中| 精品视频在线免费看| 国产精品羞羞答答xxdd| 亚洲午夜激情网站| 国产色产综合色产在线视频| 日本精品一区二区三区四区的功能| 免费成人在线播放| 亚洲欧美视频在线观看| 精品少妇一区二区三区免费观看| 99热精品一区二区| 九九精品一区二区| 亚洲一二三级电影| 亚洲国产精品ⅴa在线观看| 欧美一区午夜视频在线观看| 99热在这里有精品免费| 狠狠狠色丁香婷婷综合久久五月| 亚洲视频1区2区| 久久精品免费在线观看| 日韩一二在线观看| 色素色在线综合| 成人免费看的视频| 久久国产精品色婷婷| 亚洲va中文字幕|