Files
linux-stable-mirror/include/uapi/linux
Dylan Yudaken b3fdea6ecb io_uring: multishot recv
Support multishot receive for io_uring.
Typical server applications will run a loop where for each recv CQE it
requeues another recv/recvmsg.

This can be simplified by using the existing multishot functionality
combined with io_uring's provided buffers.
The API is to add the IORING_RECV_MULTISHOT flag to the SQE. CQEs will
then be posted (with IORING_CQE_F_MORE flag set) when data is available
and is read. Once an error occurs or the socket ends, the multishot will
be removed and a completion without IORING_CQE_F_MORE will be posted.

The benefit to this is that the recv is much more performant.
 * Subsequent receives are queued up straight away without requiring the
   application to finish a processing loop.
 * If there are more data in the socket (sat the provided buffer size is
   smaller than the socket buffer) then the data is immediately
   returned, improving batching.
 * Poll is only armed once and reused, saving CPU cycles

Signed-off-by: Dylan Yudaken <dylany@fb.com>
Link: https://lore.kernel.org/r/20220630091231.1456789-11-dylany@fb.com
Signed-off-by: Jens Axboe <axboe@kernel.dk>
2022-07-24 18:39:17 -06:00
..
2022-04-19 13:13:47 +01:00
2022-06-03 20:09:27 +08:00
2022-06-03 20:09:27 +08:00
2022-04-04 08:55:23 +02:00
2022-03-11 08:28:05 -08:00
2022-03-01 18:29:27 -08:00
2022-07-24 18:39:17 -06:00
2022-06-03 20:09:27 +08:00
2022-05-04 22:50:01 +02:00
2022-05-31 12:44:29 -04:00