From a992fb1901e0e7aacb11b62b0b5526df4f9bfc34 Mon Sep 17 00:00:00 2001 From: Alan Somers Date: Sat, 19 Aug 2023 02:57:36 +0000 Subject: [PATCH] Merge pull request #2095 from asomers/recvmsg-lifetime Fix an incorrect lifetime in the return value of recvmsg --- src/sys/socket/mod.rs | 2 +- test/sys/test_socket.rs | 10 +++------- 2 files changed, 4 insertions(+), 8 deletions(-) diff --git a/src/sys/socket/mod.rs b/src/sys/socket/mod.rs index 997e265823..e4f3fbc4c5 100644 --- a/src/sys/socket/mod.rs +++ b/src/sys/socket/mod.rs @@ -2051,7 +2051,7 @@ fn pack_mhdr_to_send<'a, I, C, S>( /// [recvmsg(2)](https://pubs.opengroup.org/onlinepubs/9699919799/functions/recvmsg.html) pub fn recvmsg<'a, 'outer, 'inner, S>(fd: RawFd, iov: &'outer mut [IoSliceMut<'inner>], mut cmsg_buffer: Option<&'a mut Vec>, - flags: MsgFlags) -> Result> + flags: MsgFlags) -> Result> where S: SockaddrLike + 'a, 'inner: 'outer { diff --git a/test/sys/test_socket.rs b/test/sys/test_socket.rs index 337c8dc0af..9db5236816 100644 --- a/test/sys/test_socket.rs +++ b/test/sys/test_socket.rs @@ -330,13 +330,9 @@ pub fn test_recvmsg_sockaddr_un() { // Receive the message let mut recv_buffer = [0u8; 32]; - let received = socket::recvmsg( - sock, - &mut [std::io::IoSliceMut::new(&mut recv_buffer)], - None, - MsgFlags::empty(), - ) - .unwrap(); + let mut iov = [std::io::IoSliceMut::new(&mut recv_buffer)]; + let received = + socket::recvmsg(sock, &mut iov, None, MsgFlags::empty()).unwrap(); // Check the address in the received message assert_eq!(sockaddr, received.address.unwrap()); }