Commit cf03f316 authored by Toke Høiland-Jørgensen's avatar Toke Høiland-Jørgensen Committed by Dominique Martinet

fs: 9p: add generic splice_read file operations

The v9fs file operations were missing the splice_read operations, which
breaks sendfile() of files on such a filesystem. I discovered this while
trying to load an eBPF program using iproute2 inside a 'virtme' environment
which uses 9pfs for the virtual file system. iproute2 relies on sendfile()
with an AF_ALG socket to hash files, which was erroring out in the virtual
environment.

Since generic_file_splice_read() seems to just implement splice_read in
terms of the read_iter operation, I simply added the generic implementation
to the file operations, which fixed the error I was seeing. A quick grep
indicates that this is what most other file systems do as well.

Link: http://lkml.kernel.org/r/20201201135409.55510-1-toke@redhat.com
Fixes: 36e2c742 ("fs: don't allow splice read/write without explicit ops")
Signed-off-by: default avatarToke Høiland-Jørgensen <toke@redhat.com>
Signed-off-by: default avatarDominique Martinet <asmadeus@codewreck.org>
parent b6505459
...@@ -655,6 +655,7 @@ const struct file_operations v9fs_cached_file_operations = { ...@@ -655,6 +655,7 @@ const struct file_operations v9fs_cached_file_operations = {
.release = v9fs_dir_release, .release = v9fs_dir_release,
.lock = v9fs_file_lock, .lock = v9fs_file_lock,
.mmap = v9fs_file_mmap, .mmap = v9fs_file_mmap,
.splice_read = generic_file_splice_read,
.fsync = v9fs_file_fsync, .fsync = v9fs_file_fsync,
}; };
...@@ -667,6 +668,7 @@ const struct file_operations v9fs_cached_file_operations_dotl = { ...@@ -667,6 +668,7 @@ const struct file_operations v9fs_cached_file_operations_dotl = {
.lock = v9fs_file_lock_dotl, .lock = v9fs_file_lock_dotl,
.flock = v9fs_file_flock_dotl, .flock = v9fs_file_flock_dotl,
.mmap = v9fs_file_mmap, .mmap = v9fs_file_mmap,
.splice_read = generic_file_splice_read,
.fsync = v9fs_file_fsync_dotl, .fsync = v9fs_file_fsync_dotl,
}; };
...@@ -678,6 +680,7 @@ const struct file_operations v9fs_file_operations = { ...@@ -678,6 +680,7 @@ const struct file_operations v9fs_file_operations = {
.release = v9fs_dir_release, .release = v9fs_dir_release,
.lock = v9fs_file_lock, .lock = v9fs_file_lock,
.mmap = generic_file_readonly_mmap, .mmap = generic_file_readonly_mmap,
.splice_read = generic_file_splice_read,
.fsync = v9fs_file_fsync, .fsync = v9fs_file_fsync,
}; };
...@@ -690,6 +693,7 @@ const struct file_operations v9fs_file_operations_dotl = { ...@@ -690,6 +693,7 @@ const struct file_operations v9fs_file_operations_dotl = {
.lock = v9fs_file_lock_dotl, .lock = v9fs_file_lock_dotl,
.flock = v9fs_file_flock_dotl, .flock = v9fs_file_flock_dotl,
.mmap = generic_file_readonly_mmap, .mmap = generic_file_readonly_mmap,
.splice_read = generic_file_splice_read,
.fsync = v9fs_file_fsync_dotl, .fsync = v9fs_file_fsync_dotl,
}; };
...@@ -701,6 +705,7 @@ const struct file_operations v9fs_mmap_file_operations = { ...@@ -701,6 +705,7 @@ const struct file_operations v9fs_mmap_file_operations = {
.release = v9fs_dir_release, .release = v9fs_dir_release,
.lock = v9fs_file_lock, .lock = v9fs_file_lock,
.mmap = v9fs_mmap_file_mmap, .mmap = v9fs_mmap_file_mmap,
.splice_read = generic_file_splice_read,
.fsync = v9fs_file_fsync, .fsync = v9fs_file_fsync,
}; };
...@@ -713,5 +718,6 @@ const struct file_operations v9fs_mmap_file_operations_dotl = { ...@@ -713,5 +718,6 @@ const struct file_operations v9fs_mmap_file_operations_dotl = {
.lock = v9fs_file_lock_dotl, .lock = v9fs_file_lock_dotl,
.flock = v9fs_file_flock_dotl, .flock = v9fs_file_flock_dotl,
.mmap = v9fs_mmap_file_mmap, .mmap = v9fs_mmap_file_mmap,
.splice_read = generic_file_splice_read,
.fsync = v9fs_file_fsync_dotl, .fsync = v9fs_file_fsync_dotl,
}; };
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