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
F108310420: D36046.id109210.diff
Thu, Jan 23, 6:38 PM
Unknown Object (File)
Sat, Jan 18, 9:47 PM
Unknown Object (File)
Wed, Jan 15, 12:50 PM
Unknown Object (File)
Wed, Jan 15, 12:47 PM
Unknown Object (File)
Wed, Jan 15, 12:45 PM
Unknown Object (File)
Wed, Jan 15, 12:42 PM
Unknown Object (File)
Wed, Jan 15, 12:40 PM
Unknown Object (File)
Thu, Jan 9, 3:16 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