]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
f2fs: fix to skip empty sections in f2fs_get_victim
authorDaeho Jeong <daehojeong@google.com>
Mon, 16 Mar 2026 18:59:21 +0000 (11:59 -0700)
committerJaegeuk Kim <jaegeuk@kernel.org>
Thu, 2 Apr 2026 16:24:19 +0000 (16:24 +0000)
In age-based victim selection (ATGC, AT_SSR, or GC_CB), f2fs_get_victim
can encounter sections with zero valid blocks. This situation often
arises when checkpoint is disabled or due to race conditions between
SIT updates and dirty list management.

In such cases, f2fs_get_section_mtime() returns INVALID_MTIME, which
subsequently triggers a fatal f2fs_bug_on(sbi, mtime == INVALID_MTIME)
in add_victim_entry() or get_cb_cost().

This patch adds a check in f2fs_get_victim's selection loop to skip
sections with no valid blocks. This prevents unnecessary age
calculations for empty sections and avoids the associated kernel panic.
This change also allows removing redundant checks in add_victim_entry().

Signed-off-by: Daeho Jeong <daehojeong@google.com>
Reviewed-by: Chao Yu <chao@kernel.org>
Signed-off-by: Jaegeuk Kim <jaegeuk@kernel.org>
fs/f2fs/gc.c

index 80b8500fa987e69dc0f3f450f3937a06fcf62ab2..4bfc4452f2997cd566da7604f35410ecde713678 100644 (file)
@@ -910,6 +910,9 @@ retry:
                                if (!f2fs_segment_has_free_slot(sbi, segno))
                                        goto next;
                        }
+
+                       if (!get_valid_blocks(sbi, segno, true))
+                               goto next;
                }
 
                if (gc_type == BG_GC && test_bit(secno, dirty_i->victim_secmap))