[PATCH v6 1/7] vfs: Prepare for adding a new preadv/pwritev with user flags.

2014-11-10 Thread Milosz Tanski
Plumbing the flags argument through the vfs code so they can be passed down to
__generic_file_(read/write)_iter function that do the acctual work.

Signed-off-by: Milosz Tanski mil...@adfin.com
Reviewed-by: Christoph Hellwig h...@lst.de
Reviewed-by: Jeff Moyer jmo...@redhat.com
---
 drivers/target/target_core_file.c |  6 +++---
 fs/nfsd/vfs.c |  4 ++--
 fs/read_write.c   | 27 +++
 fs/splice.c   |  2 +-
 include/linux/aio.h   |  2 ++
 include/linux/fs.h|  4 ++--
 6 files changed, 25 insertions(+), 20 deletions(-)

diff --git a/drivers/target/target_core_file.c 
b/drivers/target/target_core_file.c
index 7d6cdda..58d9a6d 100644
--- a/drivers/target/target_core_file.c
+++ b/drivers/target/target_core_file.c
@@ -350,9 +350,9 @@ static int fd_do_rw(struct se_cmd *cmd, struct scatterlist 
*sgl,
set_fs(get_ds());
 
if (is_write)
-   ret = vfs_writev(fd, iov[0], sgl_nents, pos);
+   ret = vfs_writev(fd, iov[0], sgl_nents, pos, 0);
else
-   ret = vfs_readv(fd, iov[0], sgl_nents, pos);
+   ret = vfs_readv(fd, iov[0], sgl_nents, pos, 0);
 
set_fs(old_fs);
 
@@ -528,7 +528,7 @@ fd_execute_write_same(struct se_cmd *cmd)
 
old_fs = get_fs();
set_fs(get_ds());
-   rc = vfs_writev(f, iov[0], iov_num, pos);
+   rc = vfs_writev(f, iov[0], iov_num, pos, 0);
set_fs(old_fs);
 
vfree(iov);
diff --git a/fs/nfsd/vfs.c b/fs/nfsd/vfs.c
index 989129e..ef01c78 100644
--- a/fs/nfsd/vfs.c
+++ b/fs/nfsd/vfs.c
@@ -872,7 +872,7 @@ __be32 nfsd_readv(struct file *file, loff_t offset, struct 
kvec *vec, int vlen,
 
oldfs = get_fs();
set_fs(KERNEL_DS);
-   host_err = vfs_readv(file, (struct iovec __user *)vec, vlen, offset);
+   host_err = vfs_readv(file, (struct iovec __user *)vec, vlen, offset, 
0);
set_fs(oldfs);
return nfsd_finish_read(file, count, host_err);
 }
@@ -960,7 +960,7 @@ nfsd_vfs_write(struct svc_rqst *rqstp, struct svc_fh *fhp, 
struct file *file,
 
/* Write the data. */
oldfs = get_fs(); set_fs(KERNEL_DS);
-   host_err = vfs_writev(file, (struct iovec __user *)vec, vlen, pos);
+   host_err = vfs_writev(file, (struct iovec __user *)vec, vlen, pos, 0);
set_fs(oldfs);
if (host_err  0)
goto out_nfserr;
diff --git a/fs/read_write.c b/fs/read_write.c
index 7d9318c..94b2d34 100644
--- a/fs/read_write.c
+++ b/fs/read_write.c
@@ -653,7 +653,8 @@ unsigned long iov_shorten(struct iovec *iov, unsigned long 
nr_segs, size_t to)
 EXPORT_SYMBOL(iov_shorten);
 
 static ssize_t do_iter_readv_writev(struct file *filp, int rw, const struct 
iovec *iov,
-   unsigned long nr_segs, size_t len, loff_t *ppos, iter_fn_t fn)
+   unsigned long nr_segs, size_t len, loff_t *ppos, iter_fn_t fn,
+   int flags)
 {
struct kiocb kiocb;
struct iov_iter iter;
@@ -662,6 +663,7 @@ static ssize_t do_iter_readv_writev(struct file *filp, int 
rw, const struct iove
init_sync_kiocb(kiocb, filp);
kiocb.ki_pos = *ppos;
kiocb.ki_nbytes = len;
+   kiocb.ki_rwflags = flags;
 
iov_iter_init(iter, rw, iov, nr_segs, len);
ret = fn(kiocb, iter);
@@ -800,7 +802,8 @@ out:
 
 static ssize_t do_readv_writev(int type, struct file *file,
   const struct iovec __user * uvector,
-  unsigned long nr_segs, loff_t *pos)
+  unsigned long nr_segs, loff_t *pos,
+  int flags)
 {
size_t tot_len;
struct iovec iovstack[UIO_FASTIOV];
@@ -834,7 +837,7 @@ static ssize_t do_readv_writev(int type, struct file *file,
 
if (iter_fn)
ret = do_iter_readv_writev(file, type, iov, nr_segs, tot_len,
-   pos, iter_fn);
+   pos, iter_fn, flags);
else if (fnv)
ret = do_sync_readv_writev(file, iov, nr_segs, tot_len,
pos, fnv);
@@ -857,27 +860,27 @@ out:
 }
 
 ssize_t vfs_readv(struct file *file, const struct iovec __user *vec,
- unsigned long vlen, loff_t *pos)
+ unsigned long vlen, loff_t *pos, int flags)
 {
if (!(file-f_mode  FMODE_READ))
return -EBADF;
if (!(file-f_mode  FMODE_CAN_READ))
return -EINVAL;
 
-   return do_readv_writev(READ, file, vec, vlen, pos);
+   return do_readv_writev(READ, file, vec, vlen, pos, flags);
 }
 
 EXPORT_SYMBOL(vfs_readv);
 
 ssize_t vfs_writev(struct file *file, const struct iovec __user *vec,
-  unsigned long vlen, loff_t *pos)
+  unsigned long vlen, loff_t *pos, int flags)
 {
if (!(file-f_mode  FMODE_WRITE))
return

[PATCH v5 1/7] vfs: Prepare for adding a new preadv/pwritev with user flags.

2014-11-05 Thread Milosz Tanski
Plumbing the flags argument through the vfs code so they can be passed down to
__generic_file_(read/write)_iter function that do the acctual work.

Signed-off-by: Milosz Tanski mil...@adfin.com
Reviewed-by: Christoph Hellwig h...@lst.de
Reviewed-by: Jeff Moyer jmo...@redhat.com
---
 drivers/target/target_core_file.c |  6 +++---
 fs/nfsd/vfs.c |  4 ++--
 fs/read_write.c   | 27 +++
 fs/splice.c   |  2 +-
 include/linux/aio.h   |  2 ++
 include/linux/fs.h|  4 ++--
 6 files changed, 25 insertions(+), 20 deletions(-)

diff --git a/drivers/target/target_core_file.c 
b/drivers/target/target_core_file.c
index 7d6cdda..58d9a6d 100644
--- a/drivers/target/target_core_file.c
+++ b/drivers/target/target_core_file.c
@@ -350,9 +350,9 @@ static int fd_do_rw(struct se_cmd *cmd, struct scatterlist 
*sgl,
set_fs(get_ds());
 
if (is_write)
-   ret = vfs_writev(fd, iov[0], sgl_nents, pos);
+   ret = vfs_writev(fd, iov[0], sgl_nents, pos, 0);
else
-   ret = vfs_readv(fd, iov[0], sgl_nents, pos);
+   ret = vfs_readv(fd, iov[0], sgl_nents, pos, 0);
 
set_fs(old_fs);
 
@@ -528,7 +528,7 @@ fd_execute_write_same(struct se_cmd *cmd)
 
old_fs = get_fs();
set_fs(get_ds());
-   rc = vfs_writev(f, iov[0], iov_num, pos);
+   rc = vfs_writev(f, iov[0], iov_num, pos, 0);
set_fs(old_fs);
 
vfree(iov);
diff --git a/fs/nfsd/vfs.c b/fs/nfsd/vfs.c
index 989129e..ef01c78 100644
--- a/fs/nfsd/vfs.c
+++ b/fs/nfsd/vfs.c
@@ -872,7 +872,7 @@ __be32 nfsd_readv(struct file *file, loff_t offset, struct 
kvec *vec, int vlen,
 
oldfs = get_fs();
set_fs(KERNEL_DS);
-   host_err = vfs_readv(file, (struct iovec __user *)vec, vlen, offset);
+   host_err = vfs_readv(file, (struct iovec __user *)vec, vlen, offset, 
0);
set_fs(oldfs);
return nfsd_finish_read(file, count, host_err);
 }
@@ -960,7 +960,7 @@ nfsd_vfs_write(struct svc_rqst *rqstp, struct svc_fh *fhp, 
struct file *file,
 
/* Write the data. */
oldfs = get_fs(); set_fs(KERNEL_DS);
-   host_err = vfs_writev(file, (struct iovec __user *)vec, vlen, pos);
+   host_err = vfs_writev(file, (struct iovec __user *)vec, vlen, pos, 0);
set_fs(oldfs);
if (host_err  0)
goto out_nfserr;
diff --git a/fs/read_write.c b/fs/read_write.c
index 7d9318c..94b2d34 100644
--- a/fs/read_write.c
+++ b/fs/read_write.c
@@ -653,7 +653,8 @@ unsigned long iov_shorten(struct iovec *iov, unsigned long 
nr_segs, size_t to)
 EXPORT_SYMBOL(iov_shorten);
 
 static ssize_t do_iter_readv_writev(struct file *filp, int rw, const struct 
iovec *iov,
-   unsigned long nr_segs, size_t len, loff_t *ppos, iter_fn_t fn)
+   unsigned long nr_segs, size_t len, loff_t *ppos, iter_fn_t fn,
+   int flags)
 {
struct kiocb kiocb;
struct iov_iter iter;
@@ -662,6 +663,7 @@ static ssize_t do_iter_readv_writev(struct file *filp, int 
rw, const struct iove
init_sync_kiocb(kiocb, filp);
kiocb.ki_pos = *ppos;
kiocb.ki_nbytes = len;
+   kiocb.ki_rwflags = flags;
 
iov_iter_init(iter, rw, iov, nr_segs, len);
ret = fn(kiocb, iter);
@@ -800,7 +802,8 @@ out:
 
 static ssize_t do_readv_writev(int type, struct file *file,
   const struct iovec __user * uvector,
-  unsigned long nr_segs, loff_t *pos)
+  unsigned long nr_segs, loff_t *pos,
+  int flags)
 {
size_t tot_len;
struct iovec iovstack[UIO_FASTIOV];
@@ -834,7 +837,7 @@ static ssize_t do_readv_writev(int type, struct file *file,
 
if (iter_fn)
ret = do_iter_readv_writev(file, type, iov, nr_segs, tot_len,
-   pos, iter_fn);
+   pos, iter_fn, flags);
else if (fnv)
ret = do_sync_readv_writev(file, iov, nr_segs, tot_len,
pos, fnv);
@@ -857,27 +860,27 @@ out:
 }
 
 ssize_t vfs_readv(struct file *file, const struct iovec __user *vec,
- unsigned long vlen, loff_t *pos)
+ unsigned long vlen, loff_t *pos, int flags)
 {
if (!(file-f_mode  FMODE_READ))
return -EBADF;
if (!(file-f_mode  FMODE_CAN_READ))
return -EINVAL;
 
-   return do_readv_writev(READ, file, vec, vlen, pos);
+   return do_readv_writev(READ, file, vec, vlen, pos, flags);
 }
 
 EXPORT_SYMBOL(vfs_readv);
 
 ssize_t vfs_writev(struct file *file, const struct iovec __user *vec,
-  unsigned long vlen, loff_t *pos)
+  unsigned long vlen, loff_t *pos, int flags)
 {
if (!(file-f_mode  FMODE_WRITE))
return