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

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

?? irpmarshall.c

?? package of develop dns
?? C
?? 第 1 頁 / 共 3 頁
字號:
/* * Copyright(c) 1989, 1993, 1995 *	The Regents of the University of California.  All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright *    notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright *    notice, this list of conditions and the following disclaimer in the *    documentation and/or other materials provided with the distribution. * 3. All advertising materials mentioning features or use of this software *    must display the following acknowledgement: *	This product includes software developed by the University of *	California, Berkeley and its contributors. * 4. Neither the name of the University nor the names of its contributors *    may be used to endorse or promote products derived from this software *    without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. *//* * Copyright (c) 2004 by Internet Systems Consortium, Inc. ("ISC") * Portions Copyright (c) 1996 by Internet Software Consortium. * * Permission to use, copy, modify, and distribute this software for any * purpose with or without fee is hereby granted, provided that the above * copyright notice and this permission notice appear in all copies. * * THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF * MERCHANTABILITY AND FITNESS.  IN NO EVENT SHALL ISC BE LIABLE FOR * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT * OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. */#if defined(LIBC_SCCS) && !defined(lint)static const char rcsid[] = "$Id: irpmarshall.c,v 1.3.206.3 2004/03/17 01:13:34 marka Exp $";#endif /* LIBC_SCCS and not lint */#if 0Check values are in approrpriate endian order.Double check memory allocations on unmarhsalling#endif/* Extern */#include "port_before.h"#include <sys/types.h>#include <sys/socket.h>#include <netinet/in.h>#include <arpa/inet.h>#include <arpa/nameser.h>#include <stdio.h>#include <ctype.h>#include <pwd.h>#include <stdlib.h>#include <string.h>#include <syslog.h>#include <utmp.h>#include <unistd.h>#include <assert.h>#include <errno.h>#include <irs.h>#include <isc/memcluster.h>#include <isc/irpmarshall.h>#include "port_after.h"#ifndef HAVE_STRNDUPstatic char    *strndup(const char *str, size_t len);#endifstatic char   **splitarray(const char *buffer, const char *buffend, char delim);static int	joinarray(char * const * argv, char *buffer, char delim);static char    *getfield(char **res, size_t reslen, char **buffer, char delim);static size_t	joinlength(char * const *argv);static void	free_array(char **argv, size_t entries);#define ADDR_T_STR(x) (x == AF_INET ? "AF_INET" :\		       (x == AF_INET6 ? "AF_INET6" : "UNKNOWN"))#define MAXPADDRSIZE (sizeof "255.255.255.255" + 1)static char COMMA = ',';static const char *COMMASTR = ",";static const char *COLONSTR = ":";/* See big comment at bottom of irpmarshall.h for description. */#ifdef WANT_IRS_PW/* +++++++++++++++++++++++++ struct passwd +++++++++++++++++++++++++ *//* * int irp_marshall_pw(const struct passwd *pw, char **buffer, size_t *len) * * notes: * *	See above * * return: * *	0 on sucess, -1 on failure. * */intirp_marshall_pw(const struct passwd *pw, char **buffer, size_t *len) {	size_t need = 1 ;		/* for null byte */	char pwUid[24];	char pwGid[24];	char pwChange[24];	char pwExpire[24];	const char *pwClass;	const char *fieldsep = COLONSTR;	if (pw == NULL || len == NULL) {		errno = EINVAL;		return (-1);	}	sprintf(pwUid, "%ld", (long)pw->pw_uid);	sprintf(pwGid, "%ld", (long)pw->pw_gid);#ifdef HAVE_PW_CHANGE	sprintf(pwChange, "%ld", (long)pw->pw_change);#else	pwChange[0] = '0';	pwChange[1] = '\0';#endif#ifdef HAVE_PW_EXPIRE	sprintf(pwExpire, "%ld", (long)pw->pw_expire);#else	pwExpire[0] = '0';	pwExpire[1] = '\0';#endif#ifdef HAVE_PW_CLASS	pwClass = pw->pw_class;#else	pwClass = "";#endif	need += strlen(pw->pw_name)	+ 1; /* one for fieldsep */	need += strlen(pw->pw_passwd)	+ 1;	need += strlen(pwUid)		+ 1;	need += strlen(pwGid)		+ 1;	need += strlen(pwClass)		+ 1;	need += strlen(pwChange)	+ 1;	need += strlen(pwExpire)	+ 1;	need += strlen(pw->pw_gecos)	+ 1;	need += strlen(pw->pw_dir)	+ 1;	need += strlen(pw->pw_shell)	+ 1;	if (buffer == NULL) {		*len = need;		return (0);	}	if (*buffer != NULL && need > *len) {		errno = EINVAL;		return (-1);	}	if (*buffer == NULL) {		need += 2;		/* for CRLF */		*buffer = memget(need);		if (*buffer == NULL) {			errno = ENOMEM;			return (-1);		}		*len = need;	}	strcpy(*buffer, pw->pw_name);		strcat(*buffer, fieldsep);	strcat(*buffer, pw->pw_passwd);		strcat(*buffer, fieldsep);	strcat(*buffer, pwUid);			strcat(*buffer, fieldsep);	strcat(*buffer, pwGid);			strcat(*buffer, fieldsep);	strcat(*buffer, pwClass);		strcat(*buffer, fieldsep);	strcat(*buffer, pwChange);		strcat(*buffer, fieldsep);	strcat(*buffer, pwExpire);		strcat(*buffer, fieldsep);	strcat(*buffer, pw->pw_gecos);		strcat(*buffer, fieldsep);	strcat(*buffer, pw->pw_dir);		strcat(*buffer, fieldsep);	strcat(*buffer, pw->pw_shell);		strcat(*buffer, fieldsep);	return (0);}/* * int irp_unmarshall_pw(struct passwd *pw, char *buffer) * * notes: * *	see above * * return: * *	0 on success, -1 on failure * */intirp_unmarshall_pw(struct passwd *pw, char *buffer) {	char *name, *pass, *class, *gecos, *dir, *shell;	uid_t pwuid;	gid_t pwgid;	time_t pwchange;	time_t pwexpire;	char *p;	long t;	char tmpbuf[24];	char *tb = &tmpbuf[0];	char fieldsep = ':';	int myerrno = EINVAL;	name = pass = class = gecos = dir = shell = NULL;	p = buffer;	/* pw_name field */	name = NULL;	if (getfield(&name, 0, &p, fieldsep) == NULL || strlen(name) == 0) {		goto error;	}	/* pw_passwd field */	pass = NULL;	if (getfield(&pass, 0, &p, fieldsep) == NULL) { /* field can be empty */		goto error;	}	/* pw_uid field */	tb = tmpbuf;	if (getfield(&tb, sizeof tmpbuf, &p, fieldsep) == NULL ||	    strlen(tb) == 0) {		goto error;	}	t = strtol(tmpbuf, &tb, 10);	if (*tb) {		goto error;	/* junk in value */	}	pwuid = (uid_t)t;	if ((long) pwuid != t) {	/* value must have been too big. */		goto error;	}	/* pw_gid field */	tb = tmpbuf;	if (getfield(&tb, sizeof tmpbuf, &p, fieldsep) == NULL ||	    strlen(tb) == 0) {		goto error;	}	t = strtol(tmpbuf, &tb, 10);	if (*tb) {		goto error;	/* junk in value */	}	pwgid = (gid_t)t;	if ((long)pwgid != t) {	/* value must have been too big. */		goto error;	}	/* pw_class field */	class = NULL;	if (getfield(&class, 0, &p, fieldsep) == NULL) {		goto error;	}	/* pw_change field */	tb = tmpbuf;	if (getfield(&tb, sizeof tmpbuf, &p, fieldsep) == NULL ||	    strlen(tb) == 0) {		goto error;	}	t = strtol(tmpbuf, &tb, 10);	if (*tb) {		goto error;	/* junk in value */	}	pwchange = (time_t)t;	if ((long)pwchange != t) {	/* value must have been too big. */		goto error;	}	/* pw_expire field */	tb = tmpbuf;	if (getfield(&tb, sizeof tmpbuf, &p, fieldsep) == NULL ||	    strlen(tb) == 0) {		goto error;	}	t = strtol(tmpbuf, &tb, 10);	if (*tb) {		goto error;	/* junk in value */	}	pwexpire = (time_t)t;	if ((long) pwexpire != t) {	/* value must have been too big. */		goto error;	}	/* pw_gecos field */	gecos = NULL;	if (getfield(&gecos, 0, &p, fieldsep) == NULL) {		goto error;	}	/* pw_dir field */	dir = NULL;	if (getfield(&dir, 0, &p, fieldsep) == NULL) {		goto error;	}	/* pw_shell field */	shell = NULL;	if (getfield(&shell, 0, &p, fieldsep) == NULL) {		goto error;	}	pw->pw_name = name;	pw->pw_passwd = pass;	pw->pw_uid = pwuid;	pw->pw_gid = pwgid;	pw->pw_gecos = gecos;	pw->pw_dir = dir;	pw->pw_shell = shell;#ifdef HAVE_PW_CHANGE	pw->pw_change = pwchange;#endif#ifdef HAVE_PW_CLASS	pw->pw_class = class;#endif#ifdef HAVE_PW_EXPIRE	pw->pw_expire = pwexpire;#endif	return (0); error:	errno = myerrno;	if (name != NULL) free(name);	if (pass != NULL) free(pass);	if (gecos != NULL) free(gecos);	if (dir != NULL) free(dir);	if (shell != NULL) free(shell);	return (-1);}/* ------------------------- struct passwd ------------------------- */#endif /* WANT_IRS_PW *//* +++++++++++++++++++++++++ struct group +++++++++++++++++++++++++ *//* * int irp_marshall_gr(const struct group *gr, char **buffer, size_t *len) * * notes: * *	see above. * * return: * *	0 on success, -1 on failure */intirp_marshall_gr(const struct group *gr, char **buffer, size_t *len) {	size_t need = 1;	/* for null byte */	char grGid[24];	const char *fieldsep = COLONSTR;	if (gr == NULL || len == NULL) {		errno = EINVAL;		return (-1);	}	sprintf(grGid, "%ld", (long)gr->gr_gid);	need += strlen(gr->gr_name) + 1;#ifndef MISSING_GR_PASSWD	need += strlen(gr->gr_passwd) + 1;#else	need++;#endif	need += strlen(grGid) + 1;	need += joinlength(gr->gr_mem) + 1;	if (buffer == NULL) {		*len = need;		return (0);	}	if (*buffer != NULL && need > *len) {		errno = EINVAL;		return (-1);	}	if (*buffer == NULL) {		need += 2;		/* for CRLF */		*buffer = memget(need);		if (*buffer == NULL) {			errno = ENOMEM;			return (-1);		}		*len = need;	}	strcpy(*buffer, gr->gr_name);		strcat(*buffer, fieldsep);#ifndef MISSING_GR_PASSWD	strcat(*buffer, gr->gr_passwd);#endif	strcat(*buffer, fieldsep);	strcat(*buffer, grGid);			strcat(*buffer, fieldsep);	joinarray(gr->gr_mem, *buffer, COMMA) ;	strcat(*buffer, fieldsep);	return (0);}/* * int irp_unmarshall_gr(struct group *gr, char *buffer) * * notes: * *	see above * * return: * *	0 on success and -1 on failure. * */intirp_unmarshall_gr(struct group *gr, char *buffer) {	char *p, *q;	gid_t grgid;	long t;	char *name = NULL;	char *pass = NULL;	char **members = NULL;	char tmpbuf[24];	char *tb;	char fieldsep = ':';	int myerrno = EINVAL;	if (gr == NULL || buffer == NULL) {		errno = EINVAL;		return (-1);	}	p = buffer;	/* gr_name field */	name = NULL;	if (getfield(&name, 0, &p, fieldsep) == NULL || strlen(name) == 0U) {		goto error;	}	/* gr_passwd field */	pass = NULL;	if (getfield(&pass, 0, &p, fieldsep) == NULL) {		goto error;	}	/* gr_gid field */	tb = tmpbuf;	if (getfield(&tb, sizeof tmpbuf, &p, fieldsep) == NULL ||	    strlen(tb) == 0U) {		goto error;	}	t = strtol(tmpbuf, &tb, 10);	if (*tb) {		goto error;	/* junk in value */	}	grgid = (gid_t)t;	if ((long) grgid != t) {	/* value must have been too big. */		goto error;	}	/* gr_mem field. Member names are separated by commas */	q = strchr(p, fieldsep);	if (q == NULL) {		goto error;	}	members = splitarray(p, q, COMMA);	if (members == NULL) {		myerrno = errno;		goto error;	}	p = q + 1;	gr->gr_name = name;#ifndef MISSING_GR_PASSWD	gr->gr_passwd = pass;#endif	gr->gr_gid = grgid;	gr->gr_mem = members;	return (0); error:	errno = myerrno;	if (name != NULL) free(name);	if (pass != NULL) free(pass);	return (-1);}/* ------------------------- struct group ------------------------- *//* +++++++++++++++++++++++++ struct servent +++++++++++++++++++++++++ *//* * int irp_marshall_sv(const struct servent *sv, char **buffer, size_t *len) * * notes: * *	see above * * return: * *	0 on success, -1 on failure. * */intirp_marshall_sv(const struct servent *sv, char **buffer, size_t *len) {	size_t need = 1;	/* for null byte */	char svPort[24];	const char *fieldsep = COLONSTR;	short realport;	if (sv == NULL || len == NULL) {		errno = EINVAL;		return (-1);	}	/* the int s_port field is actually a short in network order. We	   want host order to make the marshalled data look correct */	realport = ntohs((short)sv->s_port);	sprintf(svPort, "%d", realport);	need += strlen(sv->s_name) + 1;	need += joinlength(sv->s_aliases) + 1;	need += strlen(svPort) + 1;	need += strlen(sv->s_proto) + 1;	if (buffer == NULL) {		*len = need;		return (0);	}	if (*buffer != NULL && need > *len) {		errno = EINVAL;		return (-1);	}	if (*buffer == NULL) {		need += 2;		/* for CRLF */		*buffer = memget(need);		if (*buffer == NULL) {			errno = ENOMEM;			return (-1);		}		*len = need;	}	strcpy(*buffer, sv->s_name);		strcat(*buffer, fieldsep);	joinarray(sv->s_aliases, *buffer, COMMA); strcat(*buffer, fieldsep);	strcat(*buffer, svPort);		strcat(*buffer, fieldsep);	strcat(*buffer, sv->s_proto);		strcat(*buffer, fieldsep);	return (0);}/* * int irp_unmarshall_sv(struct servent *sv, char *buffer) * * notes: * *	see above * * return: * *	0 on success, -1 on failure. * */intirp_unmarshall_sv(struct servent *sv, char *buffer) {	char *p, *q;	short svport;	long t;	char *name = NULL;	char *proto = NULL;	char **aliases = NULL;	char tmpbuf[24];	char *tb;	char fieldsep = ':';	int myerrno = EINVAL;	if (sv == NULL || buffer == NULL)		return (-1);	p = buffer;	/* s_name field */	name = NULL;	if (getfield(&name, 0, &p, fieldsep) == NULL || strlen(name) == 0U) {		goto error;	}	/* s_aliases field */	q = strchr(p, fieldsep);	if (q == NULL) {		goto error;	}	aliases = splitarray(p, q, COMMA);	if (aliases == NULL) {		myerrno = errno;		goto error;	}	p = q + 1;	/* s_port field */	tb = tmpbuf;	if (getfield(&tb, sizeof tmpbuf, &p, fieldsep) == NULL ||	    strlen(tb) == 0U) {		goto error;	}	t = strtol(tmpbuf, &tb, 10);	if (*tb) {		goto error;	/* junk in value */	}	svport = (short)t;	if ((long) svport != t) {	/* value must have been too big. */		goto error;	}	svport = htons(svport);	/* s_proto field */	proto = NULL;	if (getfield(&proto, 0, &p, fieldsep) == NULL) {		goto error;	}	sv->s_name = name;	sv->s_aliases = aliases;	sv->s_port = svport;	sv->s_proto = proto;	return (0); error:	errno = myerrno;	if (name != NULL) free(name);	if (proto != NULL) free(proto);	free_array(aliases, 0);	return (-1);}/* ------------------------- struct servent ------------------------- *//* +++++++++++++++++++++++++ struct protoent +++++++++++++++++++++++++ *//* * int irp_marshall_pr(struct protoent *pr, char **buffer, size_t *len) * * notes: * *	see above * * return: * *	0 on success and -1 on failure. * */intirp_marshall_pr(struct protoent *pr, char **buffer, size_t *len) {	size_t need = 1;	/* for null byte */	char prProto[24];	const char *fieldsep = COLONSTR;	if (pr == NULL || len == NULL) {		errno = EINVAL;		return (-1);	}	sprintf(prProto, "%d", (int)pr->p_proto);	need += strlen(pr->p_name) + 1;	need += joinlength(pr->p_aliases) + 1;	need += strlen(prProto) + 1;	if (buffer == NULL) {		*len = need;		return (0);	}	if (*buffer != NULL && need > *len) {		errno = EINVAL;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产综合色在线| 狠狠久久亚洲欧美| 伦理电影国产精品| 色婷婷av一区二区| 欧美精品一区二区蜜臀亚洲| 亚洲国产另类av| 2020国产成人综合网| 7777精品伊人久久久大香线蕉经典版下载 | 欧美性生活一区| 久久综合色8888| 日韩激情中文字幕| 色综合久久天天| 中文字幕免费不卡| 国内精品写真在线观看 | 国产盗摄一区二区三区| 精品视频资源站| 亚洲乱码中文字幕| 国产a久久麻豆| 国产亚洲欧美日韩日本| 精品影院一区二区久久久| 欧美伦理电影网| 亚洲第一av色| 欧美中文一区二区三区| 亚洲欧美日韩国产手机在线| 不卡av电影在线播放| 久久久五月婷婷| 久久99日本精品| 精品国产伦一区二区三区免费| 亚洲第四色夜色| 欧美婷婷六月丁香综合色| 伊人夜夜躁av伊人久久| 日本丰满少妇一区二区三区| 亚洲欧美精品午睡沙发| 日本韩国一区二区| 亚洲午夜精品久久久久久久久| 色哟哟一区二区| 亚洲精品视频免费看| 色综合久久中文综合久久97| 亚洲精品高清视频在线观看| 在线精品视频小说1| 亚洲午夜激情av| 91精品久久久久久蜜臀| 蜜臀a∨国产成人精品| 欧美va在线播放| 亚洲国产裸拍裸体视频在线观看乱了 | 99国产精品久| 国产精品超碰97尤物18| 97久久久精品综合88久久| 亚洲视频网在线直播| 在线观看亚洲一区| 日韩电影在线观看网站| 精品三级av在线| 懂色av中文字幕一区二区三区 | 久久亚区不卡日本| 大桥未久av一区二区三区中文| 中文字幕欧美区| 91传媒视频在线播放| 视频在线观看91| 久久免费偷拍视频| 色综合色综合色综合| 亚洲sss视频在线视频| 精品久久久久久久久久久久久久久| 国产老肥熟一区二区三区| 亚洲色图.com| 欧美一区二区在线免费播放 | 美女在线视频一区| 国产精品亲子伦对白| 欧美日韩中文字幕一区| 国产一区二区三区四| 一区二区日韩av| 久久久不卡网国产精品一区| 色哦色哦哦色天天综合| 激情亚洲综合在线| 亚洲激情成人在线| 久久综合九色综合欧美98| 一本久久精品一区二区| 久久超碰97人人做人人爱| 国产精品久久久久一区二区三区 | 毛片基地黄久久久久久天堂| 国产精品国产三级国产a| 91精品中文字幕一区二区三区| 国产成人午夜精品影院观看视频 | 欧美视频完全免费看| 国产精品综合一区二区| 日本中文一区二区三区| 亚洲美女免费在线| 日本一区二区在线不卡| 欧美va亚洲va| 欧美精品三级在线观看| 99久久99久久久精品齐齐| 天天综合日日夜夜精品| 亚洲日本免费电影| 国产欧美精品日韩区二区麻豆天美| 欧美视频在线一区| 91蝌蚪porny成人天涯| 久久精品国产99国产| 午夜成人免费电影| 亚洲女厕所小便bbb| 国产欧美一区二区精品秋霞影院| 欧美一区二区三区在线看| 色噜噜夜夜夜综合网| 成人一级片网址| 国产制服丝袜一区| 狠狠色丁香婷婷综合久久片| 人人超碰91尤物精品国产| 午夜精品福利一区二区三区蜜桃| 亚洲免费在线电影| 亚洲欧美影音先锋| 国产精品毛片久久久久久| 久久免费电影网| 久久伊99综合婷婷久久伊| 日韩精品一区二区三区视频在线观看| 欧美伊人久久久久久久久影院| 91丨九色porny丨蝌蚪| a在线播放不卡| 91网页版在线| 在线一区二区三区四区五区| 日本韩国欧美一区| 欧美日韩精品欧美日韩精品| 欧美精选在线播放| 91精品国模一区二区三区| 91精品国产麻豆国产自产在线| 欧美精品在线一区二区三区| 在线播放国产精品二区一二区四区 | 欧美大片在线观看| 久久青草国产手机看片福利盒子 | 欧美精品粉嫩高潮一区二区| 9191国产精品| 精品sm在线观看| 国产精品入口麻豆原神| 亚洲欧美激情小说另类| 五月激情综合网| 精品一区二区三区免费视频| 国产精品一二三在| 91丨九色丨蝌蚪富婆spa| 欧美性猛片aaaaaaa做受| 欧美精品第一页| 久久综合狠狠综合| 亚洲欧美日韩人成在线播放| 亚洲电影一级片| 国产一区二三区| 91色九色蝌蚪| 欧美一区二区在线观看| 国产欧美综合在线观看第十页| 日韩一区在线看| 日韩成人精品视频| 国产成人自拍网| 欧美日韩国产免费| 久久精品在线免费观看| 一区二区三区不卡视频在线观看| 免费在线观看视频一区| 成人免费视频一区二区| 91黄色免费看| 国产亚洲精品福利| 亚洲一二三区在线观看| 国产精选一区二区三区| 91高清在线观看| 精品国产区一区| 亚洲综合视频在线观看| 国产精品一区三区| 欧美美女bb生活片| 国产精品久久99| 极品少妇一区二区| 欧美三级三级三级爽爽爽| 国产农村妇女毛片精品久久麻豆| 夜夜亚洲天天久久| 国产成人精品网址| 欧美日韩精品一二三区| 自拍av一区二区三区| 韩国av一区二区三区在线观看| 欧洲av一区二区嗯嗯嗯啊| 亚洲国产岛国毛片在线| 久久99精品久久久久久| 777欧美精品| 一区二区三区四区av| 粉嫩av一区二区三区粉嫩 | 欧美四级电影在线观看| 中文字幕av一区二区三区高| 另类专区欧美蜜桃臀第一页| 欧美在线小视频| 成人免费在线视频| 丰满少妇久久久久久久 | 日韩一区二区电影在线| 一区二区三区欧美激情| 成人h动漫精品一区二区| 久久美女高清视频| 精品一区二区三区蜜桃| 日韩欧美一级二级三级久久久| 亚洲国产日韩a在线播放性色| 高清不卡一二三区| 国产香蕉久久精品综合网| 麻豆高清免费国产一区| 制服丝袜亚洲播放| 亚洲一区二三区| 色婷婷国产精品综合在线观看| 一区在线观看免费| 91片在线免费观看| 一区二区三区日韩欧美| 91在线观看下载| 亚洲精品第1页|