浏览代码

f2fs: schedule in between two continous batch discards

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>
Chao Yu 9 年之前
父节点
当前提交
74fa5f3d43
共有 1 个文件被更改,包括 2 次插入0 次删除
  1. 2 0
      fs/f2fs/segment.c

+ 2 - 0
fs/f2fs/segment.c

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