]> www.infradead.org Git - users/dwmw2/linux.git/commitdiff
f2fs: fix to calculate dirty data during has_not_enough_free_secs()
authorChao Yu <chao@kernel.org>
Thu, 24 Jul 2025 08:01:43 +0000 (16:01 +0800)
committerJaegeuk Kim <jaegeuk@kernel.org>
Mon, 28 Jul 2025 16:36:42 +0000 (16:36 +0000)
In lfs mode, dirty data needs OPU, we'd better calculate lower_p and
upper_p w/ them during has_not_enough_free_secs(), otherwise we may
encounter out-of-space issue due to we missed to reclaim enough
free section w/ foreground gc.

Fixes: 36abef4e796d ("f2fs: introduce mode=lfs mount option")
Cc: Daeho Jeong <daehojeong@google.com>
Signed-off-by: Chao Yu <chao@kernel.org>
Signed-off-by: Jaegeuk Kim <jaegeuk@kernel.org>
fs/f2fs/segment.h

index 2123645cf1756ec28bb4c8c0e0840d061a193e63..5e2ee5c686b124824c40b7247b820f97d0fd23ad 100644 (file)
@@ -668,8 +668,7 @@ static inline void __get_secs_required(struct f2fs_sb_info *sbi,
        unsigned int dent_blocks = total_dent_blocks % CAP_BLKS_PER_SEC(sbi);
        unsigned int data_blocks = 0;
 
-       if (f2fs_lfs_mode(sbi) &&
-               unlikely(is_sbi_flag_set(sbi, SBI_CP_DISABLED))) {
+       if (f2fs_lfs_mode(sbi)) {
                total_data_blocks = get_pages(sbi, F2FS_DIRTY_DATA);
                data_secs = total_data_blocks / CAP_BLKS_PER_SEC(sbi);
                data_blocks = total_data_blocks % CAP_BLKS_PER_SEC(sbi);