mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-07 13:43:51 +00:00
io_uring: fix potential use after free on fallback request free
After __io_free_req() puts a ctx ref, it should be assumed that the ctx may already be gone. However, it can be accessed when putting the fallback req. Free the req first and then put the ctx. Signed-off-by: Pavel Begunkov <asml.silence@gmail.com> Signed-off-by: Jens Axboe <axboe@kernel.dk>
This commit is contained in:
parent
8eb7e2d007
commit
ecfc517774
@ -1526,12 +1526,15 @@ static void io_dismantle_req(struct io_kiocb *req)
|
|||||||
|
|
||||||
static void __io_free_req(struct io_kiocb *req)
|
static void __io_free_req(struct io_kiocb *req)
|
||||||
{
|
{
|
||||||
|
struct io_ring_ctx *ctx;
|
||||||
|
|
||||||
io_dismantle_req(req);
|
io_dismantle_req(req);
|
||||||
percpu_ref_put(&req->ctx->refs);
|
ctx = req->ctx;
|
||||||
if (likely(!io_is_fallback_req(req)))
|
if (likely(!io_is_fallback_req(req)))
|
||||||
kmem_cache_free(req_cachep, req);
|
kmem_cache_free(req_cachep, req);
|
||||||
else
|
else
|
||||||
clear_bit_unlock(0, (unsigned long *) &req->ctx->fallback_req);
|
clear_bit_unlock(0, (unsigned long *) &ctx->fallback_req);
|
||||||
|
percpu_ref_put(&ctx->refs);
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool io_link_cancel_timeout(struct io_kiocb *req)
|
static bool io_link_cancel_timeout(struct io_kiocb *req)
|
||||||
|
Loading…
Reference in New Issue
Block a user