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

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

?? interfamily-beet-ph-patch-v1.0-2.6.15.6

?? HIP:Host Identity Protocol
?? 6
?? 第 1 頁 / 共 2 頁
字號:
- - 	return 0;++	return 0; }  static void ipip_destroy(struct xfrm_state *x)diff -urN linux-2.6.15.6/net/ipv6/ah6.c linux-2.6.15.6-full/net/ipv6/ah6.c--- linux-2.6.15.6/net/ipv6/ah6.c	2006-04-13 23:46:09.000000000 +0300+++ linux-2.6.15.6-full/net/ipv6/ah6.c	2006-04-13 23:35:55.000000000 +0300@@ -395,6 +395,8 @@ 	x->props.header_len = XFRM_ALIGN8(sizeof(struct ipv6_auth_hdr) + ahp->icv_trunc_len); 	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.15.6/net/ipv6/esp6.c linux-2.6.15.6-full/net/ipv6/esp6.c--- linux-2.6.15.6/net/ipv6/esp6.c	2006-04-13 23:46:09.000000000 +0300+++ linux-2.6.15.6-full/net/ipv6/esp6.c	2006-04-13 23:35:55.000000000 +0300@@ -360,6 +360,8 @@ 	x->props.header_len = sizeof(struct ipv6_esp_hdr) + esp->conf.ivlen; 	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.15.6/net/ipv6/ipcomp6.c linux-2.6.15.6-full/net/ipv6/ipcomp6.c--- linux-2.6.15.6/net/ipv6/ipcomp6.c	2006-04-13 23:46:09.000000000 +0300+++ linux-2.6.15.6-full/net/ipv6/ipcomp6.c	2006-04-13 23:35:55.000000000 +0300@@ -435,6 +435,8 @@ 	x->props.header_len = 0; 	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; 	 	down(&ipcomp6_resource_sem); 	if (!ipcomp6_alloc_scratches())diff -urN linux-2.6.15.6/net/ipv6/xfrm6_input.c linux-2.6.15.6-full/net/ipv6/xfrm6_input.c--- linux-2.6.15.6/net/ipv6/xfrm6_input.c	2006-04-13 23:46:09.000000000 +0300+++ linux-2.6.15.6-full/net/ipv6/xfrm6_input.c	2006-04-13 23:35:55.000000000 +0300@@ -81,15 +81,33 @@ 		xfrm_vec[xfrm_nr++].xvec = x;  		if (x->props.mode == XFRM_MODE_TUNNEL) {-			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->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))+					goto drop;+				if (x->props.flags & XFRM_STATE_DECAP_DSCP)+					ipv4_copy_dscp(skb->nh.iph, skb->h.ipiph);++				memset(&(IPCB(skb)->opt), 0, sizeof(struct ip_options));+				skb->protocol = htons(ETH_P_IP);+			}+ 			if (!(x->props.flags & XFRM_STATE_NOECN)) 				ipip6_ecn_decapsulate(skb); 			skb->mac.raw = memmove(skb->data - skb->mac_len,@@ -98,7 +116,33 @@ 			decaps = 1; 			break; 		} else if (x->props.mode == XFRM_MODE_BEET) {-			int size = sizeof(struct ipv6hdr);+			struct ip_beet_phdr *ph = (struct ip_beet_phdr*)(skb->h.raw);+			int size = (x->sel.family == AF_INET) ? sizeof(struct iphdr) : sizeof(struct ipv6hdr);+			int delta = sizeof(struct ipv6hdr) - sizeof(struct iphdr);+			__u8 proto = skb->nh.ipv6h->nexthdr, hops = skb->nh.ipv6h->hop_limit;+			__u8 ph_nexthdr = 0;+			int phlen = 0;+			int optlen = 0;++			if (x->sel.family == AF_INET) {+				/* Inner = IPv4, therefore the IPhdr must be shrunk */+				/* Inner = 4, Outer = 6 */+				if (unlikely(proto == IPPROTO_BEETPH)) {+					if (!pskb_may_pull(skb, sizeof(*ph)))+						goto drop;+					phlen = ph->hdrlen * 8;+					optlen = phlen - ph->padlen - sizeof(*ph);++					if (optlen < 0 || optlen & 3 || optlen > 250)+						goto drop;+					if (!pskb_may_pull(skb, phlen))+						goto drop;++					proto = ph_nexthdr = ph->nexthdr;+				}+				skb->nh.raw += delta;+			}+ 			if (skb_cloned(skb) && 			    pskb_expand_head(skb, 0, 0, GFP_ATOMIC)) 				goto drop;@@ -109,18 +153,41 @@  			skb->mac.raw = memmove(skb->data - skb->mac_len, 					       skb->mac.raw, skb->mac_len);+			if (unlikely(phlen)) {+				skb_pull(skb, phlen - optlen);+				skb->nh.raw = skb->data;+			}  			if (x->sel.family == AF_INET6) { 				struct ipv6hdr *ip6h = skb->nh.ipv6h;-				ip6h = skb->nh.ipv6h; 				ip6h->payload_len = htons(skb->len - size); 				ipv6_addr_copy(&ip6h->daddr, (struct in6_addr *) &x->sel.daddr.a6); 				ipv6_addr_copy(&ip6h->saddr, (struct in6_addr *) &x->sel.saddr.a6);+			} else if (x->sel.family == AF_INET) {+				struct iphdr *iph = skb->nh.iph;+				iph->ihl = (sizeof(*iph) + optlen) / 4;+				iph->version = 4;+				iph->tos = 0;+				iph->id = 0;+				iph->frag_off = 0;+				iph->ttl = hops;+				iph->protocol = proto;+				iph->daddr = x->sel.daddr.a4;+				iph->saddr = x->sel.saddr.a4;+				iph->tot_len = htons(skb->len);+				ip_send_check(iph);+				skb->protocol = htons(ETH_P_IP);+				if (unlikely(!optlen)) {+					skb->h.raw = skb->nh.raw;+				}+				dst_release(skb->dst);+				skb->dst = NULL; 			} else 				BUG_ON(1);  			decaps = 1; 			break;+ 		}  		if ((err = xfrm_parse_spi(skb, nexthdr, &spi, &seq)) < 0)diff -urN linux-2.6.15.6/net/ipv6/xfrm6_output.c linux-2.6.15.6-full/net/ipv6/xfrm6_output.c--- linux-2.6.15.6/net/ipv6/xfrm6_output.c	2006-04-13 23:46:09.000000000 +0300+++ linux-2.6.15.6-full/net/ipv6/xfrm6_output.c	2006-04-13 23:35:55.000000000 +0300@@ -16,6 +16,7 @@ #include <net/inet_ecn.h> #include <net/ipv6.h> #include <net/xfrm.h>+#include <net/ip.h>  /* Add encapsulation header.  *@@ -38,17 +39,19 @@ 	struct xfrm_state *x = dst->xfrm; 	struct ipv6hdr *iph, *top_iph; 	int dsfield;+	int hdrlen; -	skb_push(skb, x->props.header_len);+	hdrlen = x->props.header_len - IPV4_BEET_PHMAXLEN;+	skb_push(skb, hdrlen); 	iph = skb->nh.ipv6h;  	if (x->props.mode == XFRM_MODE_TRANSPORT ||-	    x->props.mode == XFRM_MODE_BEET) {+	    (x->props.mode == XFRM_MODE_BEET && x->props.family == AF_INET6)) { 		u8 *prevhdr; 		int hdr_len;  		hdr_len = ip6_find_1stfragopt(skb, &prevhdr);-		skb->nh.raw = prevhdr - x->props.header_len;+		skb->nh.raw = prevhdr - hdrlen; 		skb->h.raw = skb->data + hdr_len; 		memmove(skb->data, iph, hdr_len); 		if (x->props.mode == XFRM_MODE_TRANSPORT)@@ -57,24 +60,52 @@  	skb->nh.raw = skb->data; 	top_iph = skb->nh.ipv6h;-	skb->nh.raw = &top_iph->nexthdr;-	skb->h.ipv6h = top_iph + 1;-	if(x->props.mode == XFRM_MODE_TUNNEL) {-		top_iph->version = 6;-		top_iph->priority = iph->priority;-		top_iph->flow_lbl[0] = iph->flow_lbl[0];-		top_iph->flow_lbl[1] = iph->flow_lbl[1];-		top_iph->flow_lbl[2] = iph->flow_lbl[2];-		dsfield = ipv6_get_dsfield(top_iph);-		dsfield = INET_ECN_encapsulate(dsfield, dsfield);-		if (x->props.flags & XFRM_STATE_NOECN)-			dsfield &= ~INET_ECN_MASK;-		ipv6_change_dsfield(top_iph, 0, dsfield);-		top_iph->nexthdr = IPPROTO_IPV6; -		top_iph->hop_limit = dst_metric(dst->child, RTAX_HOPLIMIT);-	}-	ipv6_addr_copy(&top_iph->saddr, (struct in6_addr *)&x->props.saddr);-	ipv6_addr_copy(&top_iph->daddr, (struct in6_addr *)&x->id.daddr);+	if (x->props.family == AF_INET6) {+		skb->nh.raw = &top_iph->nexthdr;+		skb->h.ipv6h = top_iph + 1;+		ipv6_addr_copy(&top_iph->saddr, (struct in6_addr *)&x->props.saddr);+		ipv6_addr_copy(&top_iph->daddr, (struct in6_addr *)&x->id.daddr);+		if (x->props.mode == XFRM_MODE_TUNNEL) {+			top_iph->version = 6;+			top_iph->priority = iph->priority;+			top_iph->flow_lbl[0] = iph->flow_lbl[0];+			top_iph->flow_lbl[1] = iph->flow_lbl[1];+			top_iph->flow_lbl[2] = iph->flow_lbl[2];+			dsfield = ipv6_get_dsfield(top_iph);+			dsfield = INET_ECN_encapsulate(dsfield, dsfield);+			if (x->props.flags & XFRM_STATE_NOECN)+				dsfield &= ~INET_ECN_MASK;+			ipv6_change_dsfield(top_iph, 0, dsfield);+			top_iph->nexthdr = IPPROTO_IPV6; +			top_iph->hop_limit = dst_metric(dst->child, RTAX_HOPLIMIT);+		}+	} else if (x->props.family == AF_INET) {+		/* Inner = 6, Outer = 4 : changing the external IP hdr+		 * to the outer addresses+		 */+		struct iphdr *top_iphv4;+		u8 protocol = iph->nexthdr;+		if (x->props.mode == XFRM_MODE_BEET) {+			int delta = sizeof(struct ipv6hdr) - sizeof(struct iphdr);+			skb->nh.raw = skb_pull(skb, delta);+		}+		top_iphv4 = skb->nh.iph;+		skb->h.raw = skb->data + hdrlen;+		top_iphv4->ihl = (sizeof(struct iphdr) >> 2);+		top_iphv4->version = 4;+		top_iphv4->id = 0;+		top_iphv4->frag_off = htons(IP_DF);+		top_iphv4->ttl = dst_metric(dst->child, RTAX_HOPLIMIT);+		top_iphv4->saddr = x->props.saddr.a4;+		top_iphv4->daddr = x->id.daddr.a4;+		if (x->props.mode == XFRM_MODE_TUNNEL)+			top_iphv4->protocol = IPPROTO_IPV6;+		else {+			skb->h.raw += top_iphv4->ihl*4;+			top_iphv4->protocol = protocol;+		}+	} else+		BUG_ON(1); }  static int xfrm6_tunnel_check_size(struct sk_buff *skb)diff -urN linux-2.6.15.6/net/ipv6/xfrm6_policy.c linux-2.6.15.6-full/net/ipv6/xfrm6_policy.c--- linux-2.6.15.6/net/ipv6/xfrm6_policy.c	2006-03-05 21:07:54.000000000 +0200+++ linux-2.6.15.6-full/net/ipv6/xfrm6_policy.c	2006-04-13 23:35:55.000000000 +0300@@ -26,6 +26,8 @@  static struct xfrm_type_map xfrm6_type_map = { .lock = RW_LOCK_UNLOCKED }; +static void xfrm6_update_pmtu(struct dst_entry *dst, u32 mtu);+ static int xfrm6_dst_lookup(struct xfrm_dst **dst, struct flowi *fl) { 	int err = 0;@@ -74,16 +76,19 @@ 	struct dst_entry *dst, *dst_prev; 	struct rt6_info *rt0 = (struct rt6_info*)(*dst_p); 	struct rt6_info *rt  = rt0;-	struct in6_addr *remote = &fl->fl6_dst;-	struct in6_addr *local  = &fl->fl6_src; 	struct flowi fl_tunnel = { 		.nl_u = { 			.ip6_u = {-				.saddr = *local,-				.daddr = *remote+				.saddr = fl->fl6_src,+				.daddr = fl->fl6_dst 			} 		} 	};+	union {+		struct in6_addr *in6;+		struct in_addr *in;+	} remote, local;+	unsigned short outer_family = 0, beet = 0; 	int i; 	int err = 0; 	int header_len = 0;@@ -95,7 +100,6 @@ 	for (i = 0; i < nx; i++) { 		struct dst_entry *dst1 = dst_alloc(&xfrm6_dst_ops); 		struct xfrm_dst *xdst;-		int tunnel = 0;  		if (unlikely(dst1 == NULL)) { 			err = -ENOBUFS;@@ -118,19 +122,35 @@  		dst1->next = dst_prev; 		dst_prev = dst1;-		if (xfrm[i]->props.mode) {-			remote = (struct in6_addr*)&xfrm[i]->id.daddr;-			local  = (struct in6_addr*)&xfrm[i]->props.saddr;-			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;+			} 		} 		header_len += xfrm[i]->props.header_len; 		trailer_len += xfrm[i]->props.trailer_len; -		if (tunnel) {-			ipv6_addr_copy(&fl_tunnel.fl6_dst, remote);-			ipv6_addr_copy(&fl_tunnel.fl6_src, local);+		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_INET6);+					      &fl_tunnel, outer_family); 			if (err) 				goto error; 		} else@@ -181,6 +201,11 @@ 	}  	xfrm_init_pmtu(dst);+	if (beet && outer_family == AF_INET) {+		int delta = sizeof(struct ipv6hdr) - sizeof(struct iphdr);+		u32 mtu = dst_mtu(dst);+		xfrm6_update_pmtu(dst, mtu + delta);+	} 	return 0;  error:diff -urN linux-2.6.15.6/net/key/af_key.c linux-2.6.15.6-full/net/key/af_key.c--- linux-2.6.15.6/net/key/af_key.c	2006-04-13 23:46:09.000000000 +0300+++ linux-2.6.15.6-full/net/key/af_key.c	2006-04-13 23:35:55.000000000 +0300@@ -1669,14 +1669,13 @@ 		if (!t->reqid && !(t->reqid = gen_reqid())) 			return -ENOBUFS; 	}--	/* addresses present only in tunnel mode */-	if (t->mode) {-		switch (xp->family) {+/* addresses present in any mode */+	{+		struct sockaddr *sa;+		sa = (struct sockaddr *)(rq+1);+		switch(sa->sa_family) { 		case AF_INET:-			sin = (void*)(rq+1);-			if (sin->sin_family != AF_INET)-				return -EINVAL;+			sin = (struct sockaddr_in *)sa; 			t->saddr.a4 = sin->sin_addr.s_addr; 			sin++; 			if (sin->sin_family != AF_INET)@@ -1685,9 +1684,7 @@ 			break; #if defined(CONFIG_IPV6) || defined(CONFIG_IPV6_MODULE) 		case AF_INET6:-			sin6 = (void *)(rq+1);-			if (sin6->sin6_family != AF_INET6)-				return -EINVAL;+			sin6 = (struct sockaddr_in6 *)sa; 			memcpy(t->saddr.a6, &sin6->sin6_addr, sizeof(struct in6_addr)); 			sin6++; 			if (sin6->sin6_family != AF_INET6)@@ -1698,6 +1695,7 @@ 		default: 			return -EINVAL; 		}+		t->outer_family = sa->sa_family; 	} 	/* No way to set this via kame pfkey */ 	t->aalgos = t->ealgos = t->calgos = ~0;diff -urN linux-2.6.15.6/net/xfrm/xfrm_policy.c linux-2.6.15.6-full/net/xfrm/xfrm_policy.c--- linux-2.6.15.6/net/xfrm/xfrm_policy.c	2006-03-05 21:07:54.000000000 +0200+++ linux-2.6.15.6-full/net/xfrm/xfrm_policy.c	2006-04-13 23:35:55.000000000 +0300@@ -674,6 +674,7 @@ 		if (tmpl->mode) { 			remote = &tmpl->id.daddr; 			local = &tmpl->saddr;+			family = tmpl->outer_family; 		}  		x = xfrm_state_find(remote, local, fl, tmpl, policy, &error, family);diff -urN linux-2.6.15.6/net/xfrm/xfrm_user.c linux-2.6.15.6-full/net/xfrm/xfrm_user.c--- linux-2.6.15.6/net/xfrm/xfrm_user.c	2006-04-13 23:46:09.000000000 +0300+++ linux-2.6.15.6-full/net/xfrm/xfrm_user.c	2006-04-13 23:35:55.000000000 +0300@@ -610,7 +610,6 @@ 	int i;  	xp->xfrm_nr = nr;-	xp->family = ut->family; 	for (i = 0; i < nr; i++, ut++) { 		struct xfrm_tmpl *t = &xp->xfrm_vec[i]; @@ -624,6 +623,7 @@ 		t->aalgos = ut->aalgos; 		t->ealgos = ut->ealgos; 		t->calgos = ut->calgos;+		t->outer_family = ut->family; 	} } 

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
在线观看国产日韩| 国产一区二区精品久久91| 日产精品久久久久久久性色| 美女在线观看视频一区二区| 国产精品白丝av| 91蝌蚪porny九色| 欧美一区二区福利在线| 国产精品免费免费| 亚洲午夜电影在线观看| 国产综合色视频| 91久久精品一区二区三区| 日韩一区二区三区在线| 日韩视频免费观看高清完整版| 亚洲国产美国国产综合一区二区| 天天操天天干天天综合网| 老司机午夜精品| 波多野结衣亚洲| 中文字幕电影一区| 丝袜美腿亚洲色图| 成人美女在线观看| 制服.丝袜.亚洲.中文.综合| 久久久激情视频| 国产精品无遮挡| 蜜臀91精品一区二区三区| 国产99久久精品| 7777精品伊人久久久大香线蕉的| wwwwww.欧美系列| 亚洲日本在线天堂| 精油按摩中文字幕久久| 成人h动漫精品一区二| 欧美日韩精品一区二区三区| 亚洲国产精品精华液ab| 亚洲福利一区二区三区| 国产精品88av| 91精品国产综合久久福利| 欧美国产激情一区二区三区蜜月 | 人妖欧美一区二区| 顶级嫩模精品视频在线看| 欧美日韩情趣电影| 国产欧美日韩另类视频免费观看| 亚洲国产一区二区在线播放| 国产一区二区三区久久悠悠色av| 91在线一区二区三区| 日韩三级.com| 亚洲三级视频在线观看| 精品中文字幕一区二区小辣椒| 99re这里只有精品视频首页| 精品精品国产高清a毛片牛牛| 亚洲免费观看高清| 国产乱码精品一区二区三区忘忧草 | 欧美片在线播放| 欧美国产日韩a欧美在线观看| 日本伊人精品一区二区三区观看方式| 成人免费av资源| 精品国产乱码久久久久久夜甘婷婷| 亚洲另类春色国产| 国产精品18久久久久久久久 | 国产精品区一区二区三区| 久久精品国产澳门| 欧美色精品在线视频| 国产精品久久影院| 国产一区二区三区综合| 91精品国产乱| 亚洲午夜一区二区三区| 国产1区2区3区精品美女| 精品国产一区二区三区四区四 | 精品亚洲porn| 91麻豆精品国产91久久久更新时间 | 91精品国产麻豆| 亚洲视频在线一区| 成人午夜激情在线| 日韩一卡二卡三卡四卡| 天堂va蜜桃一区二区三区漫画版| 91色九色蝌蚪| 国产精品美女久久久久av爽李琼 | 精品久久五月天| 亚洲一二三区在线观看| 91亚洲国产成人精品一区二三 | 91免费观看在线| 亚洲天堂中文字幕| 99综合影院在线| 日韩一区有码在线| 成人美女视频在线观看| 国产亚洲欧美色| 久久成人精品无人区| 日韩欧美视频在线| 另类中文字幕网| 精品少妇一区二区三区在线播放| 免费成人在线观看视频| 日韩一级欧美一级| 免费成人av资源网| 精品国偷自产国产一区| 捆绑紧缚一区二区三区视频| 精品国产一区二区精华| 精品制服美女久久| 久久久国产午夜精品| 国产成人免费高清| 国产精品污网站| 色综合久久中文字幕| 国产精品美女久久久久久久 | 欧美一区二区三区白人| 另类调教123区| www国产成人| 国产69精品久久777的优势| 国产精品理伦片| 欧美性感一区二区三区| 日本色综合中文字幕| 欧美精品一区二区精品网| 成人黄色在线看| 亚洲一区二区五区| 欧美一区二区二区| 激情久久五月天| 自拍偷自拍亚洲精品播放| 欧美亚日韩国产aⅴ精品中极品| 美女任你摸久久| 中文字幕免费不卡| 欧美精品18+| 国产高清精品久久久久| 国产精品久久久99| 欧美日韩一区二区三区免费看| 免费视频一区二区| 国产欧美精品在线观看| 一本色道久久综合狠狠躁的推荐| 婷婷久久综合九色国产成人| 久久久久国产精品麻豆ai换脸 | 欧美喷潮久久久xxxxx| 精品一区二区三区免费播放| 丁香六月久久综合狠狠色| 国产精品国产a| 欧美一区二区三区在| 国产精品一区二区久久不卡| 一区二区中文视频| 欧美一区二区黄| 91在线观看污| 婷婷中文字幕综合| 国产精品你懂的| 91精品国产乱码久久蜜臀| 色综合久久久久综合体桃花网| 日韩激情av在线| 亚洲美女淫视频| 久久网站最新地址| 91精品国产综合久久久久久| 成人在线视频首页| 午夜av区久久| 亚洲欧美怡红院| 日韩精品一区二区三区中文不卡 | 日韩理论电影院| 久久久91精品国产一区二区精品| 欧美性大战久久久久久久| 成人av集中营| 老司机午夜精品99久久| 一区二区三区四区蜜桃 | 蜜桃一区二区三区在线观看| 国产精品成人网| 精品国产区一区| 欧美日韩国产一区二区三区地区| 国产成人av电影在线观看| 亚洲自拍偷拍九九九| 国产日韩欧美亚洲| 欧美另类高清zo欧美| av亚洲产国偷v产偷v自拍| 久久99久久精品欧美| 伊人夜夜躁av伊人久久| 久久色视频免费观看| 7777精品伊人久久久大香线蕉最新版 | 久久成人免费网站| 亚洲一区二区三区四区的| 国产日韩欧美精品一区| 欧美日韩亚洲不卡| 一本大道综合伊人精品热热 | 97se亚洲国产综合自在线不卡| 欧美中文字幕一区二区三区| 成a人片亚洲日本久久| 亚洲成a人v欧美综合天堂| 亚洲色图.com| 中文字幕亚洲一区二区va在线| 久久久久久久网| 日韩视频一区在线观看| 欧美美女bb生活片| 在线免费观看一区| av不卡在线播放| 丁香另类激情小说| 国产成人亚洲综合色影视| 韩国一区二区视频| 日韩av中文字幕一区二区| 天天综合天天综合色| 亚洲国产精品久久艾草纯爱| 亚洲人成7777| 中文字幕一区二区三区视频| 久久久久国产成人精品亚洲午夜 | 亚洲va韩国va欧美va精品| 亚洲欧美激情视频在线观看一区二区三区 | 欧美韩日一区二区三区四区| 久久伊人中文字幕| 欧美电影免费观看高清完整版在| 91精品国产91久久久久久最新毛片| 欧美自拍丝袜亚洲| 欧美三级韩国三级日本三斤| 91精品福利在线| 色嗨嗨av一区二区三区|