Page MenuHomeFreeBSD

pf: fix syncookies in conjunction with tcp fast port reuse
ClosedPublic

Authored by kp on Dec 31 2022, 8:50 AM.
Tags
None
Referenced Files
F108537960: D37919.diff
Sun, Jan 26, 1:50 AM
Unknown Object (File)
Mon, Jan 20, 5:57 PM
Unknown Object (File)
Dec 15 2024, 10:11 PM
Unknown Object (File)
Dec 10 2024, 7:33 AM
Unknown Object (File)
Oct 11 2024, 7:27 AM
Unknown Object (File)
Oct 11 2024, 7:25 AM
Unknown Object (File)
Oct 10 2024, 10:14 PM
Unknown Object (File)
Oct 4 2024, 11:44 PM

Details

Summary

Basic scenario: we have a closed connection (In TCPS_FIN_WAIT_2), and
get a new connection (i.e. SYN) re-using the tuple.

Without syncookies we look at the SYN, and completely unlink the old,
closed state on the SYN.
With syncookies we send a generated SYN|ACK back, and drop the SYN,
never looking at the state table.

So when the ACK (i.e. the third step in the three way handshake for
connection setup) turns up, we’ve not actually removed the old state, so
we find it, and don’t do the syncookie dance, or allow the new
connection to get set up.

Explicitly check for this in pf_test_state_tcp(). If we find a state in
TCPS_FIN_WAIT_2 and the syncookie is valid we delete the existing state
so we can set up the new state.
Note that when we verify the syncookie in pf_test_state_tcp() we don't
decrement the number of half-open connections to avoid an incorrect
double decrement.

MFC after: 1 week

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Skipped
Unit
Tests Skipped
Build Status
Buildable 48916
Build 45805: arc lint + arc unit