From: Hao Xu Date: Tue, 1 Aug 2023 08:06:47 +0000 (+0800) Subject: fuse: write back dirty pages before direct write in direct_io_relax mode X-Git-Tag: v6.6.17~3983^2~7 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=b5a2a3a0b77668257fa72ee6bc0eac90493f13c1;p=platform%2Fkernel%2Flinux-rpi.git fuse: write back dirty pages before direct write in direct_io_relax mode In direct_io_relax mode, there can be shared mmaped files and thus dirty pages in its page cache. Therefore those dirty pages should be written back to backend before direct io to avoid data loss. Signed-off-by: Hao Xu Reviewed-by: Jiachen Zhang Signed-off-by: Miklos Szeredi --- diff --git a/fs/fuse/file.c b/fs/fuse/file.c index e6034ce..1cdb632 100644 --- a/fs/fuse/file.c +++ b/fs/fuse/file.c @@ -1448,6 +1448,13 @@ ssize_t fuse_direct_io(struct fuse_io_priv *io, struct iov_iter *iter, if (!ia) return -ENOMEM; + if (fopen_direct_io && fc->direct_io_relax) { + res = filemap_write_and_wait_range(mapping, pos, pos + count - 1); + if (res) { + fuse_io_free(ia); + return res; + } + } if (!cuse && fuse_range_is_writeback(inode, idx_from, idx_to)) { if (!write) inode_lock(inode);