Patch "f2fs: fix to avoid forcing direct write to use buffered IO on inline_data inode" has been added to the 6.1-stable tree

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



This is a note to let you know that I've just added the patch titled

    f2fs: fix to avoid forcing direct write to use buffered IO on inline_data inode

to the 6.1-stable tree which can be found at:
    http://www.kernel.org/git/?p=linux/kernel/git/stable/stable-queue.git;a=summary

The filename of the patch is:
     f2fs-fix-to-avoid-forcing-direct-write-to-use-buffer.patch
and it can be found in the queue-6.1 subdirectory.

If you, or anyone else, feels it should not be added to the stable tree,
please let <stable@xxxxxxxxxxxxxxx> know about it.



commit 1d965333207244d412f05079e2d2547bc0cdf4c9
Author: Chao Yu <chao@xxxxxxxxxx>
Date:   Mon Nov 4 09:50:16 2024 +0800

    f2fs: fix to avoid forcing direct write to use buffered IO on inline_data inode
    
    [ Upstream commit 26e6f59d0bbaac76fa3413462d780bd2b5f9f653 ]
    
    Jinsu Lee reported a performance regression issue, after commit
    5c8764f8679e ("f2fs: fix to force buffered IO on inline_data
    inode"), we forced direct write to use buffered IO on inline_data
    inode, it will cause performace regression due to memory copy
    and data flush.
    
    It's fine to not force direct write to use buffered IO, as it
    can convert inline inode before committing direct write IO.
    
    Fixes: 5c8764f8679e ("f2fs: fix to force buffered IO on inline_data inode")
    Reported-by: Jinsu Lee <jinsu1.lee@xxxxxxxxxxx>
    Closes: https://lore.kernel.org/linux-f2fs-devel/af03dd2c-e361-4f80-b2fd-39440766cf6e@xxxxxxxxxx
    Signed-off-by: Chao Yu <chao@xxxxxxxxxx>
    Signed-off-by: Jaegeuk Kim <jaegeuk@xxxxxxxxxx>
    Signed-off-by: Sasha Levin <sashal@xxxxxxxxxx>

diff --git a/fs/f2fs/file.c b/fs/f2fs/file.c
index a25b9bff76ffc..3bab52d33e806 100644
--- a/fs/f2fs/file.c
+++ b/fs/f2fs/file.c
@@ -855,7 +855,11 @@ static bool f2fs_force_buffered_io(struct inode *inode, int rw)
 		return true;
 	if (f2fs_compressed_file(inode))
 		return true;
-	if (f2fs_has_inline_data(inode))
+	/*
+	 * only force direct read to use buffered IO, for direct write,
+	 * it expects inline data conversion before committing IO.
+	 */
+	if (f2fs_has_inline_data(inode) && rw == READ)
 		return true;
 
 	/* disallow direct IO if any of devices has unaligned blksize */




[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Index of Archives]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux