mirror of
https://github.com/torvalds/linux.git
synced 2024-11-22 12:11:40 +00:00
io_uring: fix a layering violation in io_iopoll_req_issued
syscall-level code can't just poke into the details of the poll cookie, which is private information of the block layer. Signed-off-by: Christoph Hellwig <hch@lst.de> Link: https://lore.kernel.org/r/20211012111226.760968-5-hch@lst.de Signed-off-by: Jens Axboe <axboe@kernel.dk>
This commit is contained in:
parent
f79d474905
commit
30da1b45b1
@ -2738,19 +2738,12 @@ static void io_iopoll_req_issued(struct io_kiocb *req)
|
||||
ctx->poll_multi_queue = false;
|
||||
} else if (!ctx->poll_multi_queue) {
|
||||
struct io_kiocb *list_req;
|
||||
unsigned int queue_num0, queue_num1;
|
||||
|
||||
list_req = list_first_entry(&ctx->iopoll_list, struct io_kiocb,
|
||||
inflight_entry);
|
||||
|
||||
if (list_req->file != req->file) {
|
||||
if (list_req->file != req->file)
|
||||
ctx->poll_multi_queue = true;
|
||||
} else {
|
||||
queue_num0 = blk_qc_t_to_queue_num(list_req->rw.kiocb.ki_cookie);
|
||||
queue_num1 = blk_qc_t_to_queue_num(req->rw.kiocb.ki_cookie);
|
||||
if (queue_num0 != queue_num1)
|
||||
ctx->poll_multi_queue = true;
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
|
Loading…
Reference in New Issue
Block a user