diff --git a/quinn-udp/Cargo.toml b/quinn-udp/Cargo.toml index f65d8ae38..4cbe86019 100644 --- a/quinn-udp/Cargo.toml +++ b/quinn-udp/Cargo.toml @@ -20,7 +20,7 @@ log = ["tracing/log"] direct-log = ["dep:log"] [dependencies] -libc = "0.2.113" +libc = "0.2.158" log = { workspace = true, optional = true } socket2 = { workspace = true } tracing = { workspace = true, optional = true } diff --git a/quinn-udp/src/unix.rs b/quinn-udp/src/unix.rs index 34def460e..7033b6191 100644 --- a/quinn-udp/src/unix.rs +++ b/quinn-udp/src/unix.rs @@ -1,4 +1,9 @@ -#[cfg(not(any(target_os = "macos", target_os = "ios", target_os = "openbsd")))] +#[cfg(not(any( + target_os = "macos", + target_os = "ios", + target_os = "openbsd", + target_os = "solaris", +)))] use std::ptr; use std::{ io::{self, IoSliceMut}, @@ -62,6 +67,7 @@ impl UdpSocketState { || cfg!(target_os = "macos") || cfg!(target_os = "ios") || cfg!(target_os = "android") + || cfg!(target_os = "solaris") { cmsg_platform_space += unsafe { libc::CMSG_SPACE(mem::size_of::() as _) as usize }; @@ -84,7 +90,7 @@ impl UdpSocketState { // mac and ios do not support IP_RECVTOS on dual-stack sockets :( // older macos versions also don't have the flag and will error out if we don't ignore it - #[cfg(not(any(target_os = "openbsd", target_os = "netbsd")))] + #[cfg(not(any(target_os = "openbsd", target_os = "netbsd", target_os = "solaris")))] if is_ipv4 || !io.only_v6()? { if let Err(_err) = set_socket_option(&*io, libc::IPPROTO_IP, libc::IP_RECVTOS, OPTION_ON) @@ -138,10 +144,11 @@ impl UdpSocketState { target_os = "openbsd", target_os = "netbsd", target_os = "macos", - target_os = "ios" + target_os = "ios", + target_os = "solaris", ))] // IP_RECVDSTADDR == IP_SENDSRCADDR on FreeBSD - // macOS uses only IP_RECVDSTADDR, no IP_SENDSRCADDR on macOS + // macOS uses only IP_RECVDSTADDR, no IP_SENDSRCADDR on macOS (the same on Solaris) // macOS also supports IP_PKTINFO { if is_ipv4 { @@ -367,7 +374,12 @@ fn send(state: &UdpSocketState, io: SockRef<'_>, transmit: &Transmit<'_>) -> io: Ok(()) } -#[cfg(not(any(target_os = "macos", target_os = "ios", target_os = "openbsd")))] +#[cfg(not(any( + target_os = "macos", + target_os = "ios", + target_os = "openbsd", + target_os = "solaris", +)))] fn recv(io: SockRef<'_>, bufs: &mut [IoSliceMut<'_>], meta: &mut [RecvMeta]) -> io::Result { let mut names = [MaybeUninit::::uninit(); BATCH_SIZE]; let mut ctrls = [cmsg::Aligned(MaybeUninit::<[u8; CMSG_LEN]>::uninit()); BATCH_SIZE]; @@ -404,7 +416,12 @@ fn recv(io: SockRef<'_>, bufs: &mut [IoSliceMut<'_>], meta: &mut [RecvMeta]) -> Ok(msg_count as usize) } -#[cfg(any(target_os = "macos", target_os = "ios", target_os = "openbsd"))] +#[cfg(any( + target_os = "macos", + target_os = "ios", + target_os = "openbsd", + target_os = "solaris", +))] fn recv(io: SockRef<'_>, bufs: &mut [IoSliceMut<'_>], meta: &mut [RecvMeta]) -> io::Result { let mut name = MaybeUninit::::uninit(); let mut ctrl = cmsg::Aligned(MaybeUninit::<[u8; CMSG_LEN]>::uninit()); @@ -433,7 +450,12 @@ fn recv(io: SockRef<'_>, bufs: &mut [IoSliceMut<'_>], meta: &mut [RecvMeta]) -> /// /// It uses [`libc::syscall`] instead of [`libc::recvmmsg`] /// to avoid linking error on systems where libc does not contain `recvmmsg`. -#[cfg(not(any(target_os = "macos", target_os = "ios", target_os = "openbsd")))] +#[cfg(not(any( + target_os = "macos", + target_os = "ios", + target_os = "openbsd", + target_os = "solaris", +)))] unsafe fn recvmmsg_with_fallback( sockfd: libc::c_int, msgvec: *mut libc::mmsghdr, @@ -476,7 +498,12 @@ unsafe fn recvmmsg_with_fallback( /// Fallback implementation of `recvmmsg` using `recvmsg` /// for systems which do not support `recvmmsg` /// such as Linux <2.6.33. -#[cfg(not(any(target_os = "macos", target_os = "ios", target_os = "openbsd")))] +#[cfg(not(any( + target_os = "macos", + target_os = "ios", + target_os = "openbsd", + target_os = "solaris", +)))] unsafe fn recvmmsg_fallback( sockfd: libc::c_int, msgvec: *mut libc::mmsghdr, @@ -567,6 +594,7 @@ fn prepare_msg( target_os = "netbsd", target_os = "macos", target_os = "ios", + target_os = "solaris", ))] { if encode_src_ip { @@ -625,7 +653,7 @@ fn decode_recv( ecn_bits = cmsg::decode::(cmsg); }, // FreeBSD uses IP_RECVTOS here, and we can be liberal because cmsgs are opt-in. - #[cfg(not(any(target_os = "openbsd", target_os = "netbsd")))] + #[cfg(not(any(target_os = "openbsd", target_os = "netbsd", target_os = "solaris")))] (libc::IPPROTO_IP, libc::IP_RECVTOS) => unsafe { ecn_bits = cmsg::decode::(cmsg); }, diff --git a/quinn-udp/tests/tests.rs b/quinn-udp/tests/tests.rs index 4c06c488f..7915c9f84 100644 --- a/quinn-udp/tests/tests.rs +++ b/quinn-udp/tests/tests.rs @@ -1,4 +1,4 @@ -#[cfg(not(any(target_os = "openbsd", target_os = "netbsd")))] +#[cfg(not(any(target_os = "openbsd", target_os = "netbsd", target_os = "solaris")))] use std::net::{SocketAddr, SocketAddrV4, SocketAddrV6}; use std::{ io::IoSliceMut, @@ -51,7 +51,7 @@ fn ecn_v6() { } #[test] -#[cfg(not(any(target_os = "openbsd", target_os = "netbsd")))] +#[cfg(not(any(target_os = "openbsd", target_os = "netbsd", target_os = "solaris")))] fn ecn_v4() { let send = Socket::from(UdpSocket::bind("127.0.0.1:0").unwrap()); let recv = Socket::from(UdpSocket::bind("127.0.0.1:0").unwrap()); @@ -71,7 +71,7 @@ fn ecn_v4() { } #[test] -#[cfg(not(any(target_os = "openbsd", target_os = "netbsd")))] +#[cfg(not(any(target_os = "openbsd", target_os = "netbsd", target_os = "solaris")))] fn ecn_v6_dualstack() { let recv = socket2::Socket::new( socket2::Domain::IPV6, @@ -114,7 +114,7 @@ fn ecn_v6_dualstack() { } #[test] -#[cfg(not(any(target_os = "openbsd", target_os = "netbsd")))] +#[cfg(not(any(target_os = "openbsd", target_os = "netbsd", target_os = "solaris")))] fn ecn_v4_mapped_v6() { let send = socket2::Socket::new( socket2::Domain::IPV6,