io_uring: don't iopoll from io_ring_ctx_wait_and_kill()
authorPavel Begunkov <asml.silence@gmail.com>
Sun, 16 Oct 2022 20:30:51 +0000 (21:30 +0100)
committerJens Axboe <axboe@kernel.dk>
Sun, 16 Oct 2022 23:08:42 +0000 (17:08 -0600)
commit02bac94bd8efd75f615ac7515dd2def75b43e5b9
treec62c0e7c6e195a308496143cdd779f77fde294f3
parent34f0bc427e94065e7f828e70690f8fe1e01b3a9d
io_uring: don't iopoll from io_ring_ctx_wait_and_kill()

We should not be completing requests from a task context that has already
undergone io_uring cancellations, i.e. __io_uring_cancel(), as there are
some assumptions, e.g. around cached task refs draining. Remove
iopolling from io_ring_ctx_wait_and_kill() as it can be called later
after PF_EXITING is set with the last task_work run.

Signed-off-by: Pavel Begunkov <asml.silence@gmail.com>
Link: https://lore.kernel.org/r/7c03cc91455c4a1af49c6b9cbda4e57ea467aa11.1665891182.git.asml.silence@gmail.com
Signed-off-by: Jens Axboe <axboe@kernel.dk>
io_uring/io_uring.c