diff options
author | Pavel Begunkov <asml.silence@gmail.com> | 2020-12-20 14:21:43 +0100 |
---|---|---|
committer | Jens Axboe <axboe@kernel.dk> | 2020-12-20 19:05:39 +0100 |
commit | 55583d72e2303638d30dd4a7aabef59ffa0a017a (patch) | |
tree | f435b2d324235ad2d08aa9dbdacde0a53d7724b2 /fs | |
parent | io-wq: kill now unused io_wq_cancel_all() (diff) | |
download | linux-55583d72e2303638d30dd4a7aabef59ffa0a017a.tar.xz linux-55583d72e2303638d30dd4a7aabef59ffa0a017a.zip |
io_uring: always progress task_work on task cancel
Might happen that __io_uring_cancel_task_requests() cancels nothing but
there are task_works pending. We need to always run them.
Signed-off-by: Pavel Begunkov <asml.silence@gmail.com>
Signed-off-by: Jens Axboe <axboe@kernel.dk>
Diffstat (limited to 'fs')
-rw-r--r-- | fs/io_uring.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/fs/io_uring.c b/fs/io_uring.c index 48b9332c2354..d0ab6b503a9f 100644 --- a/fs/io_uring.c +++ b/fs/io_uring.c @@ -8801,9 +8801,9 @@ static void __io_uring_cancel_task_requests(struct io_ring_ctx *ctx, ret |= io_poll_remove_all(ctx, task, NULL); ret |= io_kill_timeouts(ctx, task, NULL); + ret |= io_run_task_work(); if (!ret) break; - io_run_task_work(); cond_resched(); } } |