f2fs: schedule in between two continous batch discards
authorChao Yu <yuchao0@huawei.com>
Sun, 21 Aug 2016 15:21:30 +0000 (23:21 +0800)
committerJaegeuk Kim <jaegeuk@kernel.org>
Thu, 8 Sep 2016 00:27:33 +0000 (17:27 -0700)
In batch discard approach of fstrim will grab/release gc_mutex lock
repeatly, it makes contention of the lock becoming more intensive.

So after one batch discards were issued in checkpoint and the lock
was released, it's better to do schedule() to increase opportunity
of grabbing gc_mutex lock for other competitors.

Signed-off-by: Chao Yu <yuchao0@huawei.com>
Signed-off-by: Jaegeuk Kim <jaegeuk@kernel.org>
fs/f2fs/segment.c

index 020767c67935b9e4df278d3111aa342f8b682186..d0f74eb521ae7033f718bbc6a9bfd3a7597cc4eb 100644 (file)
@@ -1305,6 +1305,8 @@ int f2fs_trim_fs(struct f2fs_sb_info *sbi, struct fstrim_range *range)
                mutex_unlock(&sbi->gc_mutex);
                if (err)
                        break;
+
+               schedule();
        }
 out:
        range->len = F2FS_BLK_TO_BYTES(cpc.trimmed);