Page MenuHomeFreeBSD

Keep doing SACK loss recovery when ACKs suddenly lack SACK blocks
ClosedPublic

Authored by rscheff on Aug 4 2022, 6:48 PM.
Tags
None
Referenced Files
F106931539: D36046.diff
Tue, Jan 7, 4:07 PM
Unknown Object (File)
Fri, Jan 3, 12:21 PM
Unknown Object (File)
Sun, Dec 22, 10:17 AM
Unknown Object (File)
Thu, Dec 12, 10:02 AM
Unknown Object (File)
Dec 1 2024, 9:22 PM
Unknown Object (File)
Dec 1 2024, 9:21 PM
Unknown Object (File)
Dec 1 2024, 8:59 PM
Unknown Object (File)
Nov 30 2024, 12:31 PM
Subscribers

Details

Summary

While a receiver should continue sending SACK blocks for the
duration of a SACK loss recovery, if for some reason the
TCP options no longer contain these SACK blocks, but we
already started maintaining the Scoreboard, keep on handling
incoming ACKs (without SACK) as belonging to the SACK recovery.

This should mitigate an issue with some clients.

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

  • missed closing bracket, and PRR conditional
This revision is now accepted and ready to land.Aug 11 2022, 3:27 PM

Will modify the 3 conditionals to an inline function, with added comments to the two corner cases (RTO when only pure non-SACK dupacks get received; RTO when client renegs receive buffer - and stops sending SACK blocks

  • make logic check an static inline function throughout
This revision now requires review to proceed.Aug 12 2022, 12:00 AM
This revision is now accepted and ready to land.Aug 25 2022, 4:51 PM
This revision now requires review to proceed.Aug 31 2022, 12:06 PM
This revision is now accepted and ready to land.Aug 31 2022, 12:12 PM