diff options
author | Jens Axboe <axboe@kernel.dk> | 2025-06-13 13:37:41 -0600 |
---|---|---|
committer | Jens Axboe <axboe@kernel.dk> | 2025-06-13 15:18:34 -0600 |
commit | 9ce6c9875f3e995be5fd720b65835291f8a609b1 (patch) | |
tree | 6e6bba15cdeeb8737d03b322017c5d159a2795ac /kernel/locking/rtmutex_api.c | |
parent | db3dfae1a2f662e69d535827703bcdbb04b8d72b (diff) |
nvme: always punt polled uring_cmd end_io work to task_work
Currently NVMe uring_cmd completions will complete locally, if they are
polled. This is done because those completions are always invoked from
task context. And while that is true, there's no guarantee that it's
invoked under the right ring context, or even task. If someone does
NVMe passthrough via multiple threads and with a limited number of
poll queues, then ringA may find completions from ringB. For that case,
completing the request may not be sound.
Always just punt the passthrough completions via task_work, which will
redirect the completion, if needed.
Cc: stable@vger.kernel.org
Fixes: 585079b6e425 ("nvme: wire up async polling for io passthrough commands")
Signed-off-by: Jens Axboe <axboe@kernel.dk>
Diffstat (limited to 'kernel/locking/rtmutex_api.c')
0 files changed, 0 insertions, 0 deletions