mirror of
https://github.com/tbsdtv/linux_media.git
synced 2025-07-23 20:51:03 +02:00
io_uring/net: clear msg_controllen on partial sendmsg retry
If we have cmsg attached AND we transferred partial data at least, clear
msg_controllen on retry so we don't attempt to send that again.
Cc: stable@vger.kernel.org # 5.10+
Fixes: cac9e4418f
("io_uring/net: save msghdr->msg_control for retries")
Reported-by: Stefan Metzmacher <metze@samba.org>
Reviewed-by: Stefan Metzmacher <metze@samba.org>
Signed-off-by: Jens Axboe <axboe@kernel.dk>
This commit is contained in:
@@ -326,6 +326,8 @@ int io_sendmsg(struct io_kiocb *req, unsigned int issue_flags)
|
|||||||
if (ret == -EAGAIN && (issue_flags & IO_URING_F_NONBLOCK))
|
if (ret == -EAGAIN && (issue_flags & IO_URING_F_NONBLOCK))
|
||||||
return io_setup_async_msg(req, kmsg, issue_flags);
|
return io_setup_async_msg(req, kmsg, issue_flags);
|
||||||
if (ret > 0 && io_net_retry(sock, flags)) {
|
if (ret > 0 && io_net_retry(sock, flags)) {
|
||||||
|
kmsg->msg.msg_controllen = 0;
|
||||||
|
kmsg->msg.msg_control = NULL;
|
||||||
sr->done_io += ret;
|
sr->done_io += ret;
|
||||||
req->flags |= REQ_F_PARTIAL_IO;
|
req->flags |= REQ_F_PARTIAL_IO;
|
||||||
return io_setup_async_msg(req, kmsg, issue_flags);
|
return io_setup_async_msg(req, kmsg, issue_flags);
|
||||||
|
Reference in New Issue
Block a user