提交 d9cf5dcd 编写于 作者: J Jens Axboe 提交者: Xie XiuQi

io_uring: make ctx cancel on exit targeted to actual ctx

stable inclusion
from stable-5.10.4
commit 7b81e2af5a55b07016afa81123d40acf70c994c0
bugzilla: 46903

--------------------------------

commit 00c18640 upstream.

Before IORING_SETUP_ATTACH_WQ, we could just cancel everything on the
io-wq when exiting. But that's not the case if they are shared, so
cancel for the specific ctx instead.

Cc: stable@vger.kernel.org
Fixes: 24369c2e ("io_uring: add io-wq workqueue sharing")
Signed-off-by: NJens Axboe <axboe@kernel.dk>
Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: NChen Jun <chenjun102@huawei.com>
Acked-by: NXie XiuQi <xiexiuqi@huawei.com>
上级 66bb8f08
...@@ -8401,6 +8401,13 @@ static void io_ring_exit_work(struct work_struct *work) ...@@ -8401,6 +8401,13 @@ static void io_ring_exit_work(struct work_struct *work)
io_ring_ctx_free(ctx); io_ring_ctx_free(ctx);
} }
static bool io_cancel_ctx_cb(struct io_wq_work *work, void *data)
{
struct io_kiocb *req = container_of(work, struct io_kiocb, work);
return req->ctx == data;
}
static void io_ring_ctx_wait_and_kill(struct io_ring_ctx *ctx) static void io_ring_ctx_wait_and_kill(struct io_ring_ctx *ctx)
{ {
mutex_lock(&ctx->uring_lock); mutex_lock(&ctx->uring_lock);
...@@ -8415,7 +8422,7 @@ static void io_ring_ctx_wait_and_kill(struct io_ring_ctx *ctx) ...@@ -8415,7 +8422,7 @@ static void io_ring_ctx_wait_and_kill(struct io_ring_ctx *ctx)
io_poll_remove_all(ctx, NULL); io_poll_remove_all(ctx, NULL);
if (ctx->io_wq) if (ctx->io_wq)
io_wq_cancel_all(ctx->io_wq); io_wq_cancel_cb(ctx->io_wq, io_cancel_ctx_cb, ctx, true);
/* if we failed setting up the ctx, we might not have any rings */ /* if we failed setting up the ctx, we might not have any rings */
io_iopoll_try_reap_events(ctx); io_iopoll_try_reap_events(ctx);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册