diff options
author | Christoph Hellwig <hch@lst.de> | 2015-01-25 15:11:59 -0500 |
---|---|---|
committer | Al Viro <viro@zeniv.linux.org.uk> | 2015-01-29 00:13:13 -0500 |
commit | dbe4e192a234cd6133d86fffb965d0f032c12ccc (patch) | |
tree | e5b5bbc9b22a289ec33fbc808f7e81d926caec06 /fs/read_write.c | |
parent | 05afcb77eb4713f46e7ebaa3cb54bc465c5d516e (diff) |
fs: add vfs_iter_{read,write} helpers
Simple helpers that pass an arbitrary iov_iter to filesystems.
Signed-off-by: Christoph Hellwig <hch@lst.de>
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
Diffstat (limited to 'fs/read_write.c')
-rw-r--r-- | fs/read_write.c | 46 |
1 files changed, 46 insertions, 0 deletions
diff --git a/fs/read_write.c b/fs/read_write.c index c0805c93b6fa..ab4f26a7d5cb 100644 --- a/fs/read_write.c +++ b/fs/read_write.c | |||
@@ -333,6 +333,52 @@ out_putf: | |||
333 | } | 333 | } |
334 | #endif | 334 | #endif |
335 | 335 | ||
336 | ssize_t vfs_iter_read(struct file *file, struct iov_iter *iter, loff_t *ppos) | ||
337 | { | ||
338 | struct kiocb kiocb; | ||
339 | ssize_t ret; | ||
340 | |||
341 | if (!file->f_op->read_iter) | ||
342 | return -EINVAL; | ||
343 | |||
344 | init_sync_kiocb(&kiocb, file); | ||
345 | kiocb.ki_pos = *ppos; | ||
346 | kiocb.ki_nbytes = iov_iter_count(iter); | ||
347 | |||
348 | iter->type |= READ; | ||
349 | ret = file->f_op->read_iter(&kiocb, iter); | ||
350 | if (ret == -EIOCBQUEUED) | ||
351 | ret = wait_on_sync_kiocb(&kiocb); | ||
352 | |||
353 | if (ret > 0) | ||
354 | *ppos = kiocb.ki_pos; | ||
355 | return ret; | ||
356 | } | ||
357 | EXPORT_SYMBOL(vfs_iter_read); | ||
358 | |||
359 | ssize_t vfs_iter_write(struct file *file, struct iov_iter *iter, loff_t *ppos) | ||
360 | { | ||
361 | struct kiocb kiocb; | ||
362 | ssize_t ret; | ||
363 | |||
364 | if (!file->f_op->write_iter) | ||
365 | return -EINVAL; | ||
366 | |||
367 | init_sync_kiocb(&kiocb, file); | ||
368 | kiocb.ki_pos = *ppos; | ||
369 | kiocb.ki_nbytes = iov_iter_count(iter); | ||
370 | |||
371 | iter->type |= WRITE; | ||
372 | ret = file->f_op->write_iter(&kiocb, iter); | ||
373 | if (ret == -EIOCBQUEUED) | ||
374 | ret = wait_on_sync_kiocb(&kiocb); | ||
375 | |||
376 | if (ret > 0) | ||
377 | *ppos = kiocb.ki_pos; | ||
378 | return ret; | ||
379 | } | ||
380 | EXPORT_SYMBOL(vfs_iter_write); | ||
381 | |||
336 | /* | 382 | /* |
337 | * rw_verify_area doesn't like huge counts. We limit | 383 | * rw_verify_area doesn't like huge counts. We limit |
338 | * them to something that fits in "int" so that others | 384 | * them to something that fits in "int" so that others |