mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-15 01:44:52 +00:00
nvme-pci: Hold cq_poll_lock while completing CQEs
Completions need to consumed in the same order the controller submitted them, otherwise future completion entries may overwrite ones we haven't handled yet. Hold the nvme queue's poll lock while completing new CQEs to prevent another thread from freeing command tags for reuse out-of-order. Fixes: dabcefab45d3 ("nvme: provide optimized poll function for separate poll queues") Signed-off-by: Bijan Mottahedeh <bijan.mottahedeh@oracle.com> Reviewed-by: Sagi Grimberg <sagi@grimberg.me> Reviewed-by: Jens Axboe <axboe@kernel.dk> Signed-off-by: Keith Busch <kbusch@kernel.org>
This commit is contained in:
parent
cae740a04b
commit
9515743bfb
@ -1078,9 +1078,9 @@ static int nvme_poll(struct blk_mq_hw_ctx *hctx)
|
|||||||
|
|
||||||
spin_lock(&nvmeq->cq_poll_lock);
|
spin_lock(&nvmeq->cq_poll_lock);
|
||||||
found = nvme_process_cq(nvmeq, &start, &end, -1);
|
found = nvme_process_cq(nvmeq, &start, &end, -1);
|
||||||
|
nvme_complete_cqes(nvmeq, start, end);
|
||||||
spin_unlock(&nvmeq->cq_poll_lock);
|
spin_unlock(&nvmeq->cq_poll_lock);
|
||||||
|
|
||||||
nvme_complete_cqes(nvmeq, start, end);
|
|
||||||
return found;
|
return found;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user