Page MenuHomeFreeBSD

Add a --sctp flag to nc.
ClosedPublic

Authored by markj on Jul 10 2020, 4:27 PM.
Tags
None
Referenced Files
F106675383: D25610.diff
Fri, Jan 3, 5:58 PM
Unknown Object (File)
Oct 28 2024, 2:04 AM
Unknown Object (File)
Oct 28 2024, 2:04 AM
Unknown Object (File)
Oct 28 2024, 2:04 AM
Unknown Object (File)
Oct 28 2024, 1:52 AM
Unknown Object (File)
Oct 15 2024, 4:03 AM
Unknown Object (File)
Oct 9 2024, 10:58 PM
Unknown Object (File)
Oct 9 2024, 5:38 AM
Subscribers

Details

Summary

This is handy for testing, as we don't have a lot of SCTP-enabled code
in the base system. traceroute(6) supports SCTP but uses raw sockets.

The change just adds an SCTP mode akin to UDP mode. We could perhaps
extend this further and make use of the SCTP syscalls to exercise some
unique SCTP features, but I'm not very familiar with them. If anyone
has any suggestions I will try to implement them.

Use a long option to minimize the risk of conflicts with OpenBSD, which
has about 40 single-char option flags. For bonus points, this change
unbreaks --no-tcpopt by adding a missing case required by getopt_long().

Diff Detail

Lint
No Lint Coverage
Unit
No Test Coverage
Build Status
Buildable 32226
Build 29719: arc lint + arc unit

Event Timeline

markj requested review of this revision.Jul 10 2020, 4:27 PM
markj created this revision.
This revision is now accepted and ready to land.Jul 10 2020, 4:43 PM

I'm willing to add support for SCTP features which make sense for nc over time. Just wasn't sure if this is acceptable for contributed code...

I'm willing to add support for SCTP features which make sense for nc over time. Just wasn't sure if this is acceptable for contributed code...

The impression I got from talking to a couple of folks on IRC is that upstream (OpenBSD) has already diverged quite a lot, so it is acceptable to add FreeBSD-specific code here, especially if it uses long options like --sctp so as to avoid conflicts. @delphij was the last to work on keeping us in sync, so I defer to him on this.

This revision was automatically updated to reflect the committed changes.

I'm willing to add support for SCTP features which make sense for nc over time. Just wasn't sure if this is acceptable for contributed code...

The impression I got from talking to a couple of folks on IRC is that upstream (OpenBSD) has already diverged quite a lot, so it is acceptable to add FreeBSD-specific code here, especially if it uses long options like --sctp so as to avoid conflicts. @delphij was the last to work on keeping us in sync, so I defer to him on this.

Thanks for the information. Since OpenBSD has no SCTP support, I thought it is hard to go via upstream. But if additions are acceptable, I'll add some features. Will put @delphij on the corresponding reviews.