mirror of https://gitee.com/openkylin/linux.git
io_uring: perform IOPOLL reaping if canceler is thread itself
We bypass IOPOLL completion polling (and reaping) for the SQPOLL thread,
but if it's the thread itself invoking cancelations, then we still need
to perform it or no one will.
Fixes: 9936c7c2bc
("io_uring: deduplicate core cancellations sequence")
Signed-off-by: Jens Axboe <axboe@kernel.dk>
This commit is contained in:
parent
5c2469e0a2
commit
d052d1d685
|
@ -8658,7 +8658,8 @@ static void io_uring_try_cancel_requests(struct io_ring_ctx *ctx,
|
|||
}
|
||||
|
||||
/* SQPOLL thread does its own polling */
|
||||
if (!(ctx->flags & IORING_SETUP_SQPOLL) && !files) {
|
||||
if ((!(ctx->flags & IORING_SETUP_SQPOLL) && !files) ||
|
||||
(ctx->sq_data && ctx->sq_data->thread == current)) {
|
||||
while (!list_empty_careful(&ctx->iopoll_list)) {
|
||||
io_iopoll_try_reap_events(ctx);
|
||||
ret = true;
|
||||
|
|
Loading…
Reference in New Issue