summaryrefslogtreecommitdiff
path: root/rust/helpers/bitops.c
diff options
context:
space:
mode:
authorJens Axboe <axboe@kernel.dk>2025-05-07 16:34:24 +0300
committerJens Axboe <axboe@kernel.dk>2025-05-07 16:55:15 +0300
commit687b2bae0efff9b25e071737d6af5004e6e35af5 (patch)
treeed667929806efd8b50851810e52b713dc0ec6fc7 /rust/helpers/bitops.c
parentb53e523261bf058ea4a518b482222e7a277b186b (diff)
downloadlinux-687b2bae0efff9b25e071737d6af5004e6e35af5.tar.xz
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>
Diffstat (limited to 'rust/helpers/bitops.c')
0 files changed, 0 insertions, 0 deletions