Commit 2cb1e089 authored by David Howells's avatar David Howells Committed by Jens Axboe

splice: Use filemap_splice_read() instead of generic_file_splice_read()

Replace pointers to generic_file_splice_read() with calls to
filemap_splice_read().
Signed-off-by: default avatarDavid Howells <dhowells@redhat.com>
Reviewed-by: default avatarChristoph Hellwig <hch@lst.de>
Reviewed-by: default avatarChristian Brauner <brauner@kernel.org>
cc: Jens Axboe <axboe@kernel.dk>
cc: Al Viro <viro@zeniv.linux.org.uk>
cc: David Hildenbrand <david@redhat.com>
cc: John Hubbard <jhubbard@nvidia.com>
cc: linux-mm@kvack.org
cc: linux-block@vger.kernel.org
cc: linux-fsdevel@vger.kernel.org
Link: https://lore.kernel.org/r/20230522135018.2742245-29-dhowells@redhat.comSigned-off-by: default avatarJens Axboe <axboe@kernel.dk>
parent ab825131
...@@ -691,7 +691,7 @@ const struct file_operations def_blk_fops = { ...@@ -691,7 +691,7 @@ const struct file_operations def_blk_fops = {
#ifdef CONFIG_COMPAT #ifdef CONFIG_COMPAT
.compat_ioctl = compat_blkdev_ioctl, .compat_ioctl = compat_blkdev_ioctl,
#endif #endif
.splice_read = generic_file_splice_read, .splice_read = filemap_splice_read,
.splice_write = iter_file_splice_write, .splice_write = iter_file_splice_write,
.fallocate = blkdev_fallocate, .fallocate = blkdev_fallocate,
}; };
......
...@@ -28,7 +28,7 @@ const struct file_operations adfs_file_operations = { ...@@ -28,7 +28,7 @@ const struct file_operations adfs_file_operations = {
.mmap = generic_file_mmap, .mmap = generic_file_mmap,
.fsync = generic_file_fsync, .fsync = generic_file_fsync,
.write_iter = generic_file_write_iter, .write_iter = generic_file_write_iter,
.splice_read = generic_file_splice_read, .splice_read = filemap_splice_read,
}; };
const struct inode_operations adfs_file_inode_operations = { const struct inode_operations adfs_file_inode_operations = {
......
...@@ -1001,7 +1001,7 @@ const struct file_operations affs_file_operations = { ...@@ -1001,7 +1001,7 @@ const struct file_operations affs_file_operations = {
.open = affs_file_open, .open = affs_file_open,
.release = affs_file_release, .release = affs_file_release,
.fsync = affs_file_fsync, .fsync = affs_file_fsync,
.splice_read = generic_file_splice_read, .splice_read = filemap_splice_read,
}; };
const struct inode_operations affs_file_inode_operations = { const struct inode_operations affs_file_inode_operations = {
......
...@@ -603,5 +603,5 @@ static ssize_t afs_file_splice_read(struct file *in, loff_t *ppos, ...@@ -603,5 +603,5 @@ static ssize_t afs_file_splice_read(struct file *in, loff_t *ppos,
if (ret < 0) if (ret < 0)
return ret; return ret;
return generic_file_splice_read(in, ppos, pipe, len, flags); return filemap_splice_read(in, ppos, pipe, len, flags);
} }
...@@ -27,7 +27,7 @@ const struct file_operations bfs_file_operations = { ...@@ -27,7 +27,7 @@ const struct file_operations bfs_file_operations = {
.read_iter = generic_file_read_iter, .read_iter = generic_file_read_iter,
.write_iter = generic_file_write_iter, .write_iter = generic_file_write_iter,
.mmap = generic_file_mmap, .mmap = generic_file_mmap,
.splice_read = generic_file_splice_read, .splice_read = filemap_splice_read,
}; };
static int bfs_move_block(unsigned long from, unsigned long to, static int bfs_move_block(unsigned long from, unsigned long to,
......
...@@ -3825,7 +3825,7 @@ static ssize_t btrfs_file_read_iter(struct kiocb *iocb, struct iov_iter *to) ...@@ -3825,7 +3825,7 @@ static ssize_t btrfs_file_read_iter(struct kiocb *iocb, struct iov_iter *to)
const struct file_operations btrfs_file_operations = { const struct file_operations btrfs_file_operations = {
.llseek = btrfs_file_llseek, .llseek = btrfs_file_llseek,
.read_iter = btrfs_file_read_iter, .read_iter = btrfs_file_read_iter,
.splice_read = generic_file_splice_read, .splice_read = filemap_splice_read,
.write_iter = btrfs_file_write_iter, .write_iter = btrfs_file_write_iter,
.splice_write = iter_file_splice_write, .splice_write = iter_file_splice_write,
.mmap = btrfs_file_mmap, .mmap = btrfs_file_mmap,
......
...@@ -473,7 +473,7 @@ static unsigned int cramfs_physmem_mmap_capabilities(struct file *file) ...@@ -473,7 +473,7 @@ static unsigned int cramfs_physmem_mmap_capabilities(struct file *file)
static const struct file_operations cramfs_physmem_fops = { static const struct file_operations cramfs_physmem_fops = {
.llseek = generic_file_llseek, .llseek = generic_file_llseek,
.read_iter = generic_file_read_iter, .read_iter = generic_file_read_iter,
.splice_read = generic_file_splice_read, .splice_read = filemap_splice_read,
.mmap = cramfs_physmem_mmap, .mmap = cramfs_physmem_mmap,
#ifndef CONFIG_MMU #ifndef CONFIG_MMU
.get_unmapped_area = cramfs_physmem_get_unmapped_area, .get_unmapped_area = cramfs_physmem_get_unmapped_area,
......
...@@ -47,7 +47,7 @@ static ssize_t ecryptfs_read_update_atime(struct kiocb *iocb, ...@@ -47,7 +47,7 @@ static ssize_t ecryptfs_read_update_atime(struct kiocb *iocb,
/* /*
* ecryptfs_splice_read_update_atime * ecryptfs_splice_read_update_atime
* *
* generic_file_splice_read updates the atime of upper layer inode. But, it * filemap_splice_read updates the atime of upper layer inode. But, it
* doesn't give us a chance to update the atime of the lower layer inode. This * doesn't give us a chance to update the atime of the lower layer inode. This
* function is a wrapper to generic_file_read. It updates the atime of the * function is a wrapper to generic_file_read. It updates the atime of the
* lower level inode if generic_file_read returns without any errors. This is * lower level inode if generic_file_read returns without any errors. This is
...@@ -61,7 +61,7 @@ static ssize_t ecryptfs_splice_read_update_atime(struct file *in, loff_t *ppos, ...@@ -61,7 +61,7 @@ static ssize_t ecryptfs_splice_read_update_atime(struct file *in, loff_t *ppos,
ssize_t rc; ssize_t rc;
const struct path *path; const struct path *path;
rc = generic_file_splice_read(in, ppos, pipe, len, flags); rc = filemap_splice_read(in, ppos, pipe, len, flags);
if (rc >= 0) { if (rc >= 0) {
path = ecryptfs_dentry_to_lower_path(in->f_path.dentry); path = ecryptfs_dentry_to_lower_path(in->f_path.dentry);
touch_atime(path); touch_atime(path);
......
...@@ -448,5 +448,5 @@ const struct file_operations erofs_file_fops = { ...@@ -448,5 +448,5 @@ const struct file_operations erofs_file_fops = {
.llseek = generic_file_llseek, .llseek = generic_file_llseek,
.read_iter = erofs_file_read_iter, .read_iter = erofs_file_read_iter,
.mmap = erofs_file_mmap, .mmap = erofs_file_mmap,
.splice_read = generic_file_splice_read, .splice_read = filemap_splice_read,
}; };
...@@ -389,7 +389,7 @@ const struct file_operations exfat_file_operations = { ...@@ -389,7 +389,7 @@ const struct file_operations exfat_file_operations = {
#endif #endif
.mmap = generic_file_mmap, .mmap = generic_file_mmap,
.fsync = exfat_file_fsync, .fsync = exfat_file_fsync,
.splice_read = generic_file_splice_read, .splice_read = filemap_splice_read,
.splice_write = iter_file_splice_write, .splice_write = iter_file_splice_write,
}; };
......
...@@ -192,7 +192,7 @@ const struct file_operations ext2_file_operations = { ...@@ -192,7 +192,7 @@ const struct file_operations ext2_file_operations = {
.release = ext2_release_file, .release = ext2_release_file,
.fsync = ext2_fsync, .fsync = ext2_fsync,
.get_unmapped_area = thp_get_unmapped_area, .get_unmapped_area = thp_get_unmapped_area,
.splice_read = generic_file_splice_read, .splice_read = filemap_splice_read,
.splice_write = iter_file_splice_write, .splice_write = iter_file_splice_write,
}; };
......
...@@ -155,7 +155,7 @@ static ssize_t ext4_file_splice_read(struct file *in, loff_t *ppos, ...@@ -155,7 +155,7 @@ static ssize_t ext4_file_splice_read(struct file *in, loff_t *ppos,
if (unlikely(ext4_forced_shutdown(EXT4_SB(inode->i_sb)))) if (unlikely(ext4_forced_shutdown(EXT4_SB(inode->i_sb))))
return -EIO; return -EIO;
return generic_file_splice_read(in, ppos, pipe, len, flags); return filemap_splice_read(in, ppos, pipe, len, flags);
} }
/* /*
......
...@@ -209,7 +209,7 @@ const struct file_operations fat_file_operations = { ...@@ -209,7 +209,7 @@ const struct file_operations fat_file_operations = {
.unlocked_ioctl = fat_generic_ioctl, .unlocked_ioctl = fat_generic_ioctl,
.compat_ioctl = compat_ptr_ioctl, .compat_ioctl = compat_ptr_ioctl,
.fsync = fat_file_fsync, .fsync = fat_file_fsync,
.splice_read = generic_file_splice_read, .splice_read = filemap_splice_read,
.splice_write = iter_file_splice_write, .splice_write = iter_file_splice_write,
.fallocate = fat_fallocate, .fallocate = fat_fallocate,
}; };
......
...@@ -3252,7 +3252,7 @@ static const struct file_operations fuse_file_operations = { ...@@ -3252,7 +3252,7 @@ static const struct file_operations fuse_file_operations = {
.lock = fuse_file_lock, .lock = fuse_file_lock,
.get_unmapped_area = thp_get_unmapped_area, .get_unmapped_area = thp_get_unmapped_area,
.flock = fuse_file_flock, .flock = fuse_file_flock,
.splice_read = generic_file_splice_read, .splice_read = filemap_splice_read,
.splice_write = iter_file_splice_write, .splice_write = iter_file_splice_write,
.unlocked_ioctl = fuse_file_ioctl, .unlocked_ioctl = fuse_file_ioctl,
.compat_ioctl = fuse_file_compat_ioctl, .compat_ioctl = fuse_file_compat_ioctl,
......
...@@ -1568,7 +1568,7 @@ const struct file_operations gfs2_file_fops = { ...@@ -1568,7 +1568,7 @@ const struct file_operations gfs2_file_fops = {
.fsync = gfs2_fsync, .fsync = gfs2_fsync,
.lock = gfs2_lock, .lock = gfs2_lock,
.flock = gfs2_flock, .flock = gfs2_flock,
.splice_read = generic_file_splice_read, .splice_read = filemap_splice_read,
.splice_write = gfs2_file_splice_write, .splice_write = gfs2_file_splice_write,
.setlease = simple_nosetlease, .setlease = simple_nosetlease,
.fallocate = gfs2_fallocate, .fallocate = gfs2_fallocate,
...@@ -1599,7 +1599,7 @@ const struct file_operations gfs2_file_fops_nolock = { ...@@ -1599,7 +1599,7 @@ const struct file_operations gfs2_file_fops_nolock = {
.open = gfs2_open, .open = gfs2_open,
.release = gfs2_release, .release = gfs2_release,
.fsync = gfs2_fsync, .fsync = gfs2_fsync,
.splice_read = generic_file_splice_read, .splice_read = filemap_splice_read,
.splice_write = gfs2_file_splice_write, .splice_write = gfs2_file_splice_write,
.setlease = generic_setlease, .setlease = generic_setlease,
.fallocate = gfs2_fallocate, .fallocate = gfs2_fallocate,
......
...@@ -694,7 +694,7 @@ static const struct file_operations hfs_file_operations = { ...@@ -694,7 +694,7 @@ static const struct file_operations hfs_file_operations = {
.read_iter = generic_file_read_iter, .read_iter = generic_file_read_iter,
.write_iter = generic_file_write_iter, .write_iter = generic_file_write_iter,
.mmap = generic_file_mmap, .mmap = generic_file_mmap,
.splice_read = generic_file_splice_read, .splice_read = filemap_splice_read,
.fsync = hfs_file_fsync, .fsync = hfs_file_fsync,
.open = hfs_file_open, .open = hfs_file_open,
.release = hfs_file_release, .release = hfs_file_release,
......
...@@ -372,7 +372,7 @@ static const struct file_operations hfsplus_file_operations = { ...@@ -372,7 +372,7 @@ static const struct file_operations hfsplus_file_operations = {
.read_iter = generic_file_read_iter, .read_iter = generic_file_read_iter,
.write_iter = generic_file_write_iter, .write_iter = generic_file_write_iter,
.mmap = generic_file_mmap, .mmap = generic_file_mmap,
.splice_read = generic_file_splice_read, .splice_read = filemap_splice_read,
.fsync = hfsplus_file_fsync, .fsync = hfsplus_file_fsync,
.open = hfsplus_file_open, .open = hfsplus_file_open,
.release = hfsplus_file_release, .release = hfsplus_file_release,
......
...@@ -381,7 +381,7 @@ static int hostfs_fsync(struct file *file, loff_t start, loff_t end, ...@@ -381,7 +381,7 @@ static int hostfs_fsync(struct file *file, loff_t start, loff_t end,
static const struct file_operations hostfs_file_fops = { static const struct file_operations hostfs_file_fops = {
.llseek = generic_file_llseek, .llseek = generic_file_llseek,
.splice_read = generic_file_splice_read, .splice_read = filemap_splice_read,
.splice_write = iter_file_splice_write, .splice_write = iter_file_splice_write,
.read_iter = generic_file_read_iter, .read_iter = generic_file_read_iter,
.write_iter = generic_file_write_iter, .write_iter = generic_file_write_iter,
......
...@@ -259,7 +259,7 @@ const struct file_operations hpfs_file_ops = ...@@ -259,7 +259,7 @@ const struct file_operations hpfs_file_ops =
.mmap = generic_file_mmap, .mmap = generic_file_mmap,
.release = hpfs_file_release, .release = hpfs_file_release,
.fsync = hpfs_file_fsync, .fsync = hpfs_file_fsync,
.splice_read = generic_file_splice_read, .splice_read = filemap_splice_read,
.unlocked_ioctl = hpfs_ioctl, .unlocked_ioctl = hpfs_ioctl,
.compat_ioctl = compat_ptr_ioctl, .compat_ioctl = compat_ptr_ioctl,
}; };
......
...@@ -56,7 +56,7 @@ const struct file_operations jffs2_file_operations = ...@@ -56,7 +56,7 @@ const struct file_operations jffs2_file_operations =
.unlocked_ioctl=jffs2_ioctl, .unlocked_ioctl=jffs2_ioctl,
.mmap = generic_file_readonly_mmap, .mmap = generic_file_readonly_mmap,
.fsync = jffs2_fsync, .fsync = jffs2_fsync,
.splice_read = generic_file_splice_read, .splice_read = filemap_splice_read,
.splice_write = iter_file_splice_write, .splice_write = iter_file_splice_write,
}; };
......
...@@ -144,7 +144,7 @@ const struct file_operations jfs_file_operations = { ...@@ -144,7 +144,7 @@ const struct file_operations jfs_file_operations = {
.read_iter = generic_file_read_iter, .read_iter = generic_file_read_iter,
.write_iter = generic_file_write_iter, .write_iter = generic_file_write_iter,
.mmap = generic_file_mmap, .mmap = generic_file_mmap,
.splice_read = generic_file_splice_read, .splice_read = filemap_splice_read,
.splice_write = iter_file_splice_write, .splice_write = iter_file_splice_write,
.fsync = jfs_fsync, .fsync = jfs_fsync,
.release = jfs_release, .release = jfs_release,
......
...@@ -19,7 +19,7 @@ const struct file_operations minix_file_operations = { ...@@ -19,7 +19,7 @@ const struct file_operations minix_file_operations = {
.write_iter = generic_file_write_iter, .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 = filemap_splice_read,
}; };
static int minix_setattr(struct mnt_idmap *idmap, static int minix_setattr(struct mnt_idmap *idmap,
......
...@@ -140,7 +140,7 @@ const struct file_operations nilfs_file_operations = { ...@@ -140,7 +140,7 @@ const struct file_operations nilfs_file_operations = {
.open = generic_file_open, .open = generic_file_open,
/* .release = nilfs_release_file, */ /* .release = nilfs_release_file, */
.fsync = nilfs_sync_file, .fsync = nilfs_sync_file,
.splice_read = generic_file_splice_read, .splice_read = filemap_splice_read,
.splice_write = iter_file_splice_write, .splice_write = iter_file_splice_write,
}; };
......
...@@ -1992,7 +1992,7 @@ const struct file_operations ntfs_file_ops = { ...@@ -1992,7 +1992,7 @@ const struct file_operations ntfs_file_ops = {
#endif /* NTFS_RW */ #endif /* NTFS_RW */
.mmap = generic_file_mmap, .mmap = generic_file_mmap,
.open = ntfs_file_open, .open = ntfs_file_open,
.splice_read = generic_file_splice_read, .splice_read = filemap_splice_read,
}; };
const struct inode_operations ntfs_file_inode_ops = { const struct inode_operations ntfs_file_inode_ops = {
......
...@@ -770,7 +770,7 @@ static ssize_t ntfs_file_splice_read(struct file *in, loff_t *ppos, ...@@ -770,7 +770,7 @@ static ssize_t ntfs_file_splice_read(struct file *in, loff_t *ppos,
return -EOPNOTSUPP; return -EOPNOTSUPP;
} }
return generic_file_splice_read(in, ppos, pipe, len, flags); return filemap_splice_read(in, ppos, pipe, len, flags);
} }
/* /*
......
...@@ -2827,7 +2827,7 @@ const struct file_operations ocfs2_fops_no_plocks = { ...@@ -2827,7 +2827,7 @@ const struct file_operations ocfs2_fops_no_plocks = {
.compat_ioctl = ocfs2_compat_ioctl, .compat_ioctl = ocfs2_compat_ioctl,
#endif #endif
.flock = ocfs2_flock, .flock = ocfs2_flock,
.splice_read = generic_file_splice_read, .splice_read = filemap_splice_read,
.splice_write = iter_file_splice_write, .splice_write = iter_file_splice_write,
.fallocate = ocfs2_fallocate, .fallocate = ocfs2_fallocate,
.remap_file_range = ocfs2_remap_file_range, .remap_file_range = ocfs2_remap_file_range,
......
...@@ -334,7 +334,7 @@ const struct file_operations omfs_file_operations = { ...@@ -334,7 +334,7 @@ const struct file_operations omfs_file_operations = {
.write_iter = generic_file_write_iter, .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 = filemap_splice_read,
}; };
static int omfs_setattr(struct mnt_idmap *idmap, static int omfs_setattr(struct mnt_idmap *idmap,
......
...@@ -43,7 +43,7 @@ const struct file_operations ramfs_file_operations = { ...@@ -43,7 +43,7 @@ const struct file_operations ramfs_file_operations = {
.write_iter = generic_file_write_iter, .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 = filemap_splice_read,
.splice_write = iter_file_splice_write, .splice_write = iter_file_splice_write,
.llseek = generic_file_llseek, .llseek = generic_file_llseek,
.get_unmapped_area = ramfs_mmu_get_unmapped_area, .get_unmapped_area = ramfs_mmu_get_unmapped_area,
......
...@@ -43,7 +43,7 @@ const struct file_operations ramfs_file_operations = { ...@@ -43,7 +43,7 @@ const struct file_operations ramfs_file_operations = {
.read_iter = generic_file_read_iter, .read_iter = generic_file_read_iter,
.write_iter = generic_file_write_iter, .write_iter = generic_file_write_iter,
.fsync = noop_fsync, .fsync = noop_fsync,
.splice_read = generic_file_splice_read, .splice_read = filemap_splice_read,
.splice_write = iter_file_splice_write, .splice_write = iter_file_splice_write,
.llseek = generic_file_llseek, .llseek = generic_file_llseek,
}; };
......
...@@ -29,7 +29,7 @@ const struct file_operations generic_ro_fops = { ...@@ -29,7 +29,7 @@ const struct file_operations generic_ro_fops = {
.llseek = generic_file_llseek, .llseek = generic_file_llseek,
.read_iter = generic_file_read_iter, .read_iter = generic_file_read_iter,
.mmap = generic_file_readonly_mmap, .mmap = generic_file_readonly_mmap,
.splice_read = generic_file_splice_read, .splice_read = filemap_splice_read,
}; };
EXPORT_SYMBOL(generic_ro_fops); EXPORT_SYMBOL(generic_ro_fops);
......
...@@ -247,7 +247,7 @@ const struct file_operations reiserfs_file_operations = { ...@@ -247,7 +247,7 @@ const struct file_operations reiserfs_file_operations = {
.fsync = reiserfs_sync_file, .fsync = reiserfs_sync_file,
.read_iter = generic_file_read_iter, .read_iter = generic_file_read_iter,
.write_iter = generic_file_write_iter, .write_iter = generic_file_write_iter,
.splice_read = generic_file_splice_read, .splice_read = filemap_splice_read,
.splice_write = iter_file_splice_write, .splice_write = iter_file_splice_write,
.llseek = generic_file_llseek, .llseek = generic_file_llseek,
}; };
......
...@@ -78,7 +78,7 @@ static unsigned romfs_mmap_capabilities(struct file *file) ...@@ -78,7 +78,7 @@ static unsigned romfs_mmap_capabilities(struct file *file)
const struct file_operations romfs_ro_fops = { const struct file_operations romfs_ro_fops = {
.llseek = generic_file_llseek, .llseek = generic_file_llseek,
.read_iter = generic_file_read_iter, .read_iter = generic_file_read_iter,
.splice_read = generic_file_splice_read, .splice_read = filemap_splice_read,
.mmap = romfs_mmap, .mmap = romfs_mmap,
.get_unmapped_area = romfs_get_unmapped_area, .get_unmapped_area = romfs_get_unmapped_area,
.mmap_capabilities = romfs_mmap_capabilities, .mmap_capabilities = romfs_mmap_capabilities,
......
...@@ -26,7 +26,7 @@ const struct file_operations sysv_file_operations = { ...@@ -26,7 +26,7 @@ const struct file_operations sysv_file_operations = {
.write_iter = generic_file_write_iter, .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 = filemap_splice_read,
}; };
static int sysv_setattr(struct mnt_idmap *idmap, static int sysv_setattr(struct mnt_idmap *idmap,
......
...@@ -1669,7 +1669,7 @@ const struct file_operations ubifs_file_operations = { ...@@ -1669,7 +1669,7 @@ const struct file_operations ubifs_file_operations = {
.mmap = ubifs_file_mmap, .mmap = ubifs_file_mmap,
.fsync = ubifs_fsync, .fsync = ubifs_fsync,
.unlocked_ioctl = ubifs_ioctl, .unlocked_ioctl = ubifs_ioctl,
.splice_read = generic_file_splice_read, .splice_read = filemap_splice_read,
.splice_write = iter_file_splice_write, .splice_write = iter_file_splice_write,
.open = fscrypt_file_open, .open = fscrypt_file_open,
#ifdef CONFIG_COMPAT #ifdef CONFIG_COMPAT
......
...@@ -209,7 +209,7 @@ const struct file_operations udf_file_operations = { ...@@ -209,7 +209,7 @@ const struct file_operations udf_file_operations = {
.write_iter = udf_file_write_iter, .write_iter = udf_file_write_iter,
.release = udf_release_file, .release = udf_release_file,
.fsync = generic_file_fsync, .fsync = generic_file_fsync,
.splice_read = generic_file_splice_read, .splice_read = filemap_splice_read,
.splice_write = iter_file_splice_write, .splice_write = iter_file_splice_write,
.llseek = generic_file_llseek, .llseek = generic_file_llseek,
}; };
......
...@@ -41,5 +41,5 @@ const struct file_operations ufs_file_operations = { ...@@ -41,5 +41,5 @@ const struct file_operations ufs_file_operations = {
.mmap = generic_file_mmap, .mmap = generic_file_mmap,
.open = generic_file_open, .open = generic_file_open,
.fsync = generic_file_fsync, .fsync = generic_file_fsync,
.splice_read = generic_file_splice_read, .splice_read = filemap_splice_read,
}; };
...@@ -217,7 +217,7 @@ const struct file_operations vboxsf_reg_fops = { ...@@ -217,7 +217,7 @@ const struct file_operations vboxsf_reg_fops = {
.open = vboxsf_file_open, .open = vboxsf_file_open,
.release = vboxsf_file_release, .release = vboxsf_file_release,
.fsync = noop_fsync, .fsync = noop_fsync,
.splice_read = generic_file_splice_read, .splice_read = filemap_splice_read,
}; };
const struct inode_operations vboxsf_reg_iops = { const struct inode_operations vboxsf_reg_iops = {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment