Commit 1adaa71e authored by qixiaoyu1's avatar qixiaoyu1 Committed by Jaegeuk Kim

f2fs: don't bother wait_ms by foreground gc

f2fs_gc returns -EINVAL via f2fs_balance_fs when there is enough free
secs after write checkpoint, but with gc_merge enabled, it will cause
the sleep time of gc thread to be set to no_gc_sleep_time even if there
are many dirty segments can be selected.
Signed-off-by: default avatarqixiaoyu1 <qixiaoyu1@xiaomi.com>
Reviewed-by: default avatarChao Yu <chao@kernel.org>
Signed-off-by: default avatarJaegeuk Kim <jaegeuk@kernel.org>
parent 0d5b9d81
...@@ -150,8 +150,11 @@ static int gc_thread_func(void *data) ...@@ -150,8 +150,11 @@ static int gc_thread_func(void *data)
gc_control.nr_free_secs = foreground ? 1 : 0; gc_control.nr_free_secs = foreground ? 1 : 0;
/* if return value is not zero, no victim was selected */ /* if return value is not zero, no victim was selected */
if (f2fs_gc(sbi, &gc_control)) if (f2fs_gc(sbi, &gc_control)) {
wait_ms = gc_th->no_gc_sleep_time; /* don't bother wait_ms by foreground gc */
if (!foreground)
wait_ms = gc_th->no_gc_sleep_time;
}
if (foreground) if (foreground)
wake_up_all(&gc_th->fggc_wq); wake_up_all(&gc_th->fggc_wq);
......
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