If discard IOs are blocked by user IO, do not skip to select and issue discard with lower granularity, retry with current granularity.
Signed-off-by: Chao Yu <yuch...@huawei.com> --- fs/f2fs/segment.c | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/fs/f2fs/segment.c b/fs/f2fs/segment.c index 60f54ed1413a..13f5e3665bf0 100644 --- a/fs/f2fs/segment.c +++ b/fs/f2fs/segment.c @@ -1199,6 +1199,7 @@ static int __issue_discard_cmd(struct f2fs_sb_info *sbi, pend_list = &dcc->pend_list[i]; mutex_lock(&dcc->cmd_lock); +retry: if (list_empty(pend_list)) goto next; if (unlikely(dcc->rbtree_check)) @@ -1221,6 +1222,13 @@ static int __issue_discard_cmd(struct f2fs_sb_info *sbi, break; } blk_finish_plug(&plug); + + /* + * if discard IO was interrupted by user IOs, give another + * chance to issue discard with current granularity. + */ + if (io_interrupted) + goto retry; next: mutex_unlock(&dcc->cmd_lock); -- 2.18.0.rc1 ------------------------------------------------------------------------------ Check out the vibrant tech community on one of the world's most engaging tech sites, Slashdot.org! http://sdm.link/slashdot _______________________________________________ Linux-f2fs-devel mailing list Linux-f2fs-devel@lists.sourceforge.net https://lists.sourceforge.net/lists/listinfo/linux-f2fs-devel