Skip to content

Commit 983aeac

Browse files
committed
io_uring: ensure deferred completions are flushed for multishot
JIRA: https://issues.redhat.com/browse/RHEL-102863 commit 687b2ba Author: Jens Axboe <axboe@kernel.dk> Date: Wed May 7 07:34:24 2025 -0600 io_uring: ensure deferred completions are flushed for multishot Multishot normally uses io_req_post_cqe() to post completions, but when stopping it, it may finish up with a deferred completion. This is fine, except if another multishot event triggers before the deferred completions get flushed. If this occurs, then CQEs may get reordered in the CQ ring, as new multishot completions get posted before the deferred ones are flushed. This can cause confusion on the application side, if strict ordering is required for the use case. When multishot posting via io_req_post_cqe(), flush any pending deferred completions first, if any. Cc: stable@vger.kernel.org # 6.1+ Reported-by: Norman Maurer <norman_maurer@apple.com> Reported-by: Christian Mazakas <christian.mazakas@gmail.com> Signed-off-by: Jens Axboe <axboe@kernel.dk> Signed-off-by: Jeff Moyer <jmoyer@redhat.com>
1 parent e67fe5a commit 983aeac

File tree

1 file changed

+8
-0
lines changed

1 file changed

+8
-0
lines changed

io_uring/io_uring.c

Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -880,6 +880,14 @@ bool io_req_post_cqe(struct io_kiocb *req, s32 res, u32 cflags)
880880
struct io_ring_ctx *ctx = req->ctx;
881881
bool posted;
882882

883+
/*
884+
* If multishot has already posted deferred completions, ensure that
885+
* those are flushed first before posting this one. If not, CQEs
886+
* could get reordered.
887+
*/
888+
if (!wq_list_empty(&ctx->submit_state.compl_reqs))
889+
__io_submit_flush_completions(ctx);
890+
883891
lockdep_assert(!io_wq_current_is_worker());
884892
lockdep_assert_held(&ctx->uring_lock);
885893

0 commit comments

Comments
 (0)