| io_uring_prep_sendmsg_zc_fixed(3) | liburing Manual | io_uring_prep_sendmsg_zc_fixed(3) |
NAME
io_uring_prep_sendmsg_zc_fixed - prepare a zero-copy sendmsg using fixed buffers
SYNOPSIS
#include <liburing.h>
void io_uring_prep_sendmsg_zc_fixed(struct io_uring_sqe *sqe,
int fd,
const struct msghdr *msg,
unsigned flags,
unsigned buf_index);
DESCRIPTION
The io_uring_prep_sendmsg_zc_fixed(3) function prepares a zero-copy sendmsg request using fixed (registered) buffers. The submission queue entry sqe is setup to send data on the socket indicated by the file descriptor fd using the message structure msg.
The flags argument contains flags for the sendmsg operation, as described in sendmsg(2).
The buf_index specifies the index of the registered buffer set to use. The buffers in msg must be part of the registered buffer set previously registered with io_uring_register_buffers(3).
Zero-copy sends avoid copying data from user to kernel space, improving performance for large transfers. Using fixed buffers additionally avoids the overhead of mapping buffers for each I/O operation.
Note that zero-copy sends require the application to wait for a notification before reusing the buffer. See io_uring_prep_send_zc(3) for more details on zero-copy semantics.
RETURN VALUE
None
ERRORS
The CQE res field will contain the result of the operation, the number of bytes sent on success. On error, a negative errno value is returned.
SEE ALSO
io_uring_get_sqe(3), io_uring_submit(3), io_uring_prep_sendmsg_zc(3), io_uring_prep_sendmsg(3), io_uring_prep_send_zc_fixed(3), io_uring_register_buffers(3), sendmsg(2)
| January 18, 2025 | liburing-2.10 |