Commit 2c4656df authored by Miklos Szeredi's avatar Miklos Szeredi

fuse: fix copy_file_range cache issues

a) Dirty cache needs to be written back not just in the writeback_cache
case, since the dirty pages may come from memory maps.

b) The fuse_writeback_range() helper takes an inclusive interval, so the
end position needs to be pos+len-1 instead of pos+len.

Fixes: 88bc7d50 ("fuse: add support for copy_file_range()")
Signed-off-by: default avatarMiklos Szeredi <mszeredi@redhat.com>
parent 6b2fb799
...@@ -3325,13 +3325,11 @@ static ssize_t __fuse_copy_file_range(struct file *file_in, loff_t pos_in, ...@@ -3325,13 +3325,11 @@ static ssize_t __fuse_copy_file_range(struct file *file_in, loff_t pos_in,
if (file_inode(file_in)->i_sb != file_inode(file_out)->i_sb) if (file_inode(file_in)->i_sb != file_inode(file_out)->i_sb)
return -EXDEV; return -EXDEV;
if (fc->writeback_cache) {
inode_lock(inode_in); inode_lock(inode_in);
err = fuse_writeback_range(inode_in, pos_in, pos_in + len); err = fuse_writeback_range(inode_in, pos_in, pos_in + len - 1);
inode_unlock(inode_in); inode_unlock(inode_in);
if (err) if (err)
return err; return err;
}
inode_lock(inode_out); inode_lock(inode_out);
...@@ -3339,11 +3337,9 @@ static ssize_t __fuse_copy_file_range(struct file *file_in, loff_t pos_in, ...@@ -3339,11 +3337,9 @@ static ssize_t __fuse_copy_file_range(struct file *file_in, loff_t pos_in,
if (err) if (err)
goto out; goto out;
if (fc->writeback_cache) { err = fuse_writeback_range(inode_out, pos_out, pos_out + len - 1);
err = fuse_writeback_range(inode_out, pos_out, pos_out + len);
if (err) if (err)
goto out; goto out;
}
if (is_unstable) if (is_unstable)
set_bit(FUSE_I_SIZE_UNSTABLE, &fi_out->state); set_bit(FUSE_I_SIZE_UNSTABLE, &fi_out->state);
......
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