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

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

?? xfs_ioctl.c

?? 優(yōu)龍2410linux2.6.8內(nèi)核源代碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
/* * Copyright (c) 2000-2003 Silicon Graphics, Inc.  All Rights Reserved. * * This program is free software; you can redistribute it and/or modify it * under the terms of version 2 of the GNU General Public License as * published by the Free Software Foundation. * * This program is distributed in the hope that it would be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. * * Further, this software is distributed without any warranty that it is * free of the rightful claim of any third person regarding infringement * or the like.  Any license provided herein, whether implied or * otherwise, applies only to this software file.  Patent licenses, if * any, provided herein do not apply to combinations of this program with * other software, or any other product whatsoever. * * You should have received a copy of the GNU General Public License along * with this program; if not, write the Free Software Foundation, Inc., 59 * Temple Place - Suite 330, Boston MA 02111-1307, USA. * * Contact information: Silicon Graphics, Inc., 1600 Amphitheatre Pkwy, * Mountain View, CA  94043, or: * * http://www.sgi.com * * For further information regarding this notice, see: * * http://oss.sgi.com/projects/GenInfo/SGIGPLNoticeExplan/ */#include "xfs.h"#include "xfs_fs.h"#include "xfs_inum.h"#include "xfs_log.h"#include "xfs_trans.h"#include "xfs_sb.h"#include "xfs_dir.h"#include "xfs_dir2.h"#include "xfs_alloc.h"#include "xfs_dmapi.h"#include "xfs_mount.h"#include "xfs_alloc_btree.h"#include "xfs_bmap_btree.h"#include "xfs_ialloc_btree.h"#include "xfs_btree.h"#include "xfs_ialloc.h"#include "xfs_attr_sf.h"#include "xfs_dir_sf.h"#include "xfs_dir2_sf.h"#include "xfs_dinode.h"#include "xfs_inode.h"#include "xfs_bmap.h"#include "xfs_bit.h"#include "xfs_rtalloc.h"#include "xfs_error.h"#include "xfs_itable.h"#include "xfs_rw.h"#include "xfs_acl.h"#include "xfs_cap.h"#include "xfs_mac.h"#include "xfs_attr.h"#include "xfs_buf_item.h"#include "xfs_utils.h"#include "xfs_dfrag.h"#include "xfs_fsops.h"#include <linux/dcache.h>#include <linux/mount.h>#include <linux/namei.h>#include <linux/pagemap.h>/* * ioctl commands that are used by Linux filesystems */#define XFS_IOC_GETXFLAGS	_IOR('f', 1, long)#define XFS_IOC_SETXFLAGS	_IOW('f', 2, long)#define XFS_IOC_GETVERSION	_IOR('v', 1, long)/* * xfs_find_handle maps from userspace xfs_fsop_handlereq structure to * a file or fs handle. * * XFS_IOC_PATH_TO_FSHANDLE *    returns fs handle for a mount point or path within that mount point * XFS_IOC_FD_TO_HANDLE *    returns full handle for a FD opened in user space * XFS_IOC_PATH_TO_HANDLE *    returns full handle for a path */STATIC intxfs_find_handle(	unsigned int		cmd,	unsigned long		arg){	int			hsize;	xfs_handle_t		handle;	xfs_fsop_handlereq_t	hreq;	struct inode		*inode;	struct vnode		*vp;	if (copy_from_user(&hreq, (xfs_fsop_handlereq_t *)arg, sizeof(hreq)))		return -XFS_ERROR(EFAULT);	memset((char *)&handle, 0, sizeof(handle));	switch (cmd) {	case XFS_IOC_PATH_TO_FSHANDLE:	case XFS_IOC_PATH_TO_HANDLE: {		struct nameidata	nd;		int			error;		error = user_path_walk_link(hreq.path, &nd);		if (error)			return error;		ASSERT(nd.dentry);		ASSERT(nd.dentry->d_inode);		inode = igrab(nd.dentry->d_inode);		path_release(&nd);		break;	}	case XFS_IOC_FD_TO_HANDLE: {		struct file	*file;		file = fget(hreq.fd);		if (!file)		    return -EBADF;		ASSERT(file->f_dentry);		ASSERT(file->f_dentry->d_inode);		inode = igrab(file->f_dentry->d_inode);		fput(file);		break;	}	default:		ASSERT(0);		return -XFS_ERROR(EINVAL);	}	if (inode->i_sb->s_magic != XFS_SB_MAGIC) {		/* we're not in XFS anymore, Toto */		iput(inode);		return -XFS_ERROR(EINVAL);	}	/* we need the vnode */	vp = LINVFS_GET_VP(inode);	if (vp->v_type != VREG && vp->v_type != VDIR && vp->v_type != VLNK) {		iput(inode);		return -XFS_ERROR(EBADF);	}	/* now we can grab the fsid */	memcpy(&handle.ha_fsid, vp->v_vfsp->vfs_altfsid, sizeof(xfs_fsid_t));	hsize = sizeof(xfs_fsid_t);	if (cmd != XFS_IOC_PATH_TO_FSHANDLE) {		xfs_inode_t	*ip;		bhv_desc_t	*bhv;		int		lock_mode;		/* need to get access to the xfs_inode to read the generation */		bhv = vn_bhv_lookup_unlocked(VN_BHV_HEAD(vp), &xfs_vnodeops);		ASSERT(bhv);		ip = XFS_BHVTOI(bhv);		ASSERT(ip);		lock_mode = xfs_ilock_map_shared(ip);		/* fill in fid section of handle from inode */		handle.ha_fid.xfs_fid_len = sizeof(xfs_fid_t) -					    sizeof(handle.ha_fid.xfs_fid_len);		handle.ha_fid.xfs_fid_pad = 0;		handle.ha_fid.xfs_fid_gen = ip->i_d.di_gen;		handle.ha_fid.xfs_fid_ino = ip->i_ino;		xfs_iunlock_map_shared(ip, lock_mode);		hsize = XFS_HSIZE(handle);	}	/* now copy our handle into the user buffer & write out the size */	if (copy_to_user((xfs_handle_t *)hreq.ohandle, &handle, hsize) ||	    copy_to_user(hreq.ohandlen, &hsize, sizeof(__s32))) {		iput(inode);		return -XFS_ERROR(EFAULT);	}	iput(inode);	return 0;}/* * Convert userspace handle data into vnode (and inode). * We [ab]use the fact that all the fsop_handlereq ioctl calls * have a data structure argument whose first component is always * a xfs_fsop_handlereq_t, so we can cast to and from this type. * This allows us to optimise the copy_from_user calls and gives * a handy, shared routine. * * If no error, caller must always VN_RELE the returned vp. */STATIC intxfs_vget_fsop_handlereq(	xfs_mount_t		*mp,	struct inode		*parinode,	/* parent inode pointer    */	int			cap,		/* capability level for op */	unsigned long		arg,		/* userspace data pointer  */	unsigned long		size,		/* size of expected struct */	/* output arguments */	xfs_fsop_handlereq_t	*hreq,	vnode_t			**vp,	struct inode		**inode){	void			*hanp;	size_t			hlen;	xfs_fid_t		*xfid;	xfs_handle_t		*handlep;	xfs_handle_t		handle;	xfs_inode_t		*ip;	struct inode		*inodep;	vnode_t			*vpp;	xfs_ino_t		ino;	__u32			igen;	int			error;	if (!capable(cap))		return XFS_ERROR(EPERM);	/*	 * Only allow handle opens under a directory.	 */	if (!S_ISDIR(parinode->i_mode))		return XFS_ERROR(ENOTDIR);	/*	 * Copy the handle down from the user and validate	 * that it looks to be in the correct format.	 */	if (copy_from_user(hreq, (struct xfs_fsop_handlereq *)arg, size))		return XFS_ERROR(EFAULT);	hanp = hreq->ihandle;	hlen = hreq->ihandlen;	handlep = &handle;	if (hlen < sizeof(handlep->ha_fsid) || hlen > sizeof(*handlep))		return XFS_ERROR(EINVAL);	if (copy_from_user(handlep, hanp, hlen))		return XFS_ERROR(EFAULT);	if (hlen < sizeof(*handlep))		memset(((char *)handlep) + hlen, 0, sizeof(*handlep) - hlen);	if (hlen > sizeof(handlep->ha_fsid)) {		if (handlep->ha_fid.xfs_fid_len !=				(hlen - sizeof(handlep->ha_fsid)					- sizeof(handlep->ha_fid.xfs_fid_len))		    || handlep->ha_fid.xfs_fid_pad)			return XFS_ERROR(EINVAL);	}	/*	 * Crack the handle, obtain the inode # & generation #	 */	xfid = (struct xfs_fid *)&handlep->ha_fid;	if (xfid->xfs_fid_len == sizeof(*xfid) - sizeof(xfid->xfs_fid_len)) {		ino  = xfid->xfs_fid_ino;		igen = xfid->xfs_fid_gen;	} else {		return XFS_ERROR(EINVAL);	}	/*	 * Get the XFS inode, building a vnode to go with it.	 */	error = xfs_iget(mp, NULL, ino, XFS_ILOCK_SHARED, &ip, 0);	if (error)		return error;	if (ip == NULL)		return XFS_ERROR(EIO);	if (ip->i_d.di_mode == 0 || ip->i_d.di_gen != igen) {		xfs_iput_new(ip, XFS_ILOCK_SHARED);		return XFS_ERROR(ENOENT);	}	vpp = XFS_ITOV(ip);	inodep = LINVFS_GET_IP(vpp);	xfs_iunlock(ip, XFS_ILOCK_SHARED);	*vp = vpp;	*inode = inodep;	return 0;}STATIC intxfs_open_by_handle(	xfs_mount_t		*mp,	unsigned long		arg,	struct file		*parfilp,	struct inode		*parinode){	int			error;	int			new_fd;	int			permflag;	struct file		*filp;	struct inode		*inode;	struct dentry		*dentry;	vnode_t			*vp;	xfs_fsop_handlereq_t	hreq;	error = xfs_vget_fsop_handlereq(mp, parinode, CAP_SYS_ADMIN, arg,					sizeof(xfs_fsop_handlereq_t),					&hreq, &vp, &inode);	if (error)		return -error;	/* Restrict xfs_open_by_handle to directories & regular files. */	if (!(S_ISREG(inode->i_mode) || S_ISDIR(inode->i_mode))) {		iput(inode);		return -XFS_ERROR(EINVAL);	}#if BITS_PER_LONG != 32	hreq.oflags |= O_LARGEFILE;#endif	/* Put open permission in namei format. */	permflag = hreq.oflags;	if ((permflag+1) & O_ACCMODE)		permflag++;	if (permflag & O_TRUNC)		permflag |= 2;	if ((!(permflag & O_APPEND) || (permflag & O_TRUNC)) &&	    (permflag & FMODE_WRITE) && IS_APPEND(inode)) {		iput(inode);		return -XFS_ERROR(EPERM);	}	if ((permflag & FMODE_WRITE) && IS_IMMUTABLE(inode)) {		iput(inode);		return -XFS_ERROR(EACCES);	}	/* Can't write directories. */	if ( S_ISDIR(inode->i_mode) && (permflag & FMODE_WRITE)) {		iput(inode);		return -XFS_ERROR(EISDIR);	}	if ((new_fd = get_unused_fd()) < 0) {		iput(inode);		return new_fd;	}	dentry = d_alloc_anon(inode);	if (dentry == NULL) {		iput(inode);		put_unused_fd(new_fd);		return -XFS_ERROR(ENOMEM);	}	/* Ensure umount returns EBUSY on umounts while this file is open. */	mntget(parfilp->f_vfsmnt);	/* Create file pointer. */	filp = dentry_open(dentry, parfilp->f_vfsmnt, hreq.oflags);	if (IS_ERR(filp)) {		put_unused_fd(new_fd);		return -XFS_ERROR(-PTR_ERR(filp));	}	if (inode->i_mode & S_IFREG)		filp->f_op = &linvfs_invis_file_operations;	fd_install(new_fd, filp);	return new_fd;}STATIC intxfs_readlink_by_handle(	xfs_mount_t		*mp,	unsigned long		arg,	struct file		*parfilp,	struct inode		*parinode){	int			error;	struct iovec		aiov;	struct uio		auio;	struct inode		*inode;	xfs_fsop_handlereq_t	hreq;	vnode_t			*vp;	__u32			olen;	error = xfs_vget_fsop_handlereq(mp, parinode, CAP_SYS_ADMIN, arg,					sizeof(xfs_fsop_handlereq_t),					&hreq, &vp, &inode);	if (error)		return -error;	/* Restrict this handle operation to symlinks only. */	if (vp->v_type != VLNK) {		VN_RELE(vp);		return -XFS_ERROR(EINVAL);	}	if (copy_from_user(&olen, hreq.ohandlen, sizeof(__u32))) {		VN_RELE(vp);		return -XFS_ERROR(EFAULT);	}	aiov.iov_len	= olen;	aiov.iov_base	= hreq.ohandle;	auio.uio_iov	= &aiov;	auio.uio_iovcnt	= 1;	auio.uio_offset	= 0;	auio.uio_segflg	= UIO_USERSPACE;	auio.uio_resid	= olen;	VOP_READLINK(vp, &auio, IO_INVIS, NULL, error);	VN_RELE(vp);	return (olen - auio.uio_resid);}STATIC intxfs_fssetdm_by_handle(	xfs_mount_t		*mp,	unsigned long		arg,	struct file		*parfilp,	struct inode		*parinode){	int			error;	struct fsdmidata	fsd;	xfs_fsop_setdm_handlereq_t dmhreq;	struct inode		*inode;	bhv_desc_t		*bdp;	vnode_t			*vp;	error = xfs_vget_fsop_handlereq(mp, parinode, CAP_MKNOD, arg,					sizeof(xfs_fsop_setdm_handlereq_t),					(xfs_fsop_handlereq_t *)&dmhreq,					&vp, &inode);	if (error)		return -error;	if (IS_IMMUTABLE(inode) || IS_APPEND(inode)) {		VN_RELE(vp);		return -XFS_ERROR(EPERM);	}	if (copy_from_user(&fsd, dmhreq.data, sizeof(fsd))) {		VN_RELE(vp);		return -XFS_ERROR(EFAULT);	}	bdp = bhv_base_unlocked(VN_BHV_HEAD(vp));	error = xfs_set_dmattrs(bdp, fsd.fsd_dmevmask, fsd.fsd_dmstate, NULL);	VN_RELE(vp);	if (error)		return -error;	return 0;}STATIC intxfs_attrlist_by_handle(	xfs_mount_t		*mp,	unsigned long		arg,	struct file		*parfilp,	struct inode		*parinode){	int			error;	attrlist_cursor_kern_t	*cursor;	xfs_fsop_attrlist_handlereq_t al_hreq;	struct inode		*inode;	vnode_t			*vp;	error = xfs_vget_fsop_handlereq(mp, parinode, CAP_SYS_ADMIN, arg,					sizeof(xfs_fsop_attrlist_handlereq_t),					(xfs_fsop_handlereq_t *)&al_hreq,					&vp, &inode);	if (error)		return -error;	cursor = (attrlist_cursor_kern_t *)&al_hreq.pos;	VOP_ATTR_LIST(vp, al_hreq.buffer, al_hreq.buflen, al_hreq.flags,			cursor, NULL, error);	VN_RELE(vp);	if (error)		return -error;	return 0;}STATIC intxfs_attrmulti_by_handle(	xfs_mount_t		*mp,	unsigned long		arg,	struct file		*parfilp,	struct inode		*parinode){	int			error;	xfs_attr_multiop_t	*ops;	xfs_fsop_attrmulti_handlereq_t am_hreq;	struct inode		*inode;	vnode_t			*vp;	int			i, size;	error = xfs_vget_fsop_handlereq(mp, parinode, CAP_SYS_ADMIN, arg,					sizeof(xfs_fsop_attrmulti_handlereq_t),					(xfs_fsop_handlereq_t *)&am_hreq,					&vp, &inode);	if (error)		return -error;	size = am_hreq.opcount * sizeof(attr_multiop_t);	ops = (xfs_attr_multiop_t *)kmalloc(size, GFP_KERNEL);	if (!ops) {		VN_RELE(vp);		return -XFS_ERROR(ENOMEM);	}	if (copy_from_user(ops, am_hreq.ops, size)) {		kfree(ops);		VN_RELE(vp);		return -XFS_ERROR(EFAULT);	}	for (i = 0; i < am_hreq.opcount; i++) {		switch(ops[i].am_opcode) {		case ATTR_OP_GET:			VOP_ATTR_GET(vp,ops[i].am_attrname, ops[i].am_attrvalue,					&ops[i].am_length, ops[i].am_flags,					NULL, ops[i].am_error);			break;		case ATTR_OP_SET:			if (IS_IMMUTABLE(inode) || IS_APPEND(inode)) {				ops[i].am_error = EPERM;				break;			}			VOP_ATTR_SET(vp,ops[i].am_attrname, ops[i].am_attrvalue,					ops[i].am_length, ops[i].am_flags,					NULL, ops[i].am_error);			break;		case ATTR_OP_REMOVE:			if (IS_IMMUTABLE(inode) || IS_APPEND(inode)) {				ops[i].am_error = EPERM;				break;			}			VOP_ATTR_REMOVE(vp, ops[i].am_attrname, ops[i].am_flags,					NULL, ops[i].am_error);			break;		default:			ops[i].am_error = EINVAL;		}	}	if (copy_to_user(am_hreq.ops, ops, size))		error = -XFS_ERROR(EFAULT);	kfree(ops);	VN_RELE(vp);	return error;}/* prototypes for a few of the stack-hungry cases that have * their own functions.  Functions are defined after their use * so gcc doesn't get fancy and inline them with -03 */STATIC intxfs_ioc_space(	bhv_desc_t		*bdp,	vnode_t			*vp,	struct file		*filp,	int			flags,	unsigned int		cmd,	unsigned long		arg);STATIC intxfs_ioc_bulkstat(	xfs_mount_t		*mp,	unsigned int		cmd,	unsigned long		arg);STATIC intxfs_ioc_fsgeometry_v1(	xfs_mount_t		*mp,	unsigned long		arg);STATIC intxfs_ioc_fsgeometry(	xfs_mount_t		*mp,	unsigned long		arg);STATIC intxfs_ioc_xattr(	vnode_t			*vp,	xfs_inode_t		*ip,	struct file		*filp,	unsigned int		cmd,	unsigned long		arg);STATIC intxfs_ioc_getbmap(	bhv_desc_t		*bdp,	struct file		*filp,	int			flags,	unsigned int		cmd,	unsigned long		arg);STATIC intxfs_ioc_getbmapx(	bhv_desc_t		*bdp,	unsigned long		arg);intxfs_ioctl(	bhv_desc_t		*bdp,	struct inode		*inode,	struct file		*filp,	int			ioflags,

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人91在线观看| 玖玖九九国产精品| 99综合影院在线| ●精品国产综合乱码久久久久| 国产成人在线看| 国产精品毛片久久久久久久 | 日韩黄色在线观看| 日韩情涩欧美日韩视频| 国产一区二区视频在线| 国产精品高潮呻吟| 欧美美女一区二区在线观看| 蜜臀99久久精品久久久久久软件| 久久嫩草精品久久久精品一| www.亚洲免费av| 亚洲成人黄色影院| 欧美大片在线观看| 9久草视频在线视频精品| 亚洲成人av电影在线| 精品国产a毛片| 91在线精品一区二区| 亚洲国产欧美在线人成| 久久伊人中文字幕| 色爱区综合激月婷婷| 喷白浆一区二区| 国产精品福利一区二区三区| 777xxx欧美| 成人激情免费电影网址| 亚洲18女电影在线观看| 久久久.com| 欧洲另类一二三四区| 国产精品1区二区.| 亚洲国产欧美日韩另类综合| 欧美r级在线观看| 欧美亚洲动漫精品| 国产乱码精品一区二区三区五月婷| 亚洲免费在线观看| 久久久久久久久久久黄色| 欧美亚州韩日在线看免费版国语版| 狠狠色丁香婷综合久久| 一区二区激情视频| 中文在线一区二区| 欧美成人艳星乳罩| 欧美制服丝袜第一页| 国产精品18久久久久久久久久久久 | 欧美男生操女生| 国产91丝袜在线观看| 日韩精品三区四区| 亚洲卡通动漫在线| 欧美国产综合色视频| 欧美大尺度电影在线| 日本高清不卡视频| 成人激情午夜影院| 国模大尺度一区二区三区| 亚洲成人一区二区| 一区二区三国产精华液| 中文字幕一区二区三区四区不卡| 久久这里只有精品视频网| 欧美疯狂做受xxxx富婆| 欧美系列日韩一区| 色噜噜久久综合| 99re6这里只有精品视频在线观看 99re8在线精品视频免费播放 | 国产欧美精品一区二区色综合朱莉| 制服丝袜亚洲色图| 欧美日韩在线直播| 91成人在线精品| 色综合久久久久综合| 99久久伊人网影院| 成人综合在线网站| 国产jizzjizz一区二区| 国产福利电影一区二区三区| 精品在线亚洲视频| 久久精品国产精品亚洲红杏| 婷婷一区二区三区| 日本va欧美va精品发布| 日韩不卡一区二区三区| 免费人成精品欧美精品| 日韩1区2区3区| 日韩精品免费专区| 免费观看在线综合| 免费亚洲电影在线| 国产一区二区三区美女| 国产一区二区三区电影在线观看 | 丁香桃色午夜亚洲一区二区三区| 国产精品一区二区在线观看网站| 国产精品一区在线观看你懂的| 国产成人aaa| 99视频一区二区| 日本电影欧美片| 欧美精三区欧美精三区| 日韩写真欧美这视频| 精品黑人一区二区三区久久| 久久女同精品一区二区| 国产欧美精品区一区二区三区| 国产精品国产三级国产三级人妇| 国产精品二三区| 亚洲不卡av一区二区三区| 日本视频一区二区三区| 国产精品综合av一区二区国产馆| 丁香婷婷深情五月亚洲| 日本精品一区二区三区四区的功能| 欧美三级日韩在线| 亚洲精品一区二区精华| 综合久久国产九一剧情麻豆| 亚洲 欧美综合在线网络| 美国毛片一区二区三区| 风间由美一区二区三区在线观看| 成av人片一区二区| 欧美三级电影网| 久久精品亚洲乱码伦伦中文| 最新热久久免费视频| 日韩精品欧美精品| 成人a免费在线看| 欧美欧美欧美欧美首页| 国产视频一区二区在线观看| 亚洲免费av在线| 精品一区二区av| 91国偷自产一区二区使用方法| 日韩三级精品电影久久久| 国产精品久久久久一区| 青青草一区二区三区| 97se亚洲国产综合自在线不卡| 欧美精品一级二级三级| 欧美国产一区视频在线观看| 婷婷国产在线综合| aa级大片欧美| 2017欧美狠狠色| 五月天一区二区| 成人av综合一区| 精品欧美一区二区久久| 亚洲一区二区三区激情| 成人免费视频国产在线观看| 51精品国自产在线| 亚洲免费观看高清完整版在线| 韩国成人精品a∨在线观看| 欧美制服丝袜第一页| 国产精品久久久久久久久免费丝袜| 香蕉影视欧美成人| 色综合天天综合| 中文字幕欧美日本乱码一线二线| 亚洲va国产va欧美va观看| av一区二区三区在线| 久久久99久久精品欧美| 日本色综合中文字幕| 在线观看国产91| 亚洲三级视频在线观看| 国产精一区二区三区| 精品国产91九色蝌蚪| 日韩1区2区3区| 欧美日韩激情一区| 亚洲精品va在线观看| av一区二区久久| 国产精品女上位| 成人网在线免费视频| 久久美女艺术照精彩视频福利播放 | 欧美一区二区三区免费在线看| 《视频一区视频二区| 国产成人激情av| 久久久精品国产免大香伊 | 国产在线精品一区二区夜色 | 国产婷婷色一区二区三区四区| 蜜臀av一区二区在线观看| 欧美日本精品一区二区三区| 亚洲综合在线五月| 色老汉一区二区三区| 亚洲精品国产品国语在线app| 99久久精品国产观看| 亚洲视频每日更新| 91丨九色丨黑人外教| 亚洲日本免费电影| 在线观看成人小视频| 亚洲午夜在线电影| 欧美久久久久久久久中文字幕| 亚洲成人av一区| 欧美一区三区二区| 韩国一区二区在线观看| 久久伊人蜜桃av一区二区| 国产成人av网站| 国产精品久久久久久久久快鸭| 91性感美女视频| 亚洲午夜激情网站| 日韩亚洲欧美综合| 国产精品一级在线| 自拍偷拍国产亚洲| 欧美午夜精品久久久久久超碰| 亚洲v中文字幕| 精品久久国产字幕高潮| 丁香啪啪综合成人亚洲小说| 亚洲人成网站色在线观看| 欧美亚洲高清一区| 久久狠狠亚洲综合| 久久精品人人做| 91麻豆国产福利在线观看| 亚洲va欧美va人人爽| 精品国产乱码久久久久久久| 成人高清在线视频| 亚洲午夜日本在线观看| 日韩精品一区二区三区在线 | 欧美三级中文字幕在线观看| 日韩国产精品久久久| 国产喷白浆一区二区三区|