Page MenuHomeFreeBSD

tcp: filter small SACK blocks
ClosedPublic

Authored by rscheff on May 3 2024, 10:48 AM.
Tags
None
Referenced Files
Unknown Object (File)
Fri, Jan 10, 10:15 PM
Unknown Object (File)
Fri, Jan 10, 6:56 PM
Unknown Object (File)
Fri, Jan 10, 9:38 AM
Unknown Object (File)
Sat, Jan 4, 12:58 PM
Unknown Object (File)
Dec 9 2024, 1:24 AM
Unknown Object (File)
Nov 28 2024, 5:50 PM
Unknown Object (File)
Nov 28 2024, 5:50 PM
Unknown Object (File)
Nov 28 2024, 5:50 PM
Subscribers

Details

Summary

While the SACK Scoreboard in the base stack limits
the number of holes by default to only 128 per connection
in order to prevent CPU load attacks by splitting SACKs,
filtering out SACK blocks of unusually small size can
further improve the actual processing of SACK loss recovery.

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 57577
Build 54465: arc lint + arc unit

Event Timeline

I'm wondering if it would be better to require that the sack block covers at least mss - 40 bytes. We don't know if we sent a SACK or AccECN option and it doesn't make sense to ignore the SACK blocks corresponding to such packets we sent not performing an attack.

  • filter out any segments smaller than the current maxseg size minus maximum tcp header options
This revision is now accepted and ready to land.May 7 2024, 5:55 PM
This revision was automatically updated to reflect the committed changes.