diff options
-rw-r--r-- | drivers/char/raw.c | 2 | ||||
-rw-r--r-- | drivers/net/tun.c | 37 | ||||
-rw-r--r-- | fs/bad_inode.c | 2 | ||||
-rw-r--r-- | fs/block_dev.c | 2 | ||||
-rw-r--r-- | fs/cifs/cifsfs.c | 16 | ||||
-rw-r--r-- | fs/compat.c | 44 | ||||
-rw-r--r-- | fs/ext2/file.c | 2 | ||||
-rw-r--r-- | fs/ext3/file.c | 2 | ||||
-rw-r--r-- | fs/fat/file.c | 2 | ||||
-rw-r--r-- | fs/fuse/dev.c | 37 | ||||
-rw-r--r-- | fs/hostfs/hostfs_kern.c | 2 | ||||
-rw-r--r-- | fs/jfs/file.c | 2 | ||||
-rw-r--r-- | fs/ntfs/file.c | 2 | ||||
-rw-r--r-- | fs/pipe.c | 59 | ||||
-rw-r--r-- | fs/read_write.c | 101 | ||||
-rw-r--r-- | fs/read_write.h | 14 | ||||
-rw-r--r-- | fs/xfs/linux-2.6/xfs_file.c | 94 | ||||
-rw-r--r-- | include/linux/fs.h | 6 | ||||
-rw-r--r-- | mm/filemap.c | 36 | ||||
-rw-r--r-- | net/socket.c | 40 | ||||
-rw-r--r-- | sound/core/pcm_native.c | 40 |
21 files changed, 154 insertions, 388 deletions
diff --git a/drivers/char/raw.c b/drivers/char/raw.c index 173fb08555d5..490db531e2d8 100644 --- a/drivers/char/raw.c +++ b/drivers/char/raw.c | |||
@@ -257,8 +257,6 @@ static const struct file_operations raw_fops = { | |||
257 | .open = raw_open, | 257 | .open = raw_open, |
258 | .release= raw_release, | 258 | .release= raw_release, |
259 | .ioctl = raw_ioctl, | 259 | .ioctl = raw_ioctl, |
260 | .readv = generic_file_readv, | ||
261 | .writev = generic_file_writev, | ||
262 | .owner = THIS_MODULE, | 260 | .owner = THIS_MODULE, |
263 | }; | 261 | }; |
264 | 262 | ||
diff --git a/drivers/net/tun.c b/drivers/net/tun.c index de8da6dee1b0..bc0face01d25 100644 --- a/drivers/net/tun.c +++ b/drivers/net/tun.c | |||
@@ -288,11 +288,10 @@ static inline size_t iov_total(const struct iovec *iv, unsigned long count) | |||
288 | return len; | 288 | return len; |
289 | } | 289 | } |
290 | 290 | ||
291 | /* Writev */ | 291 | static ssize_t tun_chr_aio_write(struct kiocb *iocb, const struct iovec *iv, |
292 | static ssize_t tun_chr_writev(struct file * file, const struct iovec *iv, | 292 | unsigned long count, loff_t pos) |
293 | unsigned long count, loff_t *pos) | ||
294 | { | 293 | { |
295 | struct tun_struct *tun = file->private_data; | 294 | struct tun_struct *tun = iocb->ki_filp->private_data; |
296 | 295 | ||
297 | if (!tun) | 296 | if (!tun) |
298 | return -EBADFD; | 297 | return -EBADFD; |
@@ -302,14 +301,6 @@ static ssize_t tun_chr_writev(struct file * file, const struct iovec *iv, | |||
302 | return tun_get_user(tun, (struct iovec *) iv, iov_total(iv, count)); | 301 | return tun_get_user(tun, (struct iovec *) iv, iov_total(iv, count)); |
303 | } | 302 | } |
304 | 303 | ||
305 | /* Write */ | ||
306 | static ssize_t tun_chr_write(struct file * file, const char __user * buf, | ||
307 | size_t count, loff_t *pos) | ||
308 | { | ||
309 | struct iovec iv = { (void __user *) buf, count }; | ||
310 | return tun_chr_writev(file, &iv, 1, pos); | ||
311 | } | ||
312 | |||
313 | /* Put packet to the user space buffer */ | 304 | /* Put packet to the user space buffer */ |
314 | static __inline__ ssize_t tun_put_user(struct tun_struct *tun, | 305 | static __inline__ ssize_t tun_put_user(struct tun_struct *tun, |
315 | struct sk_buff *skb, | 306 | struct sk_buff *skb, |
@@ -343,10 +334,10 @@ static __inline__ ssize_t tun_put_user(struct tun_struct *tun, | |||
343 | return total; | 334 | return total; |
344 | } | 335 | } |
345 | 336 | ||
346 | /* Readv */ | 337 | static ssize_t tun_chr_aio_read(struct kiocb *iocb, const struct iovec *iv, |
347 | static ssize_t tun_chr_readv(struct file *file, const struct iovec *iv, | 338 | unsigned long count, loff_t pos) |
348 | unsigned long count, loff_t *pos) | ||
349 | { | 339 | { |
340 | struct file *file = iocb->ki_filp; | ||
350 | struct tun_struct *tun = file->private_data; | 341 | struct tun_struct *tun = file->private_data; |
351 | DECLARE_WAITQUEUE(wait, current); | 342 | DECLARE_WAITQUEUE(wait, current); |
352 | struct sk_buff *skb; | 343 | struct sk_buff *skb; |
@@ -426,14 +417,6 @@ static ssize_t tun_chr_readv(struct file *file, const struct iovec *iv, | |||
426 | return ret; | 417 | return ret; |
427 | } | 418 | } |
428 | 419 | ||
429 | /* Read */ | ||
430 | static ssize_t tun_chr_read(struct file * file, char __user * buf, | ||
431 | size_t count, loff_t *pos) | ||
432 | { | ||
433 | struct iovec iv = { buf, count }; | ||
434 | return tun_chr_readv(file, &iv, 1, pos); | ||
435 | } | ||
436 | |||
437 | static void tun_setup(struct net_device *dev) | 420 | static void tun_setup(struct net_device *dev) |
438 | { | 421 | { |
439 | struct tun_struct *tun = netdev_priv(dev); | 422 | struct tun_struct *tun = netdev_priv(dev); |
@@ -764,10 +747,10 @@ static int tun_chr_close(struct inode *inode, struct file *file) | |||
764 | static struct file_operations tun_fops = { | 747 | static struct file_operations tun_fops = { |
765 | .owner = THIS_MODULE, | 748 | .owner = THIS_MODULE, |
766 | .llseek = no_llseek, | 749 | .llseek = no_llseek, |
767 | .read = tun_chr_read, | 750 | .read = do_sync_read, |
768 | .readv = tun_chr_readv, | 751 | .aio_read = tun_chr_aio_read, |
769 | .write = tun_chr_write, | 752 | .write = do_sync_write, |
770 | .writev = tun_chr_writev, | 753 | .aio_write = tun_chr_aio_write, |
771 | .poll = tun_chr_poll, | 754 | .poll = tun_chr_poll, |
772 | .ioctl = tun_chr_ioctl, | 755 | .ioctl = tun_chr_ioctl, |
773 | .open = tun_chr_open, | 756 | .open = tun_chr_open, |
diff --git a/fs/bad_inode.c b/fs/bad_inode.c index 80599ae33966..34e6d7b220c3 100644 --- a/fs/bad_inode.c +++ b/fs/bad_inode.c | |||
@@ -40,8 +40,6 @@ static const struct file_operations bad_file_ops = | |||
40 | .aio_fsync = EIO_ERROR, | 40 | .aio_fsync = EIO_ERROR, |
41 | .fasync = EIO_ERROR, | 41 | .fasync = EIO_ERROR, |
42 | .lock = EIO_ERROR, | 42 | .lock = EIO_ERROR, |
43 | .readv = EIO_ERROR, | ||
44 | .writev = EIO_ERROR, | ||
45 | .sendfile = EIO_ERROR, | 43 | .sendfile = EIO_ERROR, |
46 | .sendpage = EIO_ERROR, | 44 | .sendpage = EIO_ERROR, |
47 | .get_unmapped_area = EIO_ERROR, | 45 | .get_unmapped_area = EIO_ERROR, |
diff --git a/fs/block_dev.c b/fs/block_dev.c index 8c819117310b..0f143094ef1d 100644 --- a/fs/block_dev.c +++ b/fs/block_dev.c | |||
@@ -1191,8 +1191,6 @@ const struct file_operations def_blk_fops = { | |||
1191 | #ifdef CONFIG_COMPAT | 1191 | #ifdef CONFIG_COMPAT |
1192 | .compat_ioctl = compat_blkdev_ioctl, | 1192 | .compat_ioctl = compat_blkdev_ioctl, |
1193 | #endif | 1193 | #endif |
1194 | .readv = generic_file_readv, | ||
1195 | .writev = generic_file_write_nolock, | ||
1196 | .sendfile = generic_file_sendfile, | 1194 | .sendfile = generic_file_sendfile, |
1197 | .splice_read = generic_file_splice_read, | 1195 | .splice_read = generic_file_splice_read, |
1198 | .splice_write = generic_file_splice_write, | 1196 | .splice_write = generic_file_splice_write, |
diff --git a/fs/cifs/cifsfs.c b/fs/cifs/cifsfs.c index 5abb42a7c53e..c00c654f2e11 100644 --- a/fs/cifs/cifsfs.c +++ b/fs/cifs/cifsfs.c | |||
@@ -480,18 +480,6 @@ cifs_get_sb(struct file_system_type *fs_type, | |||
480 | return simple_set_mnt(mnt, sb); | 480 | return simple_set_mnt(mnt, sb); |
481 | } | 481 | } |
482 | 482 | ||
483 | static ssize_t cifs_file_writev(struct file *file, const struct iovec *iov, | ||
484 | unsigned long nr_segs, loff_t *ppos) | ||
485 | { | ||
486 | struct inode *inode = file->f_dentry->d_inode; | ||
487 | ssize_t written; | ||
488 | |||
489 | written = generic_file_writev(file, iov, nr_segs, ppos); | ||
490 | if (!CIFS_I(inode)->clientCanCacheAll) | ||
491 | filemap_fdatawrite(inode->i_mapping); | ||
492 | return written; | ||
493 | } | ||
494 | |||
495 | static ssize_t cifs_file_aio_write(struct kiocb *iocb, const struct iovec *iov, | 483 | static ssize_t cifs_file_aio_write(struct kiocb *iocb, const struct iovec *iov, |
496 | unsigned long nr_segs, loff_t pos) | 484 | unsigned long nr_segs, loff_t pos) |
497 | { | 485 | { |
@@ -577,8 +565,6 @@ struct inode_operations cifs_symlink_inode_ops = { | |||
577 | const struct file_operations cifs_file_ops = { | 565 | const struct file_operations cifs_file_ops = { |
578 | .read = do_sync_read, | 566 | .read = do_sync_read, |
579 | .write = do_sync_write, | 567 | .write = do_sync_write, |
580 | .readv = generic_file_readv, | ||
581 | .writev = cifs_file_writev, | ||
582 | .aio_read = generic_file_aio_read, | 568 | .aio_read = generic_file_aio_read, |
583 | .aio_write = cifs_file_aio_write, | 569 | .aio_write = cifs_file_aio_write, |
584 | .open = cifs_open, | 570 | .open = cifs_open, |
@@ -620,8 +606,6 @@ const struct file_operations cifs_file_direct_ops = { | |||
620 | const struct file_operations cifs_file_nobrl_ops = { | 606 | const struct file_operations cifs_file_nobrl_ops = { |
621 | .read = do_sync_read, | 607 | .read = do_sync_read, |
622 | .write = do_sync_write, | 608 | .write = do_sync_write, |
623 | .readv = generic_file_readv, | ||
624 | .writev = cifs_file_writev, | ||
625 | .aio_read = generic_file_aio_read, | 609 | .aio_read = generic_file_aio_read, |
626 | .aio_write = cifs_file_aio_write, | 610 | .aio_write = cifs_file_aio_write, |
627 | .open = cifs_open, | 611 | .open = cifs_open, |
diff --git a/fs/compat.c b/fs/compat.c index 122b4e3992b5..6b90bf35f61d 100644 --- a/fs/compat.c +++ b/fs/compat.c | |||
@@ -70,6 +70,8 @@ int compat_printk(const char *fmt, ...) | |||
70 | return ret; | 70 | return ret; |
71 | } | 71 | } |
72 | 72 | ||
73 | #include "read_write.h" | ||
74 | |||
73 | /* | 75 | /* |
74 | * Not all architectures have sys_utime, so implement this in terms | 76 | * Not all architectures have sys_utime, so implement this in terms |
75 | * of sys_utimes. | 77 | * of sys_utimes. |
@@ -1149,9 +1151,6 @@ static ssize_t compat_do_readv_writev(int type, struct file *file, | |||
1149 | const struct compat_iovec __user *uvector, | 1151 | const struct compat_iovec __user *uvector, |
1150 | unsigned long nr_segs, loff_t *pos) | 1152 | unsigned long nr_segs, loff_t *pos) |
1151 | { | 1153 | { |
1152 | typedef ssize_t (*io_fn_t)(struct file *, char __user *, size_t, loff_t *); | ||
1153 | typedef ssize_t (*iov_fn_t)(struct file *, const struct iovec *, unsigned long, loff_t *); | ||
1154 | |||
1155 | compat_ssize_t tot_len; | 1154 | compat_ssize_t tot_len; |
1156 | struct iovec iovstack[UIO_FASTIOV]; | 1155 | struct iovec iovstack[UIO_FASTIOV]; |
1157 | struct iovec *iov=iovstack, *vector; | 1156 | struct iovec *iov=iovstack, *vector; |
@@ -1234,39 +1233,18 @@ static ssize_t compat_do_readv_writev(int type, struct file *file, | |||
1234 | fnv = NULL; | 1233 | fnv = NULL; |
1235 | if (type == READ) { | 1234 | if (type == READ) { |
1236 | fn = file->f_op->read; | 1235 | fn = file->f_op->read; |
1237 | fnv = file->f_op->readv; | 1236 | fnv = file->f_op->aio_read; |
1238 | } else { | 1237 | } else { |
1239 | fn = (io_fn_t)file->f_op->write; | 1238 | fn = (io_fn_t)file->f_op->write; |
1240 | fnv = file->f_op->writev; | 1239 | fnv = file->f_op->aio_write; |
1241 | } | ||
1242 | if (fnv) { | ||
1243 | ret = fnv(file, iov, nr_segs, pos); | ||
1244 | goto out; | ||
1245 | } | 1240 | } |
1246 | 1241 | ||
1247 | /* Do it by hand, with file-ops */ | 1242 | if (fnv) |
1248 | ret = 0; | 1243 | ret = do_sync_readv_writev(file, iov, nr_segs, tot_len, |
1249 | vector = iov; | 1244 | pos, fnv); |
1250 | while (nr_segs > 0) { | 1245 | else |
1251 | void __user * base; | 1246 | ret = do_loop_readv_writev(file, iov, nr_segs, pos, fn); |
1252 | size_t len; | ||
1253 | ssize_t nr; | ||
1254 | |||
1255 | base = vector->iov_base; | ||
1256 | len = vector->iov_len; | ||
1257 | vector++; | ||
1258 | nr_segs--; | ||
1259 | |||
1260 | nr = fn(file, base, len, pos); | ||
1261 | 1247 | ||
1262 | if (nr < 0) { | ||
1263 | if (!ret) ret = nr; | ||
1264 | break; | ||
1265 | } | ||
1266 | ret += nr; | ||
1267 | if (nr != len) | ||
1268 | break; | ||
1269 | } | ||
1270 | out: | 1248 | out: |
1271 | if (iov != iovstack) | 1249 | if (iov != iovstack) |
1272 | kfree(iov); | 1250 | kfree(iov); |
@@ -1294,7 +1272,7 @@ compat_sys_readv(unsigned long fd, const struct compat_iovec __user *vec, unsign | |||
1294 | goto out; | 1272 | goto out; |
1295 | 1273 | ||
1296 | ret = -EINVAL; | 1274 | ret = -EINVAL; |
1297 | if (!file->f_op || (!file->f_op->readv && !file->f_op->read)) | 1275 | if (!file->f_op || (!file->f_op->aio_read && !file->f_op->read)) |
1298 | goto out; | 1276 | goto out; |
1299 | 1277 | ||
1300 | ret = compat_do_readv_writev(READ, file, vec, vlen, &file->f_pos); | 1278 | ret = compat_do_readv_writev(READ, file, vec, vlen, &file->f_pos); |
@@ -1317,7 +1295,7 @@ compat_sys_writev(unsigned long fd, const struct compat_iovec __user *vec, unsig | |||
1317 | goto out; | 1295 | goto out; |
1318 | 1296 | ||
1319 | ret = -EINVAL; | 1297 | ret = -EINVAL; |
1320 | if (!file->f_op || (!file->f_op->writev && !file->f_op->write)) | 1298 | if (!file->f_op || (!file->f_op->aio_write && !file->f_op->write)) |
1321 | goto out; | 1299 | goto out; |
1322 | 1300 | ||
1323 | ret = compat_do_readv_writev(WRITE, file, vec, vlen, &file->f_pos); | 1301 | ret = compat_do_readv_writev(WRITE, file, vec, vlen, &file->f_pos); |
diff --git a/fs/ext2/file.c b/fs/ext2/file.c index e8bbed9dd268..e893e2be9ed4 100644 --- a/fs/ext2/file.c +++ b/fs/ext2/file.c | |||
@@ -53,8 +53,6 @@ const struct file_operations ext2_file_operations = { | |||
53 | .open = generic_file_open, | 53 | .open = generic_file_open, |
54 | .release = ext2_release_file, | 54 | .release = ext2_release_file, |
55 | .fsync = ext2_sync_file, | 55 | .fsync = ext2_sync_file, |
56 | .readv = generic_file_readv, | ||
57 | .writev = generic_file_writev, | ||
58 | .sendfile = generic_file_sendfile, | 56 | .sendfile = generic_file_sendfile, |
59 | .splice_read = generic_file_splice_read, | 57 | .splice_read = generic_file_splice_read, |
60 | .splice_write = generic_file_splice_write, | 58 | .splice_write = generic_file_splice_write, |
diff --git a/fs/ext3/file.c b/fs/ext3/file.c index 5c762457bc89..e96c388047e0 100644 --- a/fs/ext3/file.c +++ b/fs/ext3/file.c | |||
@@ -112,8 +112,6 @@ const struct file_operations ext3_file_operations = { | |||
112 | .write = do_sync_write, | 112 | .write = do_sync_write, |
113 | .aio_read = generic_file_aio_read, | 113 | .aio_read = generic_file_aio_read, |
114 | .aio_write = ext3_file_write, | 114 | .aio_write = ext3_file_write, |
115 | .readv = generic_file_readv, | ||
116 | .writev = generic_file_writev, | ||
117 | .ioctl = ext3_ioctl, | 115 | .ioctl = ext3_ioctl, |
118 | #ifdef CONFIG_COMPAT | 116 | #ifdef CONFIG_COMPAT |
119 | .compat_ioctl = ext3_compat_ioctl, | 117 | .compat_ioctl = ext3_compat_ioctl, |
diff --git a/fs/fat/file.c b/fs/fat/file.c index d50fc47169c1..f4b8f8b3fbdd 100644 --- a/fs/fat/file.c +++ b/fs/fat/file.c | |||
@@ -127,8 +127,6 @@ const struct file_operations fat_file_operations = { | |||
127 | .llseek = generic_file_llseek, | 127 | .llseek = generic_file_llseek, |
128 | .read = do_sync_read, | 128 | .read = do_sync_read, |
129 | .write = do_sync_write, | 129 | .write = do_sync_write, |
130 | .readv = generic_file_readv, | ||
131 | .writev = generic_file_writev, | ||
132 | .aio_read = generic_file_aio_read, | 130 | .aio_read = generic_file_aio_read, |
133 | .aio_write = generic_file_aio_write, | 131 | .aio_write = generic_file_aio_write, |
134 | .mmap = generic_file_mmap, | 132 | .mmap = generic_file_mmap, |
diff --git a/fs/fuse/dev.c b/fs/fuse/dev.c index 4fc557c40cc0..66571eafbb1e 100644 --- a/fs/fuse/dev.c +++ b/fs/fuse/dev.c | |||
@@ -680,14 +680,15 @@ static int fuse_read_interrupt(struct fuse_conn *fc, struct fuse_req *req, | |||
680 | * request_end(). Otherwise add it to the processing list, and set | 680 | * request_end(). Otherwise add it to the processing list, and set |
681 | * the 'sent' flag. | 681 | * the 'sent' flag. |
682 | */ | 682 | */ |
683 | static ssize_t fuse_dev_readv(struct file *file, const struct iovec *iov, | 683 | static ssize_t fuse_dev_read(struct kiocb *iocb, const struct iovec *iov, |
684 | unsigned long nr_segs, loff_t *off) | 684 | unsigned long nr_segs, loff_t pos) |
685 | { | 685 | { |
686 | int err; | 686 | int err; |
687 | struct fuse_req *req; | 687 | struct fuse_req *req; |
688 | struct fuse_in *in; | 688 | struct fuse_in *in; |
689 | struct fuse_copy_state cs; | 689 | struct fuse_copy_state cs; |
690 | unsigned reqsize; | 690 | unsigned reqsize; |
691 | struct file *file = iocb->ki_filp; | ||
691 | struct fuse_conn *fc = fuse_get_conn(file); | 692 | struct fuse_conn *fc = fuse_get_conn(file); |
692 | if (!fc) | 693 | if (!fc) |
693 | return -EPERM; | 694 | return -EPERM; |
@@ -761,15 +762,6 @@ static ssize_t fuse_dev_readv(struct file *file, const struct iovec *iov, | |||
761 | return err; | 762 | return err; |
762 | } | 763 | } |
763 | 764 | ||
764 | static ssize_t fuse_dev_read(struct file *file, char __user *buf, | ||
765 | size_t nbytes, loff_t *off) | ||
766 | { | ||
767 | struct iovec iov; | ||
768 | iov.iov_len = nbytes; | ||
769 | iov.iov_base = buf; | ||
770 | return fuse_dev_readv(file, &iov, 1, off); | ||
771 | } | ||
772 | |||
773 | /* Look up request on processing list by unique ID */ | 765 | /* Look up request on processing list by unique ID */ |
774 | static struct fuse_req *request_find(struct fuse_conn *fc, u64 unique) | 766 | static struct fuse_req *request_find(struct fuse_conn *fc, u64 unique) |
775 | { | 767 | { |
@@ -814,15 +806,15 @@ static int copy_out_args(struct fuse_copy_state *cs, struct fuse_out *out, | |||
814 | * it from the list and copy the rest of the buffer to the request. | 806 | * it from the list and copy the rest of the buffer to the request. |
815 | * The request is finished by calling request_end() | 807 | * The request is finished by calling request_end() |
816 | */ | 808 | */ |
817 | static ssize_t fuse_dev_writev(struct file *file, const struct iovec *iov, | 809 | static ssize_t fuse_dev_write(struct kiocb *iocb, const struct iovec *iov, |
818 | unsigned long nr_segs, loff_t *off) | 810 | unsigned long nr_segs, loff_t pos) |
819 | { | 811 | { |
820 | int err; | 812 | int err; |
821 | unsigned nbytes = iov_length(iov, nr_segs); | 813 | unsigned nbytes = iov_length(iov, nr_segs); |
822 | struct fuse_req *req; | 814 | struct fuse_req *req; |
823 | struct fuse_out_header oh; | 815 | struct fuse_out_header oh; |
824 | struct fuse_copy_state cs; | 816 | struct fuse_copy_state cs; |
825 | struct fuse_conn *fc = fuse_get_conn(file); | 817 | struct fuse_conn *fc = fuse_get_conn(iocb->ki_filp); |
826 | if (!fc) | 818 | if (!fc) |
827 | return -EPERM; | 819 | return -EPERM; |
828 | 820 | ||
@@ -898,15 +890,6 @@ static ssize_t fuse_dev_writev(struct file *file, const struct iovec *iov, | |||
898 | return err; | 890 | return err; |
899 | } | 891 | } |
900 | 892 | ||
901 | static ssize_t fuse_dev_write(struct file *file, const char __user *buf, | ||
902 | size_t nbytes, loff_t *off) | ||
903 | { | ||
904 | struct iovec iov; | ||
905 | iov.iov_len = nbytes; | ||
906 | iov.iov_base = (char __user *) buf; | ||
907 | return fuse_dev_writev(file, &iov, 1, off); | ||
908 | } | ||
909 | |||
910 | static unsigned fuse_dev_poll(struct file *file, poll_table *wait) | 893 | static unsigned fuse_dev_poll(struct file *file, poll_table *wait) |
911 | { | 894 | { |
912 | unsigned mask = POLLOUT | POLLWRNORM; | 895 | unsigned mask = POLLOUT | POLLWRNORM; |
@@ -1041,10 +1024,10 @@ static int fuse_dev_fasync(int fd, struct file *file, int on) | |||
1041 | const struct file_operations fuse_dev_operations = { | 1024 | const struct file_operations fuse_dev_operations = { |
1042 | .owner = THIS_MODULE, | 1025 | .owner = THIS_MODULE, |
1043 | .llseek = no_llseek, | 1026 | .llseek = no_llseek, |
1044 | .read = fuse_dev_read, | 1027 | .read = do_sync_read, |
1045 | .readv = fuse_dev_readv, | 1028 | .aio_read = fuse_dev_read, |
1046 | .write = fuse_dev_write, | 1029 | .write = do_sync_write, |
1047 | .writev = fuse_dev_writev, | 1030 | .aio_write = fuse_dev_write, |
1048 | .poll = fuse_dev_poll, | 1031 | .poll = fuse_dev_poll, |
1049 | .release = fuse_dev_release, | 1032 | .release = fuse_dev_release, |
1050 | .fasync = fuse_dev_fasync, | 1033 | .fasync = fuse_dev_fasync, |
diff --git a/fs/hostfs/hostfs_kern.c b/fs/hostfs/hostfs_kern.c index 322e876c35ed..4908c38a5885 100644 --- a/fs/hostfs/hostfs_kern.c +++ b/fs/hostfs/hostfs_kern.c | |||
@@ -389,8 +389,6 @@ static const struct file_operations hostfs_file_fops = { | |||
389 | .sendfile = generic_file_sendfile, | 389 | .sendfile = generic_file_sendfile, |
390 | .aio_read = generic_file_aio_read, | 390 | .aio_read = generic_file_aio_read, |
391 | .aio_write = generic_file_aio_write, | 391 | .aio_write = generic_file_aio_write, |
392 | .readv = generic_file_readv, | ||
393 | .writev = generic_file_writev, | ||
394 | .write = generic_file_write, | 392 | .write = generic_file_write, |
395 | .mmap = generic_file_mmap, | 393 | .mmap = generic_file_mmap, |
396 | .open = hostfs_file_open, | 394 | .open = hostfs_file_open, |
diff --git a/fs/jfs/file.c b/fs/jfs/file.c index 1c9745be5ada..f535f2911c12 100644 --- a/fs/jfs/file.c +++ b/fs/jfs/file.c | |||
@@ -108,8 +108,6 @@ const struct file_operations jfs_file_operations = { | |||
108 | .aio_read = generic_file_aio_read, | 108 | .aio_read = generic_file_aio_read, |
109 | .aio_write = generic_file_aio_write, | 109 | .aio_write = generic_file_aio_write, |
110 | .mmap = generic_file_mmap, | 110 | .mmap = generic_file_mmap, |
111 | .readv = generic_file_readv, | ||
112 | .writev = generic_file_writev, | ||
113 | .sendfile = generic_file_sendfile, | 111 | .sendfile = generic_file_sendfile, |
114 | .fsync = jfs_fsync, | 112 | .fsync = jfs_fsync, |
115 | .release = jfs_release, | 113 | .release = jfs_release, |
diff --git a/fs/ntfs/file.c b/fs/ntfs/file.c index 0c46f5c86b71..2f9b5a0953ff 100644 --- a/fs/ntfs/file.c +++ b/fs/ntfs/file.c | |||
@@ -2298,11 +2298,9 @@ const struct file_operations ntfs_file_ops = { | |||
2298 | .llseek = generic_file_llseek, /* Seek inside file. */ | 2298 | .llseek = generic_file_llseek, /* Seek inside file. */ |
2299 | .read = generic_file_read, /* Read from file. */ | 2299 | .read = generic_file_read, /* Read from file. */ |
2300 | .aio_read = generic_file_aio_read, /* Async read from file. */ | 2300 | .aio_read = generic_file_aio_read, /* Async read from file. */ |
2301 | .readv = generic_file_readv, /* Read from file. */ | ||
2302 | #ifdef NTFS_RW | 2301 | #ifdef NTFS_RW |
2303 | .write = ntfs_file_write, /* Write to file. */ | 2302 | .write = ntfs_file_write, /* Write to file. */ |
2304 | .aio_write = ntfs_file_aio_write, /* Async write to file. */ | 2303 | .aio_write = ntfs_file_aio_write, /* Async write to file. */ |
2305 | .writev = ntfs_file_writev, /* Write to file. */ | ||
2306 | /*.release = ,*/ /* Last file is closed. See | 2304 | /*.release = ,*/ /* Last file is closed. See |
2307 | fs/ext2/file.c:: | 2305 | fs/ext2/file.c:: |
2308 | ext2_release_file() for | 2306 | ext2_release_file() for |
@@ -218,9 +218,10 @@ static struct pipe_buf_operations anon_pipe_buf_ops = { | |||
218 | }; | 218 | }; |
219 | 219 | ||
220 | static ssize_t | 220 | static ssize_t |
221 | pipe_readv(struct file *filp, const struct iovec *_iov, | 221 | pipe_read(struct kiocb *iocb, const struct iovec *_iov, |
222 | unsigned long nr_segs, loff_t *ppos) | 222 | unsigned long nr_segs, loff_t pos) |
223 | { | 223 | { |
224 | struct file *filp = iocb->ki_filp; | ||
224 | struct inode *inode = filp->f_dentry->d_inode; | 225 | struct inode *inode = filp->f_dentry->d_inode; |
225 | struct pipe_inode_info *pipe; | 226 | struct pipe_inode_info *pipe; |
226 | int do_wakeup; | 227 | int do_wakeup; |
@@ -330,17 +331,10 @@ redo: | |||
330 | } | 331 | } |
331 | 332 | ||
332 | static ssize_t | 333 | static ssize_t |
333 | pipe_read(struct file *filp, char __user *buf, size_t count, loff_t *ppos) | 334 | pipe_write(struct kiocb *iocb, const struct iovec *_iov, |
334 | { | 335 | unsigned long nr_segs, loff_t ppos) |
335 | struct iovec iov = { .iov_base = buf, .iov_len = count }; | ||
336 | |||
337 | return pipe_readv(filp, &iov, 1, ppos); | ||
338 | } | ||
339 | |||
340 | static ssize_t | ||
341 | pipe_writev(struct file *filp, const struct iovec *_iov, | ||
342 | unsigned long nr_segs, loff_t *ppos) | ||
343 | { | 336 | { |
337 | struct file *filp = iocb->ki_filp; | ||
344 | struct inode *inode = filp->f_dentry->d_inode; | 338 | struct inode *inode = filp->f_dentry->d_inode; |
345 | struct pipe_inode_info *pipe; | 339 | struct pipe_inode_info *pipe; |
346 | ssize_t ret; | 340 | ssize_t ret; |
@@ -510,15 +504,6 @@ out: | |||
510 | } | 504 | } |
511 | 505 | ||
512 | static ssize_t | 506 | static ssize_t |
513 | pipe_write(struct file *filp, const char __user *buf, | ||
514 | size_t count, loff_t *ppos) | ||
515 | { | ||
516 | struct iovec iov = { .iov_base = (void __user *)buf, .iov_len = count }; | ||
517 | |||
518 | return pipe_writev(filp, &iov, 1, ppos); | ||
519 | } | ||
520 | |||
521 | static ssize_t | ||
522 | bad_pipe_r(struct file *filp, char __user *buf, size_t count, loff_t *ppos) | 507 | bad_pipe_r(struct file *filp, char __user *buf, size_t count, loff_t *ppos) |
523 | { | 508 | { |
524 | return -EBADF; | 509 | return -EBADF; |
@@ -736,8 +721,8 @@ pipe_rdwr_open(struct inode *inode, struct file *filp) | |||
736 | */ | 721 | */ |
737 | const struct file_operations read_fifo_fops = { | 722 | const struct file_operations read_fifo_fops = { |
738 | .llseek = no_llseek, | 723 | .llseek = no_llseek, |
739 | .read = pipe_read, | 724 | .read = do_sync_read, |
740 | .readv = pipe_readv, | 725 | .aio_read = pipe_read, |
741 | .write = bad_pipe_w, | 726 | .write = bad_pipe_w, |
742 | .poll = pipe_poll, | 727 | .poll = pipe_poll, |
743 | .ioctl = pipe_ioctl, | 728 | .ioctl = pipe_ioctl, |
@@ -749,8 +734,8 @@ const struct file_operations read_fifo_fops = { | |||
749 | const struct file_operations write_fifo_fops = { | 734 | const struct file_operations write_fifo_fops = { |
750 | .llseek = no_llseek, | 735 | .llseek = no_llseek, |
751 | .read = bad_pipe_r, | 736 | .read = bad_pipe_r, |
752 | .write = pipe_write, | 737 | .write = do_sync_write, |
753 | .writev = pipe_writev, | 738 | .aio_write = pipe_write, |
754 | .poll = pipe_poll, | 739 | .poll = pipe_poll, |
755 | .ioctl = pipe_ioctl, | 740 | .ioctl = pipe_ioctl, |
756 | .open = pipe_write_open, | 741 | .open = pipe_write_open, |
@@ -760,10 +745,10 @@ const struct file_operations write_fifo_fops = { | |||
760 | 745 | ||
761 | const struct file_operations rdwr_fifo_fops = { | 746 | const struct file_operations rdwr_fifo_fops = { |
762 | .llseek = no_llseek, | 747 | .llseek = no_llseek, |
763 | .read = pipe_read, | 748 | .read = do_sync_read, |
764 | .readv = pipe_readv, | 749 | .aio_read = pipe_read, |
765 | .write = pipe_write, | 750 | .write = do_sync_write, |
766 | .writev = pipe_writev, | 751 | .aio_write = pipe_write, |
767 | .poll = pipe_poll, | 752 | .poll = pipe_poll, |
768 | .ioctl = pipe_ioctl, | 753 | .ioctl = pipe_ioctl, |
769 | .open = pipe_rdwr_open, | 754 | .open = pipe_rdwr_open, |
@@ -773,8 +758,8 @@ const struct file_operations rdwr_fifo_fops = { | |||
773 | 758 | ||
774 | static struct file_operations read_pipe_fops = { | 759 | static struct file_operations read_pipe_fops = { |
775 | .llseek = no_llseek, | 760 | .llseek = no_llseek, |
776 | .read = pipe_read, | 761 | .read = do_sync_read, |
777 | .readv = pipe_readv, | 762 | .aio_read = pipe_read, |
778 | .write = bad_pipe_w, | 763 | .write = bad_pipe_w, |
779 | .poll = pipe_poll, | 764 | .poll = pipe_poll, |
780 | .ioctl = pipe_ioctl, | 765 | .ioctl = pipe_ioctl, |
@@ -786,8 +771,8 @@ static struct file_operations read_pipe_fops = { | |||
786 | static struct file_operations write_pipe_fops = { | 771 | static struct file_operations write_pipe_fops = { |
787 | .llseek = no_llseek, | 772 | .llseek = no_llseek, |
788 | .read = bad_pipe_r, | 773 | .read = bad_pipe_r, |
789 | .write = pipe_write, | 774 | .write = do_sync_write, |
790 | .writev = pipe_writev, | 775 | .aio_write = pipe_write, |
791 | .poll = pipe_poll, | 776 | .poll = pipe_poll, |
792 | .ioctl = pipe_ioctl, | 777 | .ioctl = pipe_ioctl, |
793 | .open = pipe_write_open, | 778 | .open = pipe_write_open, |
@@ -797,10 +782,10 @@ static struct file_operations write_pipe_fops = { | |||
797 | 782 | ||
798 | static struct file_operations rdwr_pipe_fops = { | 783 | static struct file_operations rdwr_pipe_fops = { |
799 | .llseek = no_llseek, | 784 | .llseek = no_llseek, |
800 | .read = pipe_read, | 785 | .read = do_sync_read, |
801 | .readv = pipe_readv, | 786 | .aio_read = pipe_read, |
802 | .write = pipe_write, | 787 | .write = do_sync_write, |
803 | .writev = pipe_writev, | 788 | .aio_write = pipe_write, |
804 | .poll = pipe_poll, | 789 | .poll = pipe_poll, |
805 | .ioctl = pipe_ioctl, | 790 | .ioctl = pipe_ioctl, |
806 | .open = pipe_rdwr_open, | 791 | .open = pipe_rdwr_open, |
diff --git a/fs/read_write.c b/fs/read_write.c index 679dd535380f..32d54cca9bd9 100644 --- a/fs/read_write.c +++ b/fs/read_write.c | |||
@@ -15,6 +15,7 @@ | |||
15 | #include <linux/module.h> | 15 | #include <linux/module.h> |
16 | #include <linux/syscalls.h> | 16 | #include <linux/syscalls.h> |
17 | #include <linux/pagemap.h> | 17 | #include <linux/pagemap.h> |
18 | #include "read_write.h" | ||
18 | 19 | ||
19 | #include <asm/uaccess.h> | 20 | #include <asm/uaccess.h> |
20 | #include <asm/unistd.h> | 21 | #include <asm/unistd.h> |
@@ -450,6 +451,62 @@ unsigned long iov_shorten(struct iovec *iov, unsigned long nr_segs, size_t to) | |||
450 | 451 | ||
451 | EXPORT_UNUSED_SYMBOL(iov_shorten); /* June 2006 */ | 452 | EXPORT_UNUSED_SYMBOL(iov_shorten); /* June 2006 */ |
452 | 453 | ||
454 | ssize_t do_sync_readv_writev(struct file *filp, const struct iovec *iov, | ||
455 | unsigned long nr_segs, size_t len, loff_t *ppos, iov_fn_t fn) | ||
456 | { | ||
457 | struct kiocb kiocb; | ||
458 | ssize_t ret; | ||
459 | |||
460 | init_sync_kiocb(&kiocb, filp); | ||
461 | kiocb.ki_pos = *ppos; | ||
462 | kiocb.ki_left = len; | ||
463 | kiocb.ki_nbytes = len; | ||
464 | |||
465 | for (;;) { | ||
466 | ret = fn(&kiocb, iov, nr_segs, kiocb.ki_pos); | ||
467 | if (ret != -EIOCBRETRY) | ||
468 | break; | ||
469 | wait_on_retry_sync_kiocb(&kiocb); | ||
470 | } | ||
471 | |||
472 | if (ret == -EIOCBQUEUED) | ||
473 | ret = wait_on_sync_kiocb(&kiocb); | ||
474 | *ppos = kiocb.ki_pos; | ||
475 | return ret; | ||
476 | } | ||
477 | |||
478 | /* Do it by hand, with file-ops */ | ||
479 | ssize_t do_loop_readv_writev(struct file *filp, struct iovec *iov, | ||
480 | unsigned long nr_segs, loff_t *ppos, io_fn_t fn) | ||
481 | { | ||
482 | struct iovec *vector = iov; | ||
483 | ssize_t ret = 0; | ||
484 | |||
485 | while (nr_segs > 0) { | ||
486 | void __user *base; | ||
487 | size_t len; | ||
488 | ssize_t nr; | ||
489 | |||
490 | base = vector->iov_base; | ||
491 | len = vector->iov_len; | ||
492 | vector++; | ||
493 | nr_segs--; | ||
494 | |||
495 | nr = fn(filp, base, len, ppos); | ||
496 | |||
497 | if (nr < 0) { | ||
498 | if (!ret) | ||
499 | ret = nr; | ||
500 | break; | ||
501 | } | ||
502 | ret += nr; | ||
503 | if (nr != len) | ||
504 | break; | ||
505 | } | ||
506 | |||
507 | return ret; | ||
508 | } | ||
509 | |||
453 | /* A write operation does a read from user space and vice versa */ | 510 | /* A write operation does a read from user space and vice versa */ |
454 | #define vrfy_dir(type) ((type) == READ ? VERIFY_WRITE : VERIFY_READ) | 511 | #define vrfy_dir(type) ((type) == READ ? VERIFY_WRITE : VERIFY_READ) |
455 | 512 | ||
@@ -457,12 +514,9 @@ static ssize_t do_readv_writev(int type, struct file *file, | |||
457 | const struct iovec __user * uvector, | 514 | const struct iovec __user * uvector, |
458 | unsigned long nr_segs, loff_t *pos) | 515 | unsigned long nr_segs, loff_t *pos) |
459 | { | 516 | { |
460 | typedef ssize_t (*io_fn_t)(struct file *, char __user *, size_t, loff_t *); | ||
461 | typedef ssize_t (*iov_fn_t)(struct file *, const struct iovec *, unsigned long, loff_t *); | ||
462 | |||
463 | size_t tot_len; | 517 | size_t tot_len; |
464 | struct iovec iovstack[UIO_FASTIOV]; | 518 | struct iovec iovstack[UIO_FASTIOV]; |
465 | struct iovec *iov=iovstack, *vector; | 519 | struct iovec *iov = iovstack; |
466 | ssize_t ret; | 520 | ssize_t ret; |
467 | int seg; | 521 | int seg; |
468 | io_fn_t fn; | 522 | io_fn_t fn; |
@@ -532,39 +586,18 @@ static ssize_t do_readv_writev(int type, struct file *file, | |||
532 | fnv = NULL; | 586 | fnv = NULL; |
533 | if (type == READ) { | 587 | if (type == READ) { |
534 | fn = file->f_op->read; | 588 | fn = file->f_op->read; |
535 | fnv = file->f_op->readv; | 589 | fnv = file->f_op->aio_read; |
536 | } else { | 590 | } else { |
537 | fn = (io_fn_t)file->f_op->write; | 591 | fn = (io_fn_t)file->f_op->write; |
538 | fnv = file->f_op->writev; | 592 | fnv = file->f_op->aio_write; |
539 | } | ||
540 | if (fnv) { | ||
541 | ret = fnv(file, iov, nr_segs, pos); | ||
542 | goto out; | ||
543 | } | 593 | } |
544 | 594 | ||
545 | /* Do it by hand, with file-ops */ | 595 | if (fnv) |
546 | ret = 0; | 596 | ret = do_sync_readv_writev(file, iov, nr_segs, tot_len, |
547 | vector = iov; | 597 | pos, fnv); |
548 | while (nr_segs > 0) { | 598 | else |
549 | void __user * base; | 599 | ret = do_loop_readv_writev(file, iov, nr_segs, pos, fn); |
550 | size_t len; | ||
551 | ssize_t nr; | ||
552 | |||
553 | base = vector->iov_base; | ||
554 | len = vector->iov_len; | ||
555 | vector++; | ||
556 | nr_segs--; | ||
557 | |||
558 | nr = fn(file, base, len, pos); | ||
559 | 600 | ||
560 | if (nr < 0) { | ||
561 | if (!ret) ret = nr; | ||
562 | break; | ||
563 | } | ||
564 | ret += nr; | ||
565 | if (nr != len) | ||
566 | break; | ||
567 | } | ||
568 | out: | 601 | out: |
569 | if (iov != iovstack) | 602 | if (iov != iovstack) |
570 | kfree(iov); | 603 | kfree(iov); |
@@ -585,7 +618,7 @@ ssize_t vfs_readv(struct file *file, const struct iovec __user *vec, | |||
585 | { | 618 | { |
586 | if (!(file->f_mode & FMODE_READ)) | 619 | if (!(file->f_mode & FMODE_READ)) |
587 | return -EBADF; | 620 | return -EBADF; |
588 | if (!file->f_op || (!file->f_op->readv && !file->f_op->read)) | 621 | if (!file->f_op || (!file->f_op->aio_read && !file->f_op->read)) |
589 | return -EINVAL; | 622 | return -EINVAL; |
590 | 623 | ||
591 | return do_readv_writev(READ, file, vec, vlen, pos); | 624 | return do_readv_writev(READ, file, vec, vlen, pos); |
@@ -598,7 +631,7 @@ ssize_t vfs_writev(struct file *file, const struct iovec __user *vec, | |||
598 | { | 631 | { |
599 | if (!(file->f_mode & FMODE_WRITE)) | 632 | if (!(file->f_mode & FMODE_WRITE)) |
600 | return -EBADF; | 633 | return -EBADF; |
601 | if (!file->f_op || (!file->f_op->writev && !file->f_op->write)) | 634 | if (!file->f_op || (!file->f_op->aio_write && !file->f_op->write)) |
602 | return -EINVAL; | 635 | return -EINVAL; |
603 | 636 | ||
604 | return do_readv_writev(WRITE, file, vec, vlen, pos); | 637 | return do_readv_writev(WRITE, file, vec, vlen, pos); |
diff --git a/fs/read_write.h b/fs/read_write.h new file mode 100644 index 000000000000..d07b954c6e0c --- /dev/null +++ b/fs/read_write.h | |||
@@ -0,0 +1,14 @@ | |||
1 | /* | ||
2 | * This file is only for sharing some helpers from read_write.c with compat.c. | ||
3 | * Don't use anywhere else. | ||
4 | */ | ||
5 | |||
6 | |||
7 | typedef ssize_t (*io_fn_t)(struct file *, char __user *, size_t, loff_t *); | ||
8 | typedef ssize_t (*iov_fn_t)(struct kiocb *, const struct iovec *, | ||
9 | unsigned long, loff_t); | ||
10 | |||
11 | ssize_t do_sync_readv_writev(struct file *filp, const struct iovec *iov, | ||
12 | unsigned long nr_segs, size_t len, loff_t *ppos, iov_fn_t fn); | ||
13 | ssize_t do_loop_readv_writev(struct file *filp, struct iovec *iov, | ||
14 | unsigned long nr_segs, loff_t *ppos, io_fn_t fn); | ||
diff --git a/fs/xfs/linux-2.6/xfs_file.c b/fs/xfs/linux-2.6/xfs_file.c index 4737971c6a39..d93d8dd1958d 100644 --- a/fs/xfs/linux-2.6/xfs_file.c +++ b/fs/xfs/linux-2.6/xfs_file.c | |||
@@ -123,96 +123,6 @@ xfs_file_aio_write_invis( | |||
123 | return __xfs_file_write(iocb, iov, nr_segs, IO_ISAIO|IO_INVIS, pos); | 123 | return __xfs_file_write(iocb, iov, nr_segs, IO_ISAIO|IO_INVIS, pos); |
124 | } | 124 | } |
125 | 125 | ||
126 | STATIC inline ssize_t | ||
127 | __xfs_file_readv( | ||
128 | struct file *file, | ||
129 | const struct iovec *iov, | ||
130 | int ioflags, | ||
131 | unsigned long nr_segs, | ||
132 | loff_t *ppos) | ||
133 | { | ||
134 | struct inode *inode = file->f_mapping->host; | ||
135 | bhv_vnode_t *vp = vn_from_inode(inode); | ||
136 | struct kiocb kiocb; | ||
137 | ssize_t rval; | ||
138 | |||
139 | init_sync_kiocb(&kiocb, file); | ||
140 | kiocb.ki_pos = *ppos; | ||
141 | |||
142 | if (unlikely(file->f_flags & O_DIRECT)) | ||
143 | ioflags |= IO_ISDIRECT; | ||
144 | rval = bhv_vop_read(vp, &kiocb, iov, nr_segs, | ||
145 | &kiocb.ki_pos, ioflags, NULL); | ||
146 | |||
147 | *ppos = kiocb.ki_pos; | ||
148 | return rval; | ||
149 | } | ||
150 | |||
151 | STATIC ssize_t | ||
152 | xfs_file_readv( | ||
153 | struct file *file, | ||
154 | const struct iovec *iov, | ||
155 | unsigned long nr_segs, | ||
156 | loff_t *ppos) | ||
157 | { | ||
158 | return __xfs_file_readv(file, iov, 0, nr_segs, ppos); | ||
159 | } | ||
160 | |||
161 | STATIC ssize_t | ||
162 | xfs_file_readv_invis( | ||
163 | struct file *file, | ||
164 | const struct iovec *iov, | ||
165 | unsigned long nr_segs, | ||
166 | loff_t *ppos) | ||
167 | { | ||
168 | return __xfs_file_readv(file, iov, IO_INVIS, nr_segs, ppos); | ||
169 | } | ||
170 | |||
171 | STATIC inline ssize_t | ||
172 | __xfs_file_writev( | ||
173 | struct file *file, | ||
174 | const struct iovec *iov, | ||
175 | int ioflags, | ||
176 | unsigned long nr_segs, | ||
177 | loff_t *ppos) | ||
178 | { | ||
179 | struct inode *inode = file->f_mapping->host; | ||
180 | bhv_vnode_t *vp = vn_from_inode(inode); | ||
181 | struct kiocb kiocb; | ||
182 | ssize_t rval; | ||
183 | |||
184 | init_sync_kiocb(&kiocb, file); | ||
185 | kiocb.ki_pos = *ppos; | ||
186 | if (unlikely(file->f_flags & O_DIRECT)) | ||
187 | ioflags |= IO_ISDIRECT; | ||
188 | |||
189 | rval = bhv_vop_write(vp, &kiocb, iov, nr_segs, | ||
190 | &kiocb.ki_pos, ioflags, NULL); | ||
191 | |||
192 | *ppos = kiocb.ki_pos; | ||
193 | return rval; | ||
194 | } | ||
195 | |||
196 | STATIC ssize_t | ||
197 | xfs_file_writev( | ||
198 | struct file *file, | ||
199 | const struct iovec *iov, | ||
200 | unsigned long nr_segs, | ||
201 | loff_t *ppos) | ||
202 | { | ||
203 | return __xfs_file_writev(file, iov, 0, nr_segs, ppos); | ||
204 | } | ||
205 | |||
206 | STATIC ssize_t | ||
207 | xfs_file_writev_invis( | ||
208 | struct file *file, | ||
209 | const struct iovec *iov, | ||
210 | unsigned long nr_segs, | ||
211 | loff_t *ppos) | ||
212 | { | ||
213 | return __xfs_file_writev(file, iov, IO_INVIS, nr_segs, ppos); | ||
214 | } | ||
215 | |||
216 | STATIC ssize_t | 126 | STATIC ssize_t |
217 | xfs_file_sendfile( | 127 | xfs_file_sendfile( |
218 | struct file *filp, | 128 | struct file *filp, |
@@ -540,8 +450,6 @@ const struct file_operations xfs_file_operations = { | |||
540 | .llseek = generic_file_llseek, | 450 | .llseek = generic_file_llseek, |
541 | .read = do_sync_read, | 451 | .read = do_sync_read, |
542 | .write = do_sync_write, | 452 | .write = do_sync_write, |
543 | .readv = xfs_file_readv, | ||
544 | .writev = xfs_file_writev, | ||
545 | .aio_read = xfs_file_aio_read, | 453 | .aio_read = xfs_file_aio_read, |
546 | .aio_write = xfs_file_aio_write, | 454 | .aio_write = xfs_file_aio_write, |
547 | .sendfile = xfs_file_sendfile, | 455 | .sendfile = xfs_file_sendfile, |
@@ -565,8 +473,6 @@ const struct file_operations xfs_invis_file_operations = { | |||
565 | .llseek = generic_file_llseek, | 473 | .llseek = generic_file_llseek, |
566 | .read = do_sync_read, | 474 | .read = do_sync_read, |
567 | .write = do_sync_write, | 475 | .write = do_sync_write, |
568 | .readv = xfs_file_readv_invis, | ||
569 | .writev = xfs_file_writev_invis, | ||
570 | .aio_read = xfs_file_aio_read_invis, | 476 | .aio_read = xfs_file_aio_read_invis, |
571 | .aio_write = xfs_file_aio_write_invis, | 477 | .aio_write = xfs_file_aio_write_invis, |
572 | .sendfile = xfs_file_sendfile_invis, | 478 | .sendfile = xfs_file_sendfile_invis, |
diff --git a/include/linux/fs.h b/include/linux/fs.h index 257bae16f545..afb6e6f89a01 100644 --- a/include/linux/fs.h +++ b/include/linux/fs.h | |||
@@ -1113,8 +1113,6 @@ struct file_operations { | |||
1113 | int (*aio_fsync) (struct kiocb *, int datasync); | 1113 | int (*aio_fsync) (struct kiocb *, int datasync); |
1114 | int (*fasync) (int, struct file *, int); | 1114 | int (*fasync) (int, struct file *, int); |
1115 | int (*lock) (struct file *, int, struct file_lock *); | 1115 | int (*lock) (struct file *, int, struct file_lock *); |
1116 | ssize_t (*readv) (struct file *, const struct iovec *, unsigned long, loff_t *); | ||
1117 | ssize_t (*writev) (struct file *, const struct iovec *, unsigned long, loff_t *); | ||
1118 | ssize_t (*sendfile) (struct file *, loff_t *, size_t, read_actor_t, void *); | 1116 | ssize_t (*sendfile) (struct file *, loff_t *, size_t, read_actor_t, void *); |
1119 | ssize_t (*sendpage) (struct file *, struct page *, int, size_t, loff_t *, int); | 1117 | ssize_t (*sendpage) (struct file *, struct page *, int, size_t, loff_t *, int); |
1120 | unsigned long (*get_unmapped_area)(struct file *, unsigned long, unsigned long, unsigned long, unsigned long); | 1118 | unsigned long (*get_unmapped_area)(struct file *, unsigned long, unsigned long, unsigned long, unsigned long); |
@@ -1734,10 +1732,6 @@ extern long do_splice_direct(struct file *in, loff_t *ppos, struct file *out, | |||
1734 | 1732 | ||
1735 | extern void | 1733 | extern void |
1736 | file_ra_state_init(struct file_ra_state *ra, struct address_space *mapping); | 1734 | file_ra_state_init(struct file_ra_state *ra, struct address_space *mapping); |
1737 | extern ssize_t generic_file_readv(struct file *filp, const struct iovec *iov, | ||
1738 | unsigned long nr_segs, loff_t *ppos); | ||
1739 | ssize_t generic_file_writev(struct file *filp, const struct iovec *iov, | ||
1740 | unsigned long nr_segs, loff_t *ppos); | ||
1741 | extern loff_t no_llseek(struct file *file, loff_t offset, int origin); | 1735 | extern loff_t no_llseek(struct file *file, loff_t offset, int origin); |
1742 | extern loff_t generic_file_llseek(struct file *file, loff_t offset, int origin); | 1736 | extern loff_t generic_file_llseek(struct file *file, loff_t offset, int origin); |
1743 | extern loff_t remote_llseek(struct file *file, loff_t offset, int origin); | 1737 | extern loff_t remote_llseek(struct file *file, loff_t offset, int origin); |
diff --git a/mm/filemap.c b/mm/filemap.c index f6c1d22b504f..48497094ae83 100644 --- a/mm/filemap.c +++ b/mm/filemap.c | |||
@@ -2421,42 +2421,6 @@ ssize_t generic_file_write(struct file *file, const char __user *buf, | |||
2421 | } | 2421 | } |
2422 | EXPORT_SYMBOL(generic_file_write); | 2422 | EXPORT_SYMBOL(generic_file_write); |
2423 | 2423 | ||
2424 | ssize_t generic_file_readv(struct file *filp, const struct iovec *iov, | ||
2425 | unsigned long nr_segs, loff_t *ppos) | ||
2426 | { | ||
2427 | struct kiocb kiocb; | ||
2428 | ssize_t ret; | ||
2429 | |||
2430 | init_sync_kiocb(&kiocb, filp); | ||
2431 | ret = __generic_file_aio_read(&kiocb, iov, nr_segs, ppos); | ||
2432 | if (-EIOCBQUEUED == ret) | ||
2433 | ret = wait_on_sync_kiocb(&kiocb); | ||
2434 | return ret; | ||
2435 | } | ||
2436 | EXPORT_SYMBOL(generic_file_readv); | ||
2437 | |||
2438 | ssize_t generic_file_writev(struct file *file, const struct iovec *iov, | ||
2439 | unsigned long nr_segs, loff_t *ppos) | ||
2440 | { | ||
2441 | struct address_space *mapping = file->f_mapping; | ||
2442 | struct inode *inode = mapping->host; | ||
2443 | ssize_t ret; | ||
2444 | |||
2445 | mutex_lock(&inode->i_mutex); | ||
2446 | ret = __generic_file_write_nolock(file, iov, nr_segs, ppos); | ||
2447 | mutex_unlock(&inode->i_mutex); | ||
2448 | |||
2449 | if (ret > 0 && ((file->f_flags & O_SYNC) || IS_SYNC(inode))) { | ||
2450 | int err; | ||
2451 | |||
2452 | err = sync_page_range(inode, mapping, *ppos - ret, ret); | ||
2453 | if (err < 0) | ||
2454 | ret = err; | ||
2455 | } | ||
2456 | return ret; | ||
2457 | } | ||
2458 | EXPORT_SYMBOL(generic_file_writev); | ||
2459 | |||
2460 | /* | 2424 | /* |
2461 | * Called under i_mutex for writes to S_ISREG files. Returns -EIO if something | 2425 | * Called under i_mutex for writes to S_ISREG files. Returns -EIO if something |
2462 | * went wrong during pagecache shootdown. | 2426 | * went wrong during pagecache shootdown. |
diff --git a/net/socket.c b/net/socket.c index df92e4252749..01918f7a301a 100644 --- a/net/socket.c +++ b/net/socket.c | |||
@@ -110,10 +110,6 @@ static long compat_sock_ioctl(struct file *file, | |||
110 | unsigned int cmd, unsigned long arg); | 110 | unsigned int cmd, unsigned long arg); |
111 | #endif | 111 | #endif |
112 | static int sock_fasync(int fd, struct file *filp, int on); | 112 | static int sock_fasync(int fd, struct file *filp, int on); |
113 | static ssize_t sock_readv(struct file *file, const struct iovec *vector, | ||
114 | unsigned long count, loff_t *ppos); | ||
115 | static ssize_t sock_writev(struct file *file, const struct iovec *vector, | ||
116 | unsigned long count, loff_t *ppos); | ||
117 | static ssize_t sock_sendpage(struct file *file, struct page *page, | 113 | static ssize_t sock_sendpage(struct file *file, struct page *page, |
118 | int offset, size_t size, loff_t *ppos, int more); | 114 | int offset, size_t size, loff_t *ppos, int more); |
119 | 115 | ||
@@ -136,8 +132,6 @@ static struct file_operations socket_file_ops = { | |||
136 | .open = sock_no_open, /* special open code to disallow open via /proc */ | 132 | .open = sock_no_open, /* special open code to disallow open via /proc */ |
137 | .release = sock_close, | 133 | .release = sock_close, |
138 | .fasync = sock_fasync, | 134 | .fasync = sock_fasync, |
139 | .readv = sock_readv, | ||
140 | .writev = sock_writev, | ||
141 | .sendpage = sock_sendpage, | 135 | .sendpage = sock_sendpage, |
142 | .splice_write = generic_splice_sendpage, | 136 | .splice_write = generic_splice_sendpage, |
143 | }; | 137 | }; |
@@ -700,23 +694,6 @@ static ssize_t do_sock_read(struct msghdr *msg, struct kiocb *iocb, | |||
700 | return __sock_recvmsg(iocb, sock, msg, size, msg->msg_flags); | 694 | return __sock_recvmsg(iocb, sock, msg, size, msg->msg_flags); |
701 | } | 695 | } |
702 | 696 | ||
703 | static ssize_t sock_readv(struct file *file, const struct iovec *iov, | ||
704 | unsigned long nr_segs, loff_t *ppos) | ||
705 | { | ||
706 | struct kiocb iocb; | ||
707 | struct sock_iocb siocb; | ||
708 | struct msghdr msg; | ||
709 | int ret; | ||
710 | |||
711 | init_sync_kiocb(&iocb, NULL); | ||
712 | iocb.private = &siocb; | ||
713 | |||
714 | ret = do_sock_read(&msg, &iocb, file, iov, nr_segs); | ||
715 | if (-EIOCBQUEUED == ret) | ||
716 | ret = wait_on_sync_kiocb(&iocb); | ||
717 | return ret; | ||
718 | } | ||
719 | |||
720 | static ssize_t sock_aio_read(struct kiocb *iocb, const struct iovec *iov, | 697 | static ssize_t sock_aio_read(struct kiocb *iocb, const struct iovec *iov, |
721 | unsigned long nr_segs, loff_t pos) | 698 | unsigned long nr_segs, loff_t pos) |
722 | { | 699 | { |
@@ -759,23 +736,6 @@ static ssize_t do_sock_write(struct msghdr *msg, struct kiocb *iocb, | |||
759 | return __sock_sendmsg(iocb, sock, msg, size); | 736 | return __sock_sendmsg(iocb, sock, msg, size); |
760 | } | 737 | } |
761 | 738 | ||
762 | static ssize_t sock_writev(struct file *file, const struct iovec *iov, | ||
763 | unsigned long nr_segs, loff_t *ppos) | ||
764 | { | ||
765 | struct msghdr msg; | ||
766 | struct kiocb iocb; | ||
767 | struct sock_iocb siocb; | ||
768 | int ret; | ||
769 | |||
770 | init_sync_kiocb(&iocb, NULL); | ||
771 | iocb.private = &siocb; | ||
772 | |||
773 | ret = do_sock_write(&msg, &iocb, file, iov, nr_segs); | ||
774 | if (-EIOCBQUEUED == ret) | ||
775 | ret = wait_on_sync_kiocb(&iocb); | ||
776 | return ret; | ||
777 | } | ||
778 | |||
779 | static ssize_t sock_aio_write(struct kiocb *iocb, const struct iovec *iov, | 739 | static ssize_t sock_aio_write(struct kiocb *iocb, const struct iovec *iov, |
780 | unsigned long nr_segs, loff_t pos) | 740 | unsigned long nr_segs, loff_t pos) |
781 | { | 741 | { |
diff --git a/sound/core/pcm_native.c b/sound/core/pcm_native.c index 891d7140553c..37b4b10850ae 100644 --- a/sound/core/pcm_native.c +++ b/sound/core/pcm_native.c | |||
@@ -2852,8 +2852,8 @@ static ssize_t snd_pcm_write(struct file *file, const char __user *buf, | |||
2852 | return result; | 2852 | return result; |
2853 | } | 2853 | } |
2854 | 2854 | ||
2855 | static ssize_t snd_pcm_readv(struct file *file, const struct iovec *_vector, | 2855 | static ssize_t snd_pcm_aio_read(struct kiocb *iocb, const struct iovec *iov, |
2856 | unsigned long count, loff_t * offset) | 2856 | unsigned long nr_segs, loff_t pos) |
2857 | 2857 | ||
2858 | { | 2858 | { |
2859 | struct snd_pcm_file *pcm_file; | 2859 | struct snd_pcm_file *pcm_file; |
@@ -2864,22 +2864,22 @@ static ssize_t snd_pcm_readv(struct file *file, const struct iovec *_vector, | |||
2864 | void __user **bufs; | 2864 | void __user **bufs; |
2865 | snd_pcm_uframes_t frames; | 2865 | snd_pcm_uframes_t frames; |
2866 | 2866 | ||
2867 | pcm_file = file->private_data; | 2867 | pcm_file = iocb->ki_filp->private_data; |
2868 | substream = pcm_file->substream; | 2868 | substream = pcm_file->substream; |
2869 | snd_assert(substream != NULL, return -ENXIO); | 2869 | snd_assert(substream != NULL, return -ENXIO); |
2870 | runtime = substream->runtime; | 2870 | runtime = substream->runtime; |
2871 | if (runtime->status->state == SNDRV_PCM_STATE_OPEN) | 2871 | if (runtime->status->state == SNDRV_PCM_STATE_OPEN) |
2872 | return -EBADFD; | 2872 | return -EBADFD; |
2873 | if (count > 1024 || count != runtime->channels) | 2873 | if (nr_segs > 1024 || nr_segs != runtime->channels) |
2874 | return -EINVAL; | 2874 | return -EINVAL; |
2875 | if (!frame_aligned(runtime, _vector->iov_len)) | 2875 | if (!frame_aligned(runtime, iov->iov_len)) |
2876 | return -EINVAL; | 2876 | return -EINVAL; |
2877 | frames = bytes_to_samples(runtime, _vector->iov_len); | 2877 | frames = bytes_to_samples(runtime, iov->iov_len); |
2878 | bufs = kmalloc(sizeof(void *) * count, GFP_KERNEL); | 2878 | bufs = kmalloc(sizeof(void *) * nr_segs, GFP_KERNEL); |
2879 | if (bufs == NULL) | 2879 | if (bufs == NULL) |
2880 | return -ENOMEM; | 2880 | return -ENOMEM; |
2881 | for (i = 0; i < count; ++i) | 2881 | for (i = 0; i < nr_segs; ++i) |
2882 | bufs[i] = _vector[i].iov_base; | 2882 | bufs[i] = iov[i].iov_base; |
2883 | result = snd_pcm_lib_readv(substream, bufs, frames); | 2883 | result = snd_pcm_lib_readv(substream, bufs, frames); |
2884 | if (result > 0) | 2884 | if (result > 0) |
2885 | result = frames_to_bytes(runtime, result); | 2885 | result = frames_to_bytes(runtime, result); |
@@ -2887,8 +2887,8 @@ static ssize_t snd_pcm_readv(struct file *file, const struct iovec *_vector, | |||
2887 | return result; | 2887 | return result; |
2888 | } | 2888 | } |
2889 | 2889 | ||
2890 | static ssize_t snd_pcm_writev(struct file *file, const struct iovec *_vector, | 2890 | static ssize_t snd_pcm_aio_write(struct kiocb *iocb, const struct iovec *iov, |
2891 | unsigned long count, loff_t * offset) | 2891 | unsigned long nr_segs, loff_t pos) |
2892 | { | 2892 | { |
2893 | struct snd_pcm_file *pcm_file; | 2893 | struct snd_pcm_file *pcm_file; |
2894 | struct snd_pcm_substream *substream; | 2894 | struct snd_pcm_substream *substream; |
@@ -2898,7 +2898,7 @@ static ssize_t snd_pcm_writev(struct file *file, const struct iovec *_vector, | |||
2898 | void __user **bufs; | 2898 | void __user **bufs; |
2899 | snd_pcm_uframes_t frames; | 2899 | snd_pcm_uframes_t frames; |
2900 | 2900 | ||
2901 | pcm_file = file->private_data; | 2901 | pcm_file = iocb->ki_filp->private_data; |
2902 | substream = pcm_file->substream; | 2902 | substream = pcm_file->substream; |
2903 | snd_assert(substream != NULL, result = -ENXIO; goto end); | 2903 | snd_assert(substream != NULL, result = -ENXIO; goto end); |
2904 | runtime = substream->runtime; | 2904 | runtime = substream->runtime; |
@@ -2906,17 +2906,17 @@ static ssize_t snd_pcm_writev(struct file *file, const struct iovec *_vector, | |||
2906 | result = -EBADFD; | 2906 | result = -EBADFD; |
2907 | goto end; | 2907 | goto end; |
2908 | } | 2908 | } |
2909 | if (count > 128 || count != runtime->channels || | 2909 | if (nr_segs > 128 || nr_segs != runtime->channels || |
2910 | !frame_aligned(runtime, _vector->iov_len)) { | 2910 | !frame_aligned(runtime, iov->iov_len)) { |
2911 | result = -EINVAL; | 2911 | result = -EINVAL; |
2912 | goto end; | 2912 | goto end; |
2913 | } | 2913 | } |
2914 | frames = bytes_to_samples(runtime, _vector->iov_len); | 2914 | frames = bytes_to_samples(runtime, iov->iov_len); |
2915 | bufs = kmalloc(sizeof(void *) * count, GFP_KERNEL); | 2915 | bufs = kmalloc(sizeof(void *) * nr_segs, GFP_KERNEL); |
2916 | if (bufs == NULL) | 2916 | if (bufs == NULL) |
2917 | return -ENOMEM; | 2917 | return -ENOMEM; |
2918 | for (i = 0; i < count; ++i) | 2918 | for (i = 0; i < nr_segs; ++i) |
2919 | bufs[i] = _vector[i].iov_base; | 2919 | bufs[i] = iov[i].iov_base; |
2920 | result = snd_pcm_lib_writev(substream, bufs, frames); | 2920 | result = snd_pcm_lib_writev(substream, bufs, frames); |
2921 | if (result > 0) | 2921 | if (result > 0) |
2922 | result = frames_to_bytes(runtime, result); | 2922 | result = frames_to_bytes(runtime, result); |
@@ -3426,7 +3426,7 @@ struct file_operations snd_pcm_f_ops[2] = { | |||
3426 | { | 3426 | { |
3427 | .owner = THIS_MODULE, | 3427 | .owner = THIS_MODULE, |
3428 | .write = snd_pcm_write, | 3428 | .write = snd_pcm_write, |
3429 | .writev = snd_pcm_writev, | 3429 | .aio_write = snd_pcm_aio_write, |
3430 | .open = snd_pcm_playback_open, | 3430 | .open = snd_pcm_playback_open, |
3431 | .release = snd_pcm_release, | 3431 | .release = snd_pcm_release, |
3432 | .poll = snd_pcm_playback_poll, | 3432 | .poll = snd_pcm_playback_poll, |
@@ -3438,7 +3438,7 @@ struct file_operations snd_pcm_f_ops[2] = { | |||
3438 | { | 3438 | { |
3439 | .owner = THIS_MODULE, | 3439 | .owner = THIS_MODULE, |
3440 | .read = snd_pcm_read, | 3440 | .read = snd_pcm_read, |
3441 | .readv = snd_pcm_readv, | 3441 | .aio_read = snd_pcm_aio_read, |
3442 | .open = snd_pcm_capture_open, | 3442 | .open = snd_pcm_capture_open, |
3443 | .release = snd_pcm_release, | 3443 | .release = snd_pcm_release, |
3444 | .poll = snd_pcm_capture_poll, | 3444 | .poll = snd_pcm_capture_poll, |