f2fs: skip checkpoint if there is no dirty and prefree segments
authorJaegeuk Kim <jaegeuk@kernel.org>
Wed, 12 Aug 2015 04:59:49 +0000 (21:59 -0700)
committerJaegeuk Kim <jaegeuk@kernel.org>
Thu, 20 Aug 2015 16:00:07 +0000 (09:00 -0700)
We should avoid needless checkpoints when there is no dirty and prefree segment.

Reviewed-by: Chao Yu <chao2.yu@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk@kernel.org>
fs/f2fs/gc.c

index fcb263af58b38ea596698c8438fcd34f932e2f92..81de28d8326f00f20744d97bdd013f2469fd2bf8 100644 (file)
@@ -792,7 +792,8 @@ static void do_garbage_collect(struct f2fs_sb_info *sbi, unsigned int segno,
 
 int f2fs_gc(struct f2fs_sb_info *sbi)
 {
-       unsigned int segno, i;
+       unsigned int segno = NULL_SEGNO;
+       unsigned int i;
        int gc_type = BG_GC;
        int nfree = 0;
        int ret = -1;
@@ -811,10 +812,11 @@ gc_more:
 
        if (gc_type == BG_GC && has_not_enough_free_secs(sbi, nfree)) {
                gc_type = FG_GC;
-               write_checkpoint(sbi, &cpc);
+               if (__get_victim(sbi, &segno, gc_type) || prefree_segments(sbi))
+                       write_checkpoint(sbi, &cpc);
        }
 
-       if (!__get_victim(sbi, &segno, gc_type))
+       if (segno == NULL_SEGNO && !__get_victim(sbi, &segno, gc_type))
                goto stop;
        ret = 0;