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

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專(zhuān)輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? interfamily-beet-patch-2.6.9

?? Host Identity Protocol on Linux is an implemetation of the Host Identity Protocol (HIP) and the rela
?? 9
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
diff -urN linux-2.6.9-simple-patch/include/net/xfrm.h linux-2.6.9-interfamily/include/net/xfrm.h--- linux-2.6.9-simple-patch/include/net/xfrm.h	2004-10-19 00:54:55.000000000 +0300+++ linux-2.6.9-interfamily/include/net/xfrm.h	2006-08-05 15:49:52.000000000 +0300@@ -244,6 +244,10 @@ /* Source address of tunnel. Ignored, if it is not a tunnel. */ 	xfrm_address_t		saddr; +/* family of the outer addresses. The family may differ from+   the one in selector */+	unsigned short		outer_family;+ 	__u32			reqid;  /* Mode: transport/tunnel */diff -urN linux-2.6.9-simple-patch/net/ipv4/xfrm4_input.c linux-2.6.9-interfamily/net/ipv4/xfrm4_input.c--- linux-2.6.9-simple-patch/net/ipv4/xfrm4_input.c	2006-08-05 15:08:02.000000000 +0300+++ linux-2.6.9-interfamily/net/ipv4/xfrm4_input.c	2006-08-05 15:49:52.000000000 +0300@@ -94,15 +94,28 @@ 		iph = skb->nh.iph;  		if (x->props.mode == XFRM_MODE_TUNNEL) {-			if (iph->protocol != 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(iph, skb->h.ipiph);+			if (x->sel.family == AF_INET) {+				if (iph->protocol != 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(iph, skb->h.ipiph);+			} else if (x->sel.family == AF_INET6) {+				/* Inner = 6, Outer = 4 */+				if (skb->nh.iph->protocol != IPPROTO_IPV6)+					goto drop;++				if (skb_cloned(skb) &&+				    pskb_expand_head(skb, 0, 0, GFP_ATOMIC))+					goto drop;+				skb->protocol = htons(ETH_P_IPV6);+			} else+				BUG_ON(1);+ 			if (!(x->props.flags & XFRM_STATE_NOECN)) 				ipip_ecn_decapsulate(skb); 			skb->mac.raw = memmove(skb->data - skb->mac_len,@@ -112,52 +125,81 @@ 			decaps = 1; 			break; 		} else if (x->props.mode == XFRM_MODE_BEET) {-			struct ip_beet_phdr *ph = (struct ip_beet_phdr*)(iph + 1); 			int phlen = 0; 			int optlen = 0;-			__u8 ph_nexthdr = 0, protocol = 0;--			protocol = iph->protocol;-			if (unlikely(iph->protocol == 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;+			__u8 ph_nexthdr = 0;+			int size = (x->sel.family == AF_INET) ? sizeof(struct iphdr) : sizeof(struct ipv6hdr);+			int proto = skb->nh.iph->protocol;+			int hops = skb->nh.iph->ttl;+			int delta = sizeof(struct ipv6hdr) - sizeof(struct iphdr);+			if (x->sel.family == AF_INET6) {+				/* Here, the inner family is 6, therefore I have to+				 * substitute the IPhdr by enlarging it */+				if (skb_tailroom(skb) <  delta){+					if (pskb_expand_head(skb, 0, delta, GFP_ATOMIC))+						return -EINVAL;		//Just returning from here.+				}+				skb->nh.raw -= delta;+			} else if (x->sel.family == AF_INET) {+				// We need to extract the PH+				struct ip_beet_phdr *ph = (struct ip_beet_phdr*)(skb->nh.iph + 1);++				if (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;++					ph_nexthdr = ph->nexthdr;+				}+			} else+				BUG_ON(1); -				ph_nexthdr = ph->nexthdr;-			}  			if (skb_cloned(skb) && 			    pskb_expand_head(skb, 0, 0, GFP_ATOMIC)) 				goto drop; -			skb_push(skb, sizeof(struct iphdr));-			memmove(skb->data, skb->nh.raw, sizeof(struct iphdr));+			skb_push(skb, size);+			memmove(skb->data, skb->nh.raw, size); 			skb->nh.raw = skb->data; -			if (unlikely(phlen)) {-				skb_pull(skb, phlen - optlen);-				memmove(skb->data, skb->nh.raw, sizeof(*iph));-				skb->nh.raw = skb->data;-				iph = skb->nh.iph;-			}+			if (x->sel.family == AF_INET) {+				struct iphdr *iph = skb->nh.iph; -			iph = skb->nh.iph;-			iph->ihl = (sizeof(*iph) + optlen) / 4;-			iph->tot_len = htons(skb->len);-			iph->daddr = x->sel.daddr.a4;-			iph->saddr = x->sel.saddr.a4;-			if (ph_nexthdr)-				iph->protocol = ph_nexthdr;-			else-				iph->protocol = protocol;-			iph->check = 0;-			iph->check = ip_fast_csum(skb->nh.raw, iph->ihl);+				if (unlikely(phlen)) {+					skb_pull(skb, phlen - optlen);+					memmove(skb->data, skb->nh.raw, sizeof(*iph));+					skb->nh.raw = skb->data;+					iph = skb->nh.iph;+				}++				iph->ihl = (sizeof(*iph) + optlen) / 4;+				iph->tot_len = htons(skb->len);+				iph->daddr = x->sel.daddr.a4;+				iph->saddr = x->sel.saddr.a4;+				if (ph_nexthdr)+					iph->protocol = ph_nexthdr;+				else+					iph->protocol = proto;+				ip_send_check(iph);+			} else if (x->sel.family == AF_INET6) {+				struct ipv6hdr *ip6h = skb->nh.ipv6h;+				memset(ip6h->flow_lbl, 0, sizeof(ip6h->flow_lbl));+				ip6h->version = 6;+				ip6h->priority = 0;+				ip6h->nexthdr = proto;+				ip6h->hop_limit = hops;+				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);+				skb->protocol = htons(ETH_P_IPV6);+			} 			decaps = 1; 			break; 		}diff -urN linux-2.6.9-simple-patch/net/ipv4/xfrm4_output.c linux-2.6.9-interfamily/net/ipv4/xfrm4_output.c--- linux-2.6.9-simple-patch/net/ipv4/xfrm4_output.c	2006-08-06 14:20:55.000000000 +0300+++ linux-2.6.9-interfamily/net/ipv4/xfrm4_output.c	2006-08-06 14:33:53.000000000 +0300@@ -53,16 +53,18 @@  	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;-		memmove(top_iph, iph, hdrlen);+		if (x->props.family == AF_INET) {+			memmove(top_iph, iph, hdrlen);+		} 		if (unlikely(optlen)) { 			struct ip_beet_phdr *ph; @@ -71,38 +73,88 @@ 			ph = (struct ip_beet_phdr *)skb->h.raw; 			ph->padlen = 4 - (optlen & 4); 			ph->hdrlen = (optlen + ph->padlen + sizeof(*ph)) / 8;-			ph->nexthdr = top_iph->protocol;- +			ph->nexthdr = iph->protocol; 			top_iph->protocol = IPPROTO_BEETPH; 			top_iph->ihl = sizeof(struct iphdr) / 4; 		}+ 		break;-  	default: 	case XFRM_MODE_TUNNEL:-		top_iph->ihl = 5;-		top_iph->version = 4;+		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);+			/* 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);+			flags = x->props.flags;+			if (flags & XFRM_STATE_NOECN)+				IP_ECN_clear(top_iph);  -		top_iph->frag_off = iph->frag_off & htons(IP_DF);-		if (!top_iph->frag_off)-			__ip_select_ident(top_iph, dst, 0);+			top_iph->frag_off = 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->ttl = dst_metric(dst->child, RTAX_HOPLIMIT); -		top_iph->protocol = IPPROTO_IPIP;-		memset(&(IPCB(skb)->opt), 0, sizeof(struct ip_options));+			top_iph->protocol = IPPROTO_IPIP;+			memset(&(IPCB(skb)->opt), 0, sizeof(struct ip_options));+		} 		break; 	} -	top_iph->saddr = x->props.saddr.a4;-	top_iph->daddr = x->id.daddr.a4;+	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)@@ -135,7 +187,7 @@ 	struct dst_entry *dst = skb->dst; 	struct xfrm_state *x = dst->xfrm; 	int err;-	+ 	if (skb->ip_summed == CHECKSUM_HW) { 		err = skb_checksum_help(pskb, 0); 		skb = *pskb;diff -urN linux-2.6.9-simple-patch/net/ipv4/xfrm4_policy.c linux-2.6.9-interfamily/net/ipv4/xfrm4_policy.c--- linux-2.6.9-simple-patch/net/ipv4/xfrm4_policy.c	2004-10-19 00:54:54.000000000 +0300+++ linux-2.6.9-interfamily/net/ipv4/xfrm4_policy.c	2006-08-07 21:39:45.000000000 +0300@@ -17,6 +17,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);@@ -73,20 +75,33 @@ 	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 = fl->fl4_src,+				.daddr = fl->fl4_dst+			}+		}+	};+	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; 	int trailer_len = 0;  	dst = dst_prev = NULL;+	dst_hold(&rt->u.dst);  	for (i = 0; i < nx; i++) { 		struct dst_entry *dst1 = dst_alloc(&xfrm4_dst_ops);  		if (unlikely(dst1 == NULL)) { 			err = -ENOBUFS;+			dst_release(&rt->u.dst); 			goto error; 		} @@ -98,27 +113,55 @@ 			dst_clone(dst1); 		} 		dst_prev = dst1;-		if (xfrm[i]->props.mode) {-			remote = xfrm[i]->id.daddr.a4;-			local  = xfrm[i]->props.saddr.a4;+		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 (remote != fl->fl4_dst) {-		struct flowi fl_tunnel = { .nl_u = { .ip4_u =-						     { .daddr = remote,-						       .saddr = local }-					           }-				         };-		err = xfrm_dst_lookup((struct xfrm_dst**)&rt, &fl_tunnel, AF_INET);-		if (err)-			goto error;-	} else {-		dst_hold(&rt->u.dst);+		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, 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); 	}+ 	dst_prev->child = &rt->u.dst;+	dst->path = &rt->u.dst;++	*dst_p = dst;+	dst = dst_prev;++	dst_prev = *dst_p; 	i = 0; 	for (dst_prev = dst; dst_prev != &rt->u.dst; dst_prev = dst_prev->child) { 		struct xfrm_dst *x = (struct xfrm_dst*)dst_prev;@@ -154,7 +197,13 @@ 		header_len -= x->u.dst.xfrm->props.header_len; 		trailer_len -= x->u.dst.xfrm->props.trailer_len; 	}+ 	*dst_p = dst;+	if (beet && outer_family == AF_INET6) {+		int delta = sizeof(struct ipv6hdr) - sizeof(struct iphdr);+		u32 mtu = dst_metric(dst, RTAX_MTU);+		xfrm4_update_pmtu(dst, mtu - delta);+	} 	return 0;  error:diff -urN linux-2.6.9-simple-patch/net/ipv6/ah6.c linux-2.6.9-interfamily/net/ipv6/ah6.c--- linux-2.6.9-simple-patch/net/ipv6/ah6.c	2006-08-05 15:08:02.000000000 +0300+++ linux-2.6.9-interfamily/net/ipv6/ah6.c	2006-08-05 15:50:11.000000000 +0300@@ -398,6 +398,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.9-simple-patch/net/ipv6/esp6.c linux-2.6.9-interfamily/net/ipv6/esp6.c--- linux-2.6.9-simple-patch/net/ipv6/esp6.c	2006-08-05 15:08:02.000000000 +0300

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久伊人中文字幕| 亚洲gay无套男同| 日本午夜精品视频在线观看| 综合欧美亚洲日本| 国产精品色噜噜| 国产精品福利影院| 欧美激情一区二区| 国产精品三级视频| 中文字幕欧美区| 国产精品免费视频一区| 亚洲国产精品av| 1024成人网| 亚洲美女一区二区三区| 亚洲综合在线电影| 亚洲一区二区黄色| 日本不卡一区二区三区高清视频| 天天影视涩香欲综合网| 欧美a级理论片| 久久国产生活片100| 国产一区亚洲一区| 成人精品一区二区三区四区| eeuss鲁一区二区三区| 91精品办公室少妇高潮对白| 欧美综合视频在线观看| 91精品国产综合久久国产大片| 91精品国产色综合久久| 久久伊人蜜桃av一区二区| 国产精品美女久久久久aⅴ| 一区精品在线播放| 亚洲成人av福利| 精品一区二区免费视频| 成人免费不卡视频| 欧美唯美清纯偷拍| 久久影院视频免费| 久久精品国产一区二区三区免费看| 午夜免费久久看| 久久成人免费日本黄色| 国产成人精品一区二| 一本久久综合亚洲鲁鲁五月天 | 综合久久一区二区三区| 亚洲五码中文字幕| 久久er精品视频| 99精品视频中文字幕| 欧美欧美欧美欧美| 久久精品一区二区| 洋洋成人永久网站入口| 久久成人精品无人区| 99久久久精品免费观看国产蜜| 欧美日韩电影在线播放| 久久久www免费人成精品| 亚洲制服丝袜av| 国产精品一区二区三区99| 欧美亚洲尤物久久| 久久久久久久电影| 亚洲第一电影网| 成人sese在线| 日韩视频在线一区二区| 亚洲欧美另类综合偷拍| 国产中文字幕精品| 欧美色欧美亚洲另类二区| 国产日韩欧美a| 日韩电影在线观看一区| 97se狠狠狠综合亚洲狠狠| 欧美mv日韩mv亚洲| 亚洲一区二区三区四区在线观看 | 色94色欧美sute亚洲线路一久| 日韩一级免费观看| 日韩欧美一区在线| 亚洲综合精品自拍| 国内精品国产成人国产三级粉色| 91在线视频18| 国产亚洲综合在线| 免费美女久久99| 欧美在线观看一二区| 中文字幕在线观看一区| 国产一区啦啦啦在线观看| 777午夜精品免费视频| 国产精品成人午夜| 国产乱子伦视频一区二区三区 | 中文字幕在线不卡国产视频| 精品无码三级在线观看视频| 欧美亚洲尤物久久| 国产成人av在线影院| 欧美一级国产精品| 午夜久久电影网| 在线亚洲精品福利网址导航| 国产精品久久久久久久久搜平片| av一二三不卡影片| 91丝袜美腿高跟国产极品老师| 精品免费国产一区二区三区四区| 亚洲综合丁香婷婷六月香| av亚洲精华国产精华| 国产日产亚洲精品系列| 久久综合综合久久综合| 欧美一区二区三区视频在线| 亚洲福利电影网| 在线观看日韩电影| 亚洲一区欧美一区| 欧美午夜一区二区| 一区二区三区四区不卡视频| 色综合天天综合网天天看片| 国产精品久99| 99国产精品久久| 亚洲男人天堂一区| 色狠狠一区二区三区香蕉| 亚洲精品国产a久久久久久 | 国产欧美日韩综合精品一区二区 | 欧美日本乱大交xxxxx| 亚洲综合一二区| 欧美午夜在线观看| 丝袜美腿亚洲一区| 日韩亚洲国产中文字幕欧美| 看国产成人h片视频| 精品国产乱码久久久久久久久| 精品一区二区三区不卡| 久久精品免视看| av亚洲产国偷v产偷v自拍| 亚洲日本青草视频在线怡红院| 一本一本久久a久久精品综合麻豆| 玉米视频成人免费看| 欧美天天综合网| 蜜桃视频第一区免费观看| 26uuu国产电影一区二区| 国产91精品一区二区麻豆网站| 国产精品美女久久久久aⅴ | 成人在线综合网| 中文字幕在线不卡| 欧美亚洲另类激情小说| 亚洲不卡av一区二区三区| 日韩一级欧美一级| 国产成人一级电影| 亚洲欧美另类综合偷拍| 欧美日本国产视频| 国产一区二区三区香蕉| 国产精品成人在线观看 | 亚洲午夜一区二区三区| 91精品国产综合久久久久久漫画| 狠狠狠色丁香婷婷综合久久五月| 国产情人综合久久777777| 色播五月激情综合网| 免费成人av资源网| 国产精品毛片大码女人| 欧美三级韩国三级日本一级| 精品一区二区三区的国产在线播放 | 欧美在线免费视屏| 精品一区二区在线免费观看| 中文字幕制服丝袜一区二区三区| 欧美三级视频在线观看| 国产一区在线观看麻豆| 亚洲欧美日韩国产综合| 日韩欧美第一区| 91视频在线看| 蜜桃av噜噜一区| 亚洲视频香蕉人妖| 欧美成人女星排行榜| 91视频.com| 国产做a爰片久久毛片| 亚洲综合一区二区精品导航| 久久久精品中文字幕麻豆发布| 色猫猫国产区一区二在线视频| 久久精品理论片| 亚洲最色的网站| 中文字幕二三区不卡| 欧美日韩国产三级| 不卡的电影网站| 久久狠狠亚洲综合| 亚洲午夜免费电影| 国产精品毛片久久久久久久| 日韩精品中文字幕一区 | 亚洲免费电影在线| 26uuuu精品一区二区| 欧美日韩成人综合| 91免费视频大全| 国产成人综合亚洲网站| 日韩精品电影在线观看| 亚洲男人天堂av网| 国产精品色一区二区三区| 欧美tk—视频vk| 777久久久精品| 欧美色男人天堂| 色综合久久88色综合天天6| 国产91在线看| 激情久久久久久久久久久久久久久久| 亚洲一区二区三区四区在线免费观看 | 成人免费看视频| 国产在线国偷精品免费看| 日一区二区三区| 一区二区三区免费| 中文字幕欧美一| 国产欧美一区视频| 久久亚洲精品小早川怜子| 日韩一区二区不卡| 91精品国产黑色紧身裤美女| 欧美午夜片在线观看| 色婷婷av一区| 色乱码一区二区三区88| 91女人视频在线观看| 91最新地址在线播放| thepron国产精品| 成人精品亚洲人成在线|