Page MenuHomeFreeBSD

Remove TFO from the packet processing path when the kernel is not configured with TCP_RFC7413
ClosedPublic

Authored by jtl on Oct 11 2016, 3:51 PM.
Tags
None
Referenced Files
F108399190: D8219.id21264.diff
Fri, Jan 24, 11:45 AM
Unknown Object (File)
Fri, Jan 10, 1:07 PM
Unknown Object (File)
Wed, Jan 8, 10:56 AM
Unknown Object (File)
Sun, Dec 29, 10:20 AM
Unknown Object (File)
Sun, Dec 29, 10:14 AM
Unknown Object (File)
Dec 22 2024, 7:28 PM
Unknown Object (File)
Dec 22 2024, 7:28 PM
Unknown Object (File)
Oct 31 2024, 4:27 AM
Subscribers

Details

Summary

The TFO server-side code contains some changes that are not conditioned on the TCP_RFC7413 kernel option. This change removes those few instructions from the packet processing path.

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

jtl retitled this revision from to Remove TFO from the packet processing path when the kernel is not configured with TCP_RFC7413.
jtl updated this object.
jtl edited the test plan for this revision. (Show Details)
jtl added reviewers: transport, rrs, gallatin.
hiren added a reviewer: hiren.
hiren added a subscriber: hiren.

Thanks for fixing these corner-cases. :-)

sys/netinet/tcp_input.c
3254 ↗(On Diff #21252)

Is this block necessary?

This revision is now accepted and ready to land.Oct 11 2016, 4:03 PM
sys/netinet/tcp_input.c
3254 ↗(On Diff #21252)

Its not necessary, but it constrains the macro to the same namespace as the variable it overrides.

jtl edited edge metadata.

I guess we should be consistent and use the new macro everywhere in the packet processing path...

This revision now requires review to proceed.Oct 11 2016, 6:35 PM
hiren edited edge metadata.
hiren added inline comments.
sys/netinet/tcp_input.c
3254 ↗(On Diff #21252)

I don't see us doing this to any other vars. Or probably I am missing something that's special with tfo_syn.

This revision is now accepted and ready to land.Oct 11 2016, 11:54 PM
sys/netinet/tcp_input.c
3254 ↗(On Diff #21252)

Normally, variables are confined to the scope in which they are defined. Here, I am trying to eliminate a variable which isn't needed unless TCP_RFC7413 is defined. So, if TCP_RFC7413 isn't defined, I have defined a macro to replace the occurrences of the variable with the constant value false. Just to be tidy, I'm undefining the macro at the end of the function. This gives the macro the same scope as the variable it replaces.

I probably could have achieved similar results with a definition like this:
const bool tfo_syn = false;

However, I thought the macro would be more likely to completely eliminate the instruction in all compilers. (I'm happy to be corrected if there's a more stylistically pleasing way to do this that produces the same functional result. :-) )

sys/netinet/tcp_input.c
3254 ↗(On Diff #21252)

Though I find const bool way cleaner, I'd totally leave it up to you to do it in a fashion that makes all compilers happy. :-) Thanks for answering my questions.

This revision was automatically updated to reflect the committed changes.