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

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
Loading
Loading
Loading
Loading
+5 −2
Original line number Diff line number Diff line
@@ -150,8 +150,11 @@ static int gc_thread_func(void *data)
		gc_control.nr_free_secs = foreground ? 1 : 0;

		/* if return value is not zero, no victim was selected */
		if (f2fs_gc(sbi, &gc_control))
		if (f2fs_gc(sbi, &gc_control)) {
			/* don't bother wait_ms by foreground gc */
			if (!foreground)
				wait_ms = gc_th->no_gc_sleep_time;
		}

		if (foreground)
			wake_up_all(&gc_th->fggc_wq);