write_iter variants of {__,}generic_file_aio_write()

Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
This commit is contained in:
Al Viro 2014-04-03 03:17:43 -04:00
parent 3644424dc6
commit 8174202b34
29 changed files with 94 additions and 79 deletions

View File

@ -763,7 +763,7 @@ err_out:
buff_write: buff_write:
mutex_unlock(&inode->i_mutex); mutex_unlock(&inode->i_mutex);
return do_sync_write(filp, data, count, offsetp); return new_sync_write(filp, data, count, offsetp);
} }
/** /**
@ -781,7 +781,7 @@ v9fs_cached_file_write(struct file *filp, const char __user * data,
if (filp->f_flags & O_DIRECT) if (filp->f_flags & O_DIRECT)
return v9fs_direct_write(filp, data, count, offset); return v9fs_direct_write(filp, data, count, offset);
return do_sync_write(filp, data, count, offset); return new_sync_write(filp, data, count, offset);
} }
@ -851,7 +851,7 @@ const struct file_operations v9fs_cached_file_operations = {
.read = v9fs_cached_file_read, .read = v9fs_cached_file_read,
.write = v9fs_cached_file_write, .write = v9fs_cached_file_write,
.read_iter = generic_file_read_iter, .read_iter = generic_file_read_iter,
.aio_write = generic_file_aio_write, .write_iter = generic_file_write_iter,
.open = v9fs_file_open, .open = v9fs_file_open,
.release = v9fs_dir_release, .release = v9fs_dir_release,
.lock = v9fs_file_lock, .lock = v9fs_file_lock,
@ -864,7 +864,7 @@ const struct file_operations v9fs_cached_file_operations_dotl = {
.read = v9fs_cached_file_read, .read = v9fs_cached_file_read,
.write = v9fs_cached_file_write, .write = v9fs_cached_file_write,
.read_iter = generic_file_read_iter, .read_iter = generic_file_read_iter,
.aio_write = generic_file_aio_write, .write_iter = generic_file_write_iter,
.open = v9fs_file_open, .open = v9fs_file_open,
.release = v9fs_dir_release, .release = v9fs_dir_release,
.lock = v9fs_file_lock_dotl, .lock = v9fs_file_lock_dotl,

View File

@ -27,8 +27,8 @@ const struct file_operations adfs_file_operations = {
.read_iter = generic_file_read_iter, .read_iter = generic_file_read_iter,
.mmap = generic_file_mmap, .mmap = generic_file_mmap,
.fsync = generic_file_fsync, .fsync = generic_file_fsync,
.write = do_sync_write, .write = new_sync_write,
.aio_write = generic_file_aio_write, .write_iter = generic_file_write_iter,
.splice_read = generic_file_splice_read, .splice_read = generic_file_splice_read,
}; };

View File

@ -29,8 +29,8 @@ const struct file_operations affs_file_operations = {
.llseek = generic_file_llseek, .llseek = generic_file_llseek,
.read = new_sync_read, .read = new_sync_read,
.read_iter = generic_file_read_iter, .read_iter = generic_file_read_iter,
.write = do_sync_write, .write = new_sync_write,
.aio_write = generic_file_aio_write, .write_iter = generic_file_write_iter,
.mmap = generic_file_mmap, .mmap = generic_file_mmap,
.open = affs_file_open, .open = affs_file_open,
.release = affs_file_release, .release = affs_file_release,

View File

@ -25,8 +25,8 @@ const struct file_operations bfs_file_operations = {
.llseek = generic_file_llseek, .llseek = generic_file_llseek,
.read = new_sync_read, .read = new_sync_read,
.read_iter = generic_file_read_iter, .read_iter = generic_file_read_iter,
.write = do_sync_write, .write = new_sync_write,
.aio_write = generic_file_aio_write, .write_iter = generic_file_write_iter,
.mmap = generic_file_mmap, .mmap = generic_file_mmap,
.splice_read = generic_file_splice_read, .splice_read = generic_file_splice_read,
}; };

View File

@ -353,8 +353,8 @@ const struct file_operations ecryptfs_main_fops = {
.llseek = generic_file_llseek, .llseek = generic_file_llseek,
.read = new_sync_read, .read = new_sync_read,
.read_iter = ecryptfs_read_update_atime, .read_iter = ecryptfs_read_update_atime,
.write = do_sync_write, .write = new_sync_write,
.aio_write = generic_file_aio_write, .write_iter = generic_file_write_iter,
.iterate = ecryptfs_readdir, .iterate = ecryptfs_readdir,
.unlocked_ioctl = ecryptfs_unlocked_ioctl, .unlocked_ioctl = ecryptfs_unlocked_ioctl,
#ifdef CONFIG_COMPAT #ifdef CONFIG_COMPAT

View File

@ -68,9 +68,9 @@ static int exofs_flush(struct file *file, fl_owner_t id)
const struct file_operations exofs_file_operations = { const struct file_operations exofs_file_operations = {
.llseek = generic_file_llseek, .llseek = generic_file_llseek,
.read = new_sync_read, .read = new_sync_read,
.write = do_sync_write, .write = new_sync_write,
.read_iter = generic_file_read_iter, .read_iter = generic_file_read_iter,
.aio_write = generic_file_aio_write, .write_iter = generic_file_write_iter,
.mmap = generic_file_mmap, .mmap = generic_file_mmap,
.open = generic_file_open, .open = generic_file_open,
.release = exofs_release_file, .release = exofs_release_file,

View File

@ -63,9 +63,9 @@ int ext2_fsync(struct file *file, loff_t start, loff_t end, int datasync)
const struct file_operations ext2_file_operations = { const struct file_operations ext2_file_operations = {
.llseek = generic_file_llseek, .llseek = generic_file_llseek,
.read = new_sync_read, .read = new_sync_read,
.write = do_sync_write, .write = new_sync_write,
.read_iter = generic_file_read_iter, .read_iter = generic_file_read_iter,
.aio_write = generic_file_aio_write, .write_iter = generic_file_write_iter,
.unlocked_ioctl = ext2_ioctl, .unlocked_ioctl = ext2_ioctl,
#ifdef CONFIG_COMPAT #ifdef CONFIG_COMPAT
.compat_ioctl = ext2_compat_ioctl, .compat_ioctl = ext2_compat_ioctl,

View File

@ -51,9 +51,9 @@ static int ext3_release_file (struct inode * inode, struct file * filp)
const struct file_operations ext3_file_operations = { const struct file_operations ext3_file_operations = {
.llseek = generic_file_llseek, .llseek = generic_file_llseek,
.read = new_sync_read, .read = new_sync_read,
.write = do_sync_write, .write = new_sync_write,
.read_iter = generic_file_read_iter, .read_iter = generic_file_read_iter,
.aio_write = generic_file_aio_write, .write_iter = generic_file_write_iter,
.unlocked_ioctl = ext3_ioctl, .unlocked_ioctl = ext3_ioctl,
#ifdef CONFIG_COMPAT #ifdef CONFIG_COMPAT
.compat_ioctl = ext3_compat_ioctl, .compat_ioctl = ext3_compat_ioctl,

View File

@ -680,9 +680,9 @@ long f2fs_compat_ioctl(struct file *file, unsigned int cmd, unsigned long arg)
const struct file_operations f2fs_file_operations = { const struct file_operations f2fs_file_operations = {
.llseek = generic_file_llseek, .llseek = generic_file_llseek,
.read = new_sync_read, .read = new_sync_read,
.write = do_sync_write, .write = new_sync_write,
.read_iter = generic_file_read_iter, .read_iter = generic_file_read_iter,
.aio_write = generic_file_aio_write, .write_iter = generic_file_write_iter,
.open = generic_file_open, .open = generic_file_open,
.mmap = f2fs_file_mmap, .mmap = f2fs_file_mmap,
.fsync = f2fs_sync_file, .fsync = f2fs_sync_file,

View File

@ -171,9 +171,9 @@ int fat_file_fsync(struct file *filp, loff_t start, loff_t end, int datasync)
const struct file_operations fat_file_operations = { const struct file_operations fat_file_operations = {
.llseek = generic_file_llseek, .llseek = generic_file_llseek,
.read = new_sync_read, .read = new_sync_read,
.write = do_sync_write, .write = new_sync_write,
.read_iter = generic_file_read_iter, .read_iter = generic_file_read_iter,
.aio_write = generic_file_aio_write, .write_iter = generic_file_write_iter,
.mmap = generic_file_mmap, .mmap = generic_file_mmap,
.release = fat_file_release, .release = fat_file_release,
.unlocked_ioctl = fat_generic_ioctl, .unlocked_ioctl = fat_generic_ioctl,

View File

@ -676,8 +676,8 @@ static const struct file_operations hfs_file_operations = {
.llseek = generic_file_llseek, .llseek = generic_file_llseek,
.read = new_sync_read, .read = new_sync_read,
.read_iter = generic_file_read_iter, .read_iter = generic_file_read_iter,
.write = do_sync_write, .write = new_sync_write,
.aio_write = generic_file_aio_write, .write_iter = generic_file_write_iter,
.mmap = generic_file_mmap, .mmap = generic_file_mmap,
.splice_read = generic_file_splice_read, .splice_read = generic_file_splice_read,
.fsync = hfs_file_fsync, .fsync = hfs_file_fsync,

View File

@ -343,8 +343,8 @@ static const struct file_operations hfsplus_file_operations = {
.llseek = generic_file_llseek, .llseek = generic_file_llseek,
.read = new_sync_read, .read = new_sync_read,
.read_iter = generic_file_read_iter, .read_iter = generic_file_read_iter,
.write = do_sync_write, .write = new_sync_write,
.aio_write = generic_file_aio_write, .write_iter = generic_file_write_iter,
.mmap = generic_file_mmap, .mmap = generic_file_mmap,
.splice_read = generic_file_splice_read, .splice_read = generic_file_splice_read,
.fsync = hfsplus_file_fsync, .fsync = hfsplus_file_fsync,

View File

@ -381,8 +381,8 @@ static const struct file_operations hostfs_file_fops = {
.read = new_sync_read, .read = new_sync_read,
.splice_read = generic_file_splice_read, .splice_read = generic_file_splice_read,
.read_iter = generic_file_read_iter, .read_iter = generic_file_read_iter,
.aio_write = generic_file_aio_write, .write_iter = generic_file_write_iter,
.write = do_sync_write, .write = new_sync_write,
.mmap = generic_file_mmap, .mmap = generic_file_mmap,
.open = hostfs_file_open, .open = hostfs_file_open,
.release = hostfs_file_release, .release = hostfs_file_release,

View File

@ -199,8 +199,8 @@ const struct file_operations hpfs_file_ops =
.llseek = generic_file_llseek, .llseek = generic_file_llseek,
.read = new_sync_read, .read = new_sync_read,
.read_iter = generic_file_read_iter, .read_iter = generic_file_read_iter,
.write = do_sync_write, .write = new_sync_write,
.aio_write = generic_file_aio_write, .write_iter = generic_file_write_iter,
.mmap = generic_file_mmap, .mmap = generic_file_mmap,
.release = hpfs_file_release, .release = hpfs_file_release,
.fsync = hpfs_file_fsync, .fsync = hpfs_file_fsync,

View File

@ -53,8 +53,8 @@ const struct file_operations jffs2_file_operations =
.open = generic_file_open, .open = generic_file_open,
.read = new_sync_read, .read = new_sync_read,
.read_iter = generic_file_read_iter, .read_iter = generic_file_read_iter,
.write = do_sync_write, .write = new_sync_write,
.aio_write = generic_file_aio_write, .write_iter = generic_file_write_iter,
.unlocked_ioctl=jffs2_ioctl, .unlocked_ioctl=jffs2_ioctl,
.mmap = generic_file_readonly_mmap, .mmap = generic_file_readonly_mmap,
.fsync = jffs2_fsync, .fsync = jffs2_fsync,

View File

@ -151,10 +151,10 @@ const struct inode_operations jfs_file_inode_operations = {
const struct file_operations jfs_file_operations = { const struct file_operations jfs_file_operations = {
.open = jfs_open, .open = jfs_open,
.llseek = generic_file_llseek, .llseek = generic_file_llseek,
.write = do_sync_write, .write = new_sync_write,
.read = new_sync_read, .read = new_sync_read,
.read_iter = generic_file_read_iter, .read_iter = generic_file_read_iter,
.aio_write = generic_file_aio_write, .write_iter = generic_file_write_iter,
.mmap = generic_file_mmap, .mmap = generic_file_mmap,
.splice_read = generic_file_splice_read, .splice_read = generic_file_splice_read,
.splice_write = generic_file_splice_write, .splice_write = generic_file_splice_write,

View File

@ -265,14 +265,14 @@ const struct inode_operations logfs_reg_iops = {
const struct file_operations logfs_reg_fops = { const struct file_operations logfs_reg_fops = {
.read_iter = generic_file_read_iter, .read_iter = generic_file_read_iter,
.aio_write = generic_file_aio_write, .write_iter = generic_file_write_iter,
.fsync = logfs_fsync, .fsync = logfs_fsync,
.unlocked_ioctl = logfs_ioctl, .unlocked_ioctl = logfs_ioctl,
.llseek = generic_file_llseek, .llseek = generic_file_llseek,
.mmap = generic_file_readonly_mmap, .mmap = generic_file_readonly_mmap,
.open = generic_file_open, .open = generic_file_open,
.read = new_sync_read, .read = new_sync_read,
.write = do_sync_write, .write = new_sync_write,
}; };
const struct address_space_operations logfs_reg_aops = { const struct address_space_operations logfs_reg_aops = {

View File

@ -16,8 +16,8 @@ const struct file_operations minix_file_operations = {
.llseek = generic_file_llseek, .llseek = generic_file_llseek,
.read = new_sync_read, .read = new_sync_read,
.read_iter = generic_file_read_iter, .read_iter = generic_file_read_iter,
.write = do_sync_write, .write = new_sync_write,
.aio_write = generic_file_aio_write, .write_iter = generic_file_write_iter,
.mmap = generic_file_mmap, .mmap = generic_file_mmap,
.fsync = generic_file_fsync, .fsync = generic_file_fsync,
.splice_read = generic_file_splice_read, .splice_read = generic_file_splice_read,

View File

@ -153,9 +153,9 @@ static int nilfs_file_mmap(struct file *file, struct vm_area_struct *vma)
const struct file_operations nilfs_file_operations = { const struct file_operations nilfs_file_operations = {
.llseek = generic_file_llseek, .llseek = generic_file_llseek,
.read = new_sync_read, .read = new_sync_read,
.write = do_sync_write, .write = new_sync_write,
.read_iter = generic_file_read_iter, .read_iter = generic_file_read_iter,
.aio_write = generic_file_aio_write, .write_iter = generic_file_write_iter,
.unlocked_ioctl = nilfs_ioctl, .unlocked_ioctl = nilfs_ioctl,
#ifdef CONFIG_COMPAT #ifdef CONFIG_COMPAT
.compat_ioctl = nilfs_compat_ioctl, .compat_ioctl = nilfs_compat_ioctl,

View File

@ -338,9 +338,9 @@ static sector_t omfs_bmap(struct address_space *mapping, sector_t block)
const struct file_operations omfs_file_operations = { const struct file_operations omfs_file_operations = {
.llseek = generic_file_llseek, .llseek = generic_file_llseek,
.read = new_sync_read, .read = new_sync_read,
.write = do_sync_write, .write = new_sync_write,
.read_iter = generic_file_read_iter, .read_iter = generic_file_read_iter,
.aio_write = generic_file_aio_write, .write_iter = generic_file_write_iter,
.mmap = generic_file_mmap, .mmap = generic_file_mmap,
.fsync = generic_file_fsync, .fsync = generic_file_fsync,
.splice_read = generic_file_splice_read, .splice_read = generic_file_splice_read,

View File

@ -33,8 +33,8 @@
const struct file_operations ramfs_file_operations = { const struct file_operations ramfs_file_operations = {
.read = new_sync_read, .read = new_sync_read,
.read_iter = generic_file_read_iter, .read_iter = generic_file_read_iter,
.write = do_sync_write, .write = new_sync_write,
.aio_write = generic_file_aio_write, .write_iter = generic_file_write_iter,
.mmap = generic_file_mmap, .mmap = generic_file_mmap,
.fsync = noop_fsync, .fsync = noop_fsync,
.splice_read = generic_file_splice_read, .splice_read = generic_file_splice_read,

View File

@ -39,8 +39,8 @@ const struct file_operations ramfs_file_operations = {
.get_unmapped_area = ramfs_nommu_get_unmapped_area, .get_unmapped_area = ramfs_nommu_get_unmapped_area,
.read = new_sync_read, .read = new_sync_read,
.read_iter = generic_file_read_iter, .read_iter = generic_file_read_iter,
.write = do_sync_write, .write = new_sync_write,
.aio_write = generic_file_aio_write, .write_iter = generic_file_write_iter,
.fsync = noop_fsync, .fsync = noop_fsync,
.splice_read = generic_file_splice_read, .splice_read = generic_file_splice_read,
.splice_write = generic_file_splice_write, .splice_write = generic_file_splice_write,

View File

@ -236,7 +236,7 @@ int reiserfs_commit_page(struct inode *inode, struct page *page,
const struct file_operations reiserfs_file_operations = { const struct file_operations reiserfs_file_operations = {
.read = new_sync_read, .read = new_sync_read,
.write = do_sync_write, .write = new_sync_write,
.unlocked_ioctl = reiserfs_ioctl, .unlocked_ioctl = reiserfs_ioctl,
#ifdef CONFIG_COMPAT #ifdef CONFIG_COMPAT
.compat_ioctl = reiserfs_compat_ioctl, .compat_ioctl = reiserfs_compat_ioctl,
@ -246,7 +246,7 @@ const struct file_operations reiserfs_file_operations = {
.release = reiserfs_file_release, .release = reiserfs_file_release,
.fsync = reiserfs_sync_file, .fsync = reiserfs_sync_file,
.read_iter = generic_file_read_iter, .read_iter = generic_file_read_iter,
.aio_write = generic_file_aio_write, .write_iter = generic_file_write_iter,
.splice_read = generic_file_splice_read, .splice_read = generic_file_splice_read,
.splice_write = generic_file_splice_write, .splice_write = generic_file_splice_write,
.llseek = generic_file_llseek, .llseek = generic_file_llseek,

View File

@ -23,8 +23,8 @@ const struct file_operations sysv_file_operations = {
.llseek = generic_file_llseek, .llseek = generic_file_llseek,
.read = new_sync_read, .read = new_sync_read,
.read_iter = generic_file_read_iter, .read_iter = generic_file_read_iter,
.write = do_sync_write, .write = new_sync_write,
.aio_write = generic_file_aio_write, .write_iter = generic_file_write_iter,
.mmap = generic_file_mmap, .mmap = generic_file_mmap,
.fsync = generic_file_fsync, .fsync = generic_file_fsync,
.splice_read = generic_file_splice_read, .splice_read = generic_file_splice_read,

View File

@ -37,8 +37,8 @@ const struct file_operations ufs_file_operations = {
.llseek = generic_file_llseek, .llseek = generic_file_llseek,
.read = new_sync_read, .read = new_sync_read,
.read_iter = generic_file_read_iter, .read_iter = generic_file_read_iter,
.write = do_sync_write, .write = new_sync_write,
.aio_write = generic_file_aio_write, .write_iter = generic_file_write_iter,
.mmap = generic_file_mmap, .mmap = generic_file_mmap,
.open = generic_file_open, .open = generic_file_open,
.fsync = generic_file_fsync, .fsync = generic_file_fsync,

View File

@ -2414,7 +2414,9 @@ int generic_write_checks(struct file *file, loff_t *pos, size_t *count, int isbl
extern ssize_t generic_file_aio_read(struct kiocb *, const struct iovec *, unsigned long, loff_t); extern ssize_t generic_file_aio_read(struct kiocb *, const struct iovec *, unsigned long, loff_t);
extern ssize_t generic_file_read_iter(struct kiocb *, struct iov_iter *); extern ssize_t generic_file_read_iter(struct kiocb *, struct iov_iter *);
extern ssize_t __generic_file_aio_write(struct kiocb *, const struct iovec *, unsigned long); extern ssize_t __generic_file_aio_write(struct kiocb *, const struct iovec *, unsigned long);
extern ssize_t __generic_file_write_iter(struct kiocb *, struct iov_iter *);
extern ssize_t generic_file_aio_write(struct kiocb *, const struct iovec *, unsigned long, loff_t); extern ssize_t generic_file_aio_write(struct kiocb *, const struct iovec *, unsigned long, loff_t);
extern ssize_t generic_file_write_iter(struct kiocb *, struct iov_iter *);
extern ssize_t generic_file_direct_write(struct kiocb *, struct iov_iter *, loff_t); extern ssize_t generic_file_direct_write(struct kiocb *, struct iov_iter *, loff_t);
extern ssize_t generic_perform_write(struct file *, struct iov_iter *, loff_t); extern ssize_t generic_perform_write(struct file *, struct iov_iter *, loff_t);
extern ssize_t do_sync_read(struct file *filp, char __user *buf, size_t len, loff_t *ppos); extern ssize_t do_sync_read(struct file *filp, char __user *buf, size_t len, loff_t *ppos);

View File

@ -2542,10 +2542,9 @@ again:
EXPORT_SYMBOL(generic_perform_write); EXPORT_SYMBOL(generic_perform_write);
/** /**
* __generic_file_aio_write - write data to a file * __generic_file_write_iter - write data to a file
* @iocb: IO state structure (file, offset, etc.) * @iocb: IO state structure (file, offset, etc.)
* @iov: vector with data to write * @from: iov_iter with data to write
* @nr_segs: number of segments in the vector
* *
* This function does all the work needed for actually writing data to a * This function does all the work needed for actually writing data to a
* file. It does all basic checks, removes SUID from the file, updates * file. It does all basic checks, removes SUID from the file, updates
@ -2559,21 +2558,16 @@ EXPORT_SYMBOL(generic_perform_write);
* A caller has to handle it. This is mainly due to the fact that we want to * A caller has to handle it. This is mainly due to the fact that we want to
* avoid syncing under i_mutex. * avoid syncing under i_mutex.
*/ */
ssize_t __generic_file_aio_write(struct kiocb *iocb, const struct iovec *iov, ssize_t __generic_file_write_iter(struct kiocb *iocb, struct iov_iter *from)
unsigned long nr_segs)
{ {
struct file *file = iocb->ki_filp; struct file *file = iocb->ki_filp;
struct address_space * mapping = file->f_mapping; struct address_space * mapping = file->f_mapping;
size_t count; /* after file limit checks */
struct inode *inode = mapping->host; struct inode *inode = mapping->host;
loff_t pos = iocb->ki_pos; loff_t pos = iocb->ki_pos;
ssize_t written = 0; ssize_t written = 0;
ssize_t err; ssize_t err;
ssize_t status; ssize_t status;
struct iov_iter from; size_t count = iov_iter_count(from);
count = iov_length(iov, nr_segs);
iov_iter_init(&from, WRITE, iov, nr_segs, count);
/* We can write back this queue in page reclaim */ /* We can write back this queue in page reclaim */
current->backing_dev_info = mapping->backing_dev_info; current->backing_dev_info = mapping->backing_dev_info;
@ -2584,7 +2578,7 @@ ssize_t __generic_file_aio_write(struct kiocb *iocb, const struct iovec *iov,
if (count == 0) if (count == 0)
goto out; goto out;
iov_iter_truncate(&from, count); iov_iter_truncate(from, count);
err = file_remove_suid(file); err = file_remove_suid(file);
if (err) if (err)
@ -2598,7 +2592,7 @@ ssize_t __generic_file_aio_write(struct kiocb *iocb, const struct iovec *iov,
if (unlikely(file->f_flags & O_DIRECT)) { if (unlikely(file->f_flags & O_DIRECT)) {
loff_t endbyte; loff_t endbyte;
written = generic_file_direct_write(iocb, &from, pos); written = generic_file_direct_write(iocb, from, pos);
if (written < 0 || written == count) if (written < 0 || written == count)
goto out; goto out;
@ -2609,7 +2603,7 @@ ssize_t __generic_file_aio_write(struct kiocb *iocb, const struct iovec *iov,
pos += written; pos += written;
count -= written; count -= written;
status = generic_perform_write(file, &from, pos); status = generic_perform_write(file, from, pos);
/* /*
* If generic_perform_write() returned a synchronous error * If generic_perform_write() returned a synchronous error
* then we want to return the number of bytes which were * then we want to return the number of bytes which were
@ -2641,7 +2635,7 @@ ssize_t __generic_file_aio_write(struct kiocb *iocb, const struct iovec *iov,
*/ */
} }
} else { } else {
written = generic_perform_write(file, &from, pos); written = generic_perform_write(file, from, pos);
if (likely(written >= 0)) if (likely(written >= 0))
iocb->ki_pos = pos + written; iocb->ki_pos = pos + written;
} }
@ -2649,30 +2643,36 @@ out:
current->backing_dev_info = NULL; current->backing_dev_info = NULL;
return written ? written : err; return written ? written : err;
} }
EXPORT_SYMBOL(__generic_file_write_iter);
ssize_t __generic_file_aio_write(struct kiocb *iocb, const struct iovec *iov,
unsigned long nr_segs)
{
size_t count = iov_length(iov, nr_segs);
struct iov_iter from;
iov_iter_init(&from, WRITE, iov, nr_segs, count);
return __generic_file_write_iter(iocb, &from);
}
EXPORT_SYMBOL(__generic_file_aio_write); EXPORT_SYMBOL(__generic_file_aio_write);
/** /**
* generic_file_aio_write - write data to a file * generic_file_write_iter - write data to a file
* @iocb: IO state structure * @iocb: IO state structure
* @iov: vector with data to write * @from: iov_iter with data to write
* @nr_segs: number of segments in the vector
* @pos: position in file where to write
* *
* This is a wrapper around __generic_file_aio_write() to be used by most * This is a wrapper around __generic_file_write_iter() to be used by most
* filesystems. It takes care of syncing the file in case of O_SYNC file * filesystems. It takes care of syncing the file in case of O_SYNC file
* and acquires i_mutex as needed. * and acquires i_mutex as needed.
*/ */
ssize_t generic_file_aio_write(struct kiocb *iocb, const struct iovec *iov, ssize_t generic_file_write_iter(struct kiocb *iocb, struct iov_iter *from)
unsigned long nr_segs, loff_t pos)
{ {
struct file *file = iocb->ki_filp; struct file *file = iocb->ki_filp;
struct inode *inode = file->f_mapping->host; struct inode *inode = file->f_mapping->host;
ssize_t ret; ssize_t ret;
BUG_ON(iocb->ki_pos != pos);
mutex_lock(&inode->i_mutex); mutex_lock(&inode->i_mutex);
ret = __generic_file_aio_write(iocb, iov, nr_segs); ret = __generic_file_write_iter(iocb, from);
mutex_unlock(&inode->i_mutex); mutex_unlock(&inode->i_mutex);
if (ret > 0) { if (ret > 0) {
@ -2684,6 +2684,19 @@ ssize_t generic_file_aio_write(struct kiocb *iocb, const struct iovec *iov,
} }
return ret; return ret;
} }
EXPORT_SYMBOL(generic_file_write_iter);
ssize_t generic_file_aio_write(struct kiocb *iocb, const struct iovec *iov,
unsigned long nr_segs, loff_t pos)
{
size_t count = iov_length(iov, nr_segs);
struct iov_iter from;
BUG_ON(iocb->ki_pos != pos);
iov_iter_init(&from, WRITE, iov, nr_segs, count);
return generic_file_write_iter(iocb, &from);
}
EXPORT_SYMBOL(generic_file_aio_write); EXPORT_SYMBOL(generic_file_aio_write);
/** /**

View File

@ -2618,9 +2618,9 @@ static const struct file_operations shmem_file_operations = {
#ifdef CONFIG_TMPFS #ifdef CONFIG_TMPFS
.llseek = shmem_file_llseek, .llseek = shmem_file_llseek,
.read = new_sync_read, .read = new_sync_read,
.write = do_sync_write, .write = new_sync_write,
.read_iter = shmem_file_read_iter, .read_iter = shmem_file_read_iter,
.aio_write = generic_file_aio_write, .write_iter = generic_file_write_iter,
.fsync = noop_fsync, .fsync = noop_fsync,
.splice_read = shmem_file_splice_read, .splice_read = shmem_file_splice_read,
.splice_write = generic_file_splice_write, .splice_write = generic_file_splice_write,

View File

@ -458,7 +458,7 @@ static pageout_t pageout(struct page *page, struct address_space *mapping,
* stalls if we need to run get_block(). We could test * stalls if we need to run get_block(). We could test
* PagePrivate for that. * PagePrivate for that.
* *
* If this process is currently in __generic_file_aio_write() against * If this process is currently in __generic_file_write_iter() against
* this page's queue, we can perform writeback even if that * this page's queue, we can perform writeback even if that
* will block. * will block.
* *