summaryrefslogtreecommitdiff
path: root/io_uring/net.c
diff options
context:
space:
mode:
authorPavel Begunkov <asml.silence@gmail.com>2022-08-24 15:07:41 +0300
committerJens Axboe <axboe@kernel.dk>2022-08-24 17:57:28 +0300
commit53bdc88aac9a21aae937452724fa4738cd843795 (patch)
tree9f3c2b3ecf2c84631b305b29328e348ef61fbbb2 /io_uring/net.c
parent986e263def32eec89153babf469859d837507d34 (diff)
downloadlinux-53bdc88aac9a21aae937452724fa4738cd843795.tar.xz
io_uring/notif: order notif vs send CQEs
Currently, there is no ordering between notification CQEs and completions of the send flushing it, this quite complicates the userspace, especially since we don't flush notification when the send(+flush) request fails, i.e. there will be only one CQE. What we can do is to make sure that notification completions come only after sends. The easiest way to achieve this is to not try to complete a notification inline from io_sendzc() but defer it to task_work, considering that io-wq sendzc is disallowed CQEs will be naturally ordered because task_works will only be executed after we're done with submission and so inline completion. Signed-off-by: Pavel Begunkov <asml.silence@gmail.com> Link: https://lore.kernel.org/r/cddfd1c2bf91f22b9fe08e13b7dffdd8f858a151.1661342812.git.asml.silence@gmail.com Signed-off-by: Jens Axboe <axboe@kernel.dk>
Diffstat (limited to 'io_uring/net.c')
0 files changed, 0 insertions, 0 deletions