|
@@ -1149,13 +1149,14 @@ success:
|
|
* that can use the page cache directly.
|
|
* that can use the page cache directly.
|
|
*/
|
|
*/
|
|
ssize_t
|
|
ssize_t
|
|
-__generic_file_aio_read(struct kiocb *iocb, const struct iovec *iov,
|
|
|
|
- unsigned long nr_segs, loff_t *ppos)
|
|
|
|
|
|
+generic_file_aio_read(struct kiocb *iocb, const struct iovec *iov,
|
|
|
|
+ unsigned long nr_segs, loff_t pos)
|
|
{
|
|
{
|
|
struct file *filp = iocb->ki_filp;
|
|
struct file *filp = iocb->ki_filp;
|
|
ssize_t retval;
|
|
ssize_t retval;
|
|
unsigned long seg;
|
|
unsigned long seg;
|
|
size_t count;
|
|
size_t count;
|
|
|
|
+ loff_t *ppos = &iocb->ki_pos;
|
|
|
|
|
|
count = 0;
|
|
count = 0;
|
|
for (seg = 0; seg < nr_segs; seg++) {
|
|
for (seg = 0; seg < nr_segs; seg++) {
|
|
@@ -1179,7 +1180,7 @@ __generic_file_aio_read(struct kiocb *iocb, const struct iovec *iov,
|
|
|
|
|
|
/* coalesce the iovecs and go direct-to-BIO for O_DIRECT */
|
|
/* coalesce the iovecs and go direct-to-BIO for O_DIRECT */
|
|
if (filp->f_flags & O_DIRECT) {
|
|
if (filp->f_flags & O_DIRECT) {
|
|
- loff_t pos = *ppos, size;
|
|
|
|
|
|
+ loff_t size;
|
|
struct address_space *mapping;
|
|
struct address_space *mapping;
|
|
struct inode *inode;
|
|
struct inode *inode;
|
|
|
|
|
|
@@ -1223,32 +1224,8 @@ __generic_file_aio_read(struct kiocb *iocb, const struct iovec *iov,
|
|
out:
|
|
out:
|
|
return retval;
|
|
return retval;
|
|
}
|
|
}
|
|
-EXPORT_SYMBOL(__generic_file_aio_read);
|
|
|
|
-
|
|
|
|
-ssize_t
|
|
|
|
-generic_file_aio_read(struct kiocb *iocb, const struct iovec *iov,
|
|
|
|
- unsigned long nr_segs, loff_t pos)
|
|
|
|
-{
|
|
|
|
- BUG_ON(iocb->ki_pos != pos);
|
|
|
|
- return __generic_file_aio_read(iocb, iov, nr_segs, &iocb->ki_pos);
|
|
|
|
-}
|
|
|
|
EXPORT_SYMBOL(generic_file_aio_read);
|
|
EXPORT_SYMBOL(generic_file_aio_read);
|
|
|
|
|
|
-ssize_t
|
|
|
|
-generic_file_read(struct file *filp, char __user *buf, size_t count, loff_t *ppos)
|
|
|
|
-{
|
|
|
|
- struct iovec local_iov = { .iov_base = buf, .iov_len = count };
|
|
|
|
- struct kiocb kiocb;
|
|
|
|
- ssize_t ret;
|
|
|
|
-
|
|
|
|
- init_sync_kiocb(&kiocb, filp);
|
|
|
|
- ret = __generic_file_aio_read(&kiocb, &local_iov, 1, ppos);
|
|
|
|
- if (-EIOCBQUEUED == ret)
|
|
|
|
- ret = wait_on_sync_kiocb(&kiocb);
|
|
|
|
- return ret;
|
|
|
|
-}
|
|
|
|
-EXPORT_SYMBOL(generic_file_read);
|
|
|
|
-
|
|
|
|
int file_send_actor(read_descriptor_t * desc, struct page *page, unsigned long offset, unsigned long size)
|
|
int file_send_actor(read_descriptor_t * desc, struct page *page, unsigned long offset, unsigned long size)
|
|
{
|
|
{
|
|
ssize_t written;
|
|
ssize_t written;
|
|
@@ -2339,38 +2316,6 @@ ssize_t generic_file_aio_write_nolock(struct kiocb *iocb,
|
|
}
|
|
}
|
|
EXPORT_SYMBOL(generic_file_aio_write_nolock);
|
|
EXPORT_SYMBOL(generic_file_aio_write_nolock);
|
|
|
|
|
|
-static ssize_t
|
|
|
|
-__generic_file_write_nolock(struct file *file, const struct iovec *iov,
|
|
|
|
- unsigned long nr_segs, loff_t *ppos)
|
|
|
|
-{
|
|
|
|
- struct kiocb kiocb;
|
|
|
|
- ssize_t ret;
|
|
|
|
-
|
|
|
|
- init_sync_kiocb(&kiocb, file);
|
|
|
|
- kiocb.ki_pos = *ppos;
|
|
|
|
- ret = __generic_file_aio_write_nolock(&kiocb, iov, nr_segs, ppos);
|
|
|
|
- if (-EIOCBQUEUED == ret)
|
|
|
|
- ret = wait_on_sync_kiocb(&kiocb);
|
|
|
|
- return ret;
|
|
|
|
-}
|
|
|
|
-
|
|
|
|
-ssize_t
|
|
|
|
-generic_file_write_nolock(struct file *file, const struct iovec *iov,
|
|
|
|
- unsigned long nr_segs, loff_t *ppos)
|
|
|
|
-{
|
|
|
|
- struct kiocb kiocb;
|
|
|
|
- ssize_t ret;
|
|
|
|
-
|
|
|
|
- init_sync_kiocb(&kiocb, file);
|
|
|
|
- kiocb.ki_pos = *ppos;
|
|
|
|
- ret = generic_file_aio_write_nolock(&kiocb, iov, nr_segs, *ppos);
|
|
|
|
- if (-EIOCBQUEUED == ret)
|
|
|
|
- ret = wait_on_sync_kiocb(&kiocb);
|
|
|
|
- *ppos = kiocb.ki_pos;
|
|
|
|
- return ret;
|
|
|
|
-}
|
|
|
|
-EXPORT_SYMBOL(generic_file_write_nolock);
|
|
|
|
-
|
|
|
|
ssize_t generic_file_aio_write(struct kiocb *iocb, const struct iovec *iov,
|
|
ssize_t generic_file_aio_write(struct kiocb *iocb, const struct iovec *iov,
|
|
unsigned long nr_segs, loff_t pos)
|
|
unsigned long nr_segs, loff_t pos)
|
|
{
|
|
{
|
|
@@ -2397,30 +2342,6 @@ ssize_t generic_file_aio_write(struct kiocb *iocb, const struct iovec *iov,
|
|
}
|
|
}
|
|
EXPORT_SYMBOL(generic_file_aio_write);
|
|
EXPORT_SYMBOL(generic_file_aio_write);
|
|
|
|
|
|
-ssize_t generic_file_write(struct file *file, const char __user *buf,
|
|
|
|
- size_t count, loff_t *ppos)
|
|
|
|
-{
|
|
|
|
- struct address_space *mapping = file->f_mapping;
|
|
|
|
- struct inode *inode = mapping->host;
|
|
|
|
- ssize_t ret;
|
|
|
|
- struct iovec local_iov = { .iov_base = (void __user *)buf,
|
|
|
|
- .iov_len = count };
|
|
|
|
-
|
|
|
|
- mutex_lock(&inode->i_mutex);
|
|
|
|
- ret = __generic_file_write_nolock(file, &local_iov, 1, ppos);
|
|
|
|
- mutex_unlock(&inode->i_mutex);
|
|
|
|
-
|
|
|
|
- if (ret > 0 && ((file->f_flags & O_SYNC) || IS_SYNC(inode))) {
|
|
|
|
- ssize_t err;
|
|
|
|
-
|
|
|
|
- err = sync_page_range(inode, mapping, *ppos - ret, ret);
|
|
|
|
- if (err < 0)
|
|
|
|
- ret = err;
|
|
|
|
- }
|
|
|
|
- return ret;
|
|
|
|
-}
|
|
|
|
-EXPORT_SYMBOL(generic_file_write);
|
|
|
|
-
|
|
|
|
/*
|
|
/*
|
|
* Called under i_mutex for writes to S_ISREG files. Returns -EIO if something
|
|
* Called under i_mutex for writes to S_ISREG files. Returns -EIO if something
|
|
* went wrong during pagecache shootdown.
|
|
* went wrong during pagecache shootdown.
|