Skip to content

Commit

Permalink
fix(udp): make GRO (i.e. URO) optional, off by default
Browse files Browse the repository at this point in the history
We have multiple bug reports for URO on Windows, including non-ARM. See:

- quinn-rs#2041
- https://bugzilla.mozilla.org/show_bug.cgi?id=1916558

Instead of enabling GRO on Windows by default, this commit changes the default
to off, adding a `set_gro` to optionally enable it.
  • Loading branch information
mxinden committed Dec 16, 2024
1 parent 18303fc commit 2436041
Showing 1 changed file with 23 additions and 11 deletions.
34 changes: 23 additions & 11 deletions quinn-udp/src/windows.rs
Original file line number Diff line number Diff line change
Expand Up @@ -107,23 +107,35 @@ impl UdpSocketState {
)?;
}

// Opportunistically try to enable GRO
_ = set_socket_option(
&*socket.0,
WinSock::IPPROTO_UDP,
WinSock::UDP_RECV_MAX_COALESCED_SIZE,
// u32 per
// https://learn.microsoft.com/en-us/windows/win32/winsock/ipproto-udp-socket-options.
// Choice of 2^16 - 1 inspired by msquic.
u16::MAX as u32,
);

let now = Instant::now();
Ok(Self {
last_send_error: Mutex::new(now.checked_sub(2 * IO_ERROR_LOG_INTERVAL).unwrap_or(now)),
})
}

/// Enable or disable receive offloading.
///
/// Also referred to as UDP Receive Segment Coalescing Offload (URO) on Windows.
///
/// <https://learn.microsoft.com/en-us/windows-hardware/drivers/network/udp-rsc-offload>
///
/// Disabled by default due to <https://github.com/quinn-rs/quinn/issues/2041>.
pub fn set_gro(&self, enable: bool) -> io::Result<()> {
set_socket_option(
&*socket.0,
WinSock::IPPROTO_UDP,
WinSock::UDP_RECV_MAX_COALESCED_SIZE,
if enable {
// u32 per
// https://learn.microsoft.com/en-us/windows/win32/winsock/ipproto-udp-socket-options.
// Choice of 2^16 - 1 inspired by msquic.
u16::MAX as u32
} else {
0
},
)
}

/// Sends a [`Transmit`] on the given socket.
///
/// This function will only ever return errors of kind [`io::ErrorKind::WouldBlock`].
Expand Down

0 comments on commit 2436041

Please sign in to comment.