Skip to content

Conversation

@XAMPPRocky
Copy link

Allows setting UDP_GRO on the socket.

https://www.man7.org/linux/man-pages/man7/udp.7.html

Enables UDP receive offload. If enabled, the socket may
receive multiple datagrams worth of data as a single large
buffer, together with a cmsg(3) that holds the segment
size. This option is the inverse of segmentation offload.
It reduces receive cost by handling multiple datagrams
worth of data as a single large packet in the kernel
receive path, even when that exceeds MTU. This option
should not be used in code intended to be portable.

Copy link
Collaborator

@Thomasdezeeuw Thomasdezeeuw left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Since this Linux only, can you put in the sys/unix.rs file:

impl SockAddr {

Could also you make sure it's order by option name.

Can you add the appropriate attributes, e.g. see

socket2/src/sys/unix.rs

Lines 791 to 795 in 3a93893

#[cfg(all(feature = "all", any(target_os = "android", target_os = "linux")))]
#[cfg_attr(
docsrs,
doc(cfg(all(feature = "all", any(target_os = "android", target_os = "linux"))))
)]

Finally can you add a test? A simple set and get test is sufficient, see

test!(reuse_port, set_reuse_port(true));

@XAMPPRocky
Copy link
Author

@Thomasdezeeuw Thank you, I've implemented your feedback, the only thing I wasn't 100% sure on was "Could also you make sure it's order by option name." let me know if I need to make more changes

@Thomasdezeeuw Thomasdezeeuw enabled auto-merge (squash) November 21, 2024 12:24
@Thomasdezeeuw
Copy link
Collaborator

Thanks @XAMPPRocky

@Thomasdezeeuw
Copy link
Collaborator

@XAMPPRocky sorry for leaving this so long. I'm not sure why I didn't merge after I approved it. I tried rebase the branch, but GitHub won't allow me (I think it's because it's the master branch, but not sure). I've opened #577 which is the same patch, but rebased.

@Thomasdezeeuw Thomasdezeeuw mentioned this pull request May 24, 2025
@Thomasdezeeuw
Copy link
Collaborator

It seems like the CI is failing, even with a rebase. @XAMPPRocky do you have time to look at it? I totally understand if you've lost interest after all this time.

@XAMPPRocky
Copy link
Author

XAMPPRocky commented May 24, 2025

Hey, yeah my initial need for the option has gone as the project I was using it in now uses XDP sockets which bypass this setting. I'lll try to fixup the PR next week though.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants