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

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

?? xfs_ioctl.c

?? 優龍2410linux2.6.8內核源代碼
?? 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,

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本美女一区二区| 欧美高清在线精品一区| 国产ts人妖一区二区| 6080国产精品一区二区| 日韩激情一二三区| 欧美成人video| 国产69精品一区二区亚洲孕妇 | 在线观看成人免费视频| 亚洲在线视频免费观看| 8x8x8国产精品| 狠狠色狠狠色合久久伊人| 久久久久亚洲蜜桃| 99热精品国产| 视频在线观看一区二区三区| 久久久久久免费毛片精品| av中文字幕在线不卡| 亚洲狠狠爱一区二区三区| 精品国产91久久久久久久妲己| 93久久精品日日躁夜夜躁欧美| 亚洲chinese男男1069| 精品福利av导航| 91女厕偷拍女厕偷拍高清| 日韩精品乱码av一区二区| 国产欧美日韩三级| 欧洲在线/亚洲| 极品少妇一区二区| 亚洲一区二区三区四区不卡| 久久综合网色—综合色88| 91视频免费看| 久久电影国产免费久久电影 | 国产视频一区在线播放| 欧美日韩精品欧美日韩精品| 国产成人啪免费观看软件| 亚洲一区二区影院| 国产欧美日韩另类视频免费观看| 91香蕉视频mp4| 精品中文av资源站在线观看| 伊人色综合久久天天| 日韩一级高清毛片| 91黄色小视频| 高清不卡一区二区| 久久精品72免费观看| 亚洲综合在线五月| 中文字幕欧美区| 精品少妇一区二区三区在线播放| 日本韩国精品一区二区在线观看| 国产精品白丝jk白祙喷水网站| 亚洲高清视频的网址| 中文字幕在线一区| 久久人人爽人人爽| 欧美一级片免费看| 在线免费观看成人短视频| 成人精品gif动图一区| 精品一区二区久久久| 日韩高清不卡一区二区| 亚洲一区二区视频在线| 中文字幕欧美一区| 国产精品网站在线观看| 精品日韩99亚洲| 91精品国产综合久久久蜜臀图片| 色www精品视频在线观看| 成人在线视频一区| 国产成人亚洲综合a∨猫咪| 99久久综合色| 国产精品一品二品| 国产乱子伦一区二区三区国色天香| 首页亚洲欧美制服丝腿| 亚洲电影一级黄| 亚洲一区二区视频| 午夜精品一区二区三区免费视频 | 91免费看视频| 成人av网站大全| 成人av资源在线观看| 懂色av一区二区三区免费观看 | 成人av电影在线| 国产v综合v亚洲欧| 成人在线综合网| 北条麻妃一区二区三区| 99久久综合99久久综合网站| 成人精品鲁一区一区二区| 99久久国产综合精品色伊| www.亚洲色图| 91久久一区二区| 欧美亚洲动漫精品| 欧美精品第1页| 日韩欧美自拍偷拍| 久久你懂得1024| 日本一区二区久久| 亚洲精品中文在线| 午夜在线成人av| 蓝色福利精品导航| 风间由美一区二区三区在线观看 | 欧美日韩视频在线一区二区| 欧美日韩久久一区二区| 欧美一区二区二区| 久久久久久久综合色一本| 中文字幕在线一区二区三区| 一个色妞综合视频在线观看| 香蕉成人伊视频在线观看| 韩国三级电影一区二区| kk眼镜猥琐国模调教系列一区二区| 91视视频在线观看入口直接观看www| 欧美伊人精品成人久久综合97| 欧美精品在线一区二区三区| 精品三级在线观看| 亚洲色图19p| 亚洲午夜久久久| 极品少妇xxxx精品少妇偷拍 | 亚洲一区二区黄色| 美女尤物国产一区| 国产成人免费av在线| 欧洲国内综合视频| 久久久久久免费| 亚洲国产另类精品专区| 精品在线一区二区三区| 色婷婷av一区二区三区大白胸 | 欧美日韩精品一区视频| www成人在线观看| 亚洲精品国产一区二区精华液 | 六月丁香综合在线视频| 国产在线精品国自产拍免费| 日本丶国产丶欧美色综合| 日韩视频免费观看高清完整版在线观看| 2020国产精品久久精品美国| 一区二区三区影院| 国产黄色成人av| 欧美日韩久久一区| 日韩理论在线观看| 国产在线国偷精品产拍免费yy| 在线观看www91| 亚洲精品一区二区三区四区高清| 亚洲在线视频免费观看| 高清av一区二区| 精品国产一区二区三区久久影院| 亚洲综合色网站| 成人av资源网站| 久久久噜噜噜久久人人看 | 一区二区三区在线免费| 国产精品白丝av| 日韩欧美一级二级| 亚洲午夜激情网站| 97精品视频在线观看自产线路二| 欧美精品一区二区三区很污很色的| 亚洲一区二区四区蜜桃| 91麻豆精品在线观看| 国产精品麻豆网站| 国产一区亚洲一区| 日韩女同互慰一区二区| 亚洲va国产va欧美va观看| 9久草视频在线视频精品| 久久综合九色综合97婷婷女人| 日韩av一区二区三区| 欧美情侣在线播放| 亚洲国产综合色| 一本大道av一区二区在线播放| 欧美国产日韩精品免费观看| 精品伊人久久久久7777人| 日韩一区二区三区免费观看| 日韩精品福利网| 欧美久久久一区| 日韩高清欧美激情| 日韩一区二区电影| 美女任你摸久久| 亚洲精品一区二区在线观看| 久热成人在线视频| 日韩一区二区不卡| 精品亚洲国内自在自线福利| 欧美大胆一级视频| 久久国产精品第一页| 欧美精品一区二区精品网| 激情五月婷婷综合| 337p粉嫩大胆噜噜噜噜噜91av| 久久精品免费看| 国产天堂亚洲国产碰碰| 成人午夜视频在线| 亚洲免费资源在线播放| 欧美亚洲另类激情小说| 首页亚洲欧美制服丝腿| 日韩精品中文字幕一区| 国产一区二区三区四| 国产精品亲子伦对白| 91在线观看成人| 亚洲成av人在线观看| 69p69国产精品| 国产中文字幕一区| 国产精品日产欧美久久久久| 99re这里只有精品首页| 五月婷婷久久丁香| 欧美成人猛片aaaaaaa| 国产精品一级片在线观看| 国产精品对白交换视频 | 日韩欧美电影一二三| 国产盗摄女厕一区二区三区 | 午夜私人影院久久久久| 7777精品伊人久久久大香线蕉完整版| 伦理电影国产精品| |精品福利一区二区三区| www激情久久| 色素色在线综合| 久久成人免费电影|