]> www.infradead.org Git - users/dwmw2/qemu.git/commitdiff
linux-user: always translate cmsg when recvmsg
authorIcenowy Zheng <uwu@icenowy.me>
Fri, 28 Oct 2022 08:12:20 +0000 (16:12 +0800)
committerLaurent Vivier <laurent@vivier.eu>
Wed, 2 Nov 2022 16:29:17 +0000 (17:29 +0100)
It's possible that a message contains both normal payload and ancillary
data in the same message, and even if no ancillary data is available
this information should be passed to the target, otherwise the target
cmsghdr will be left uninitialized and the target is going to access
uninitialized memory if it expects cmsg.

Always call the function that translate cmsg when recvmsg, because that
function should be empty-cmsg-safe (it creates an empty cmsg in the
target).

Signed-off-by: Icenowy Zheng <uwu@icenowy.me>
Reviewed-by: Laurent Vivier <laurent@vivier.eu>
Message-Id: <20221028081220.1604244-1-uwu@icenowy.me>
Signed-off-by: Laurent Vivier <laurent@vivier.eu>
linux-user/syscall.c

index 8b18adfba89442fb8c83b4cb1c4a2d3ffce6b820..24b25759beabbe76d7582b99bfe76d9096326149 100644 (file)
@@ -3353,7 +3353,8 @@ static abi_long do_sendrecvmsg_locked(int fd, struct target_msghdr *msgp,
             if (fd_trans_host_to_target_data(fd)) {
                 ret = fd_trans_host_to_target_data(fd)(msg.msg_iov->iov_base,
                                                MIN(msg.msg_iov->iov_len, len));
-            } else {
+            }
+            if (!is_error(ret)) {
                 ret = host_to_target_cmsg(msgp, &msg);
             }
             if (!is_error(ret)) {