Page MenuHomeFreeBSD

Fix IP ECN codepoint for SACK retransmissions (RFC3168)
ClosedPublic

Authored by rscheff on Jan 9 2020, 11:54 PM.
Tags
None
Referenced Files
Unknown Object (File)
Sat, Jan 18, 6:54 PM
Unknown Object (File)
Dec 13 2024, 5:27 AM
Unknown Object (File)
Dec 11 2024, 11:55 AM
Unknown Object (File)
Dec 10 2024, 8:59 AM
Unknown Object (File)
Nov 25 2024, 4:26 AM
Unknown Object (File)
Nov 23 2024, 2:39 PM
Unknown Object (File)
Nov 22 2024, 9:54 PM
Unknown Object (File)
Nov 22 2024, 12:35 PM
Subscribers

Details

Summary

retransmissions during SACK loss recovery are not using adjusted snd_nxt and thus get marked as ECT0, not strictly according to RFC3168.
This is addressing Bug report 243231.

Note that this behavior is in-line with ECN++ (work in progress @ IETF).

Since this interaction between ECN and SACK has been in production, it must have had similar exposure as ECN itself...

Further note that the compliant RFC3168 behavior might lead to higher RTO rates, as not-ECT marked retransmissions are prone to higher loss rates in congested enviornments, if the oversaturated queue could still mark packets with CE instead of dropping. With other words, this patches an RFC compliance violation, but might result in less good performance in existing ECN deployments.

Test Plan

packetdrill script - set up a session with ECN negotiated, and also SACK enabled. Observe the IP ECN codepoint of the retransmission when not acknowleding transmitted data by packetdrill.

Diff Detail

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

Event Timeline

How did you run into this one?

Testing and validating Cubic with ECN (and implicitly SACK) over two simulated congestion points (one with ECN, one loss-based).

  • rexmit w/o ip ect mark now in rack too

Randall, can you please validate that this is sufficient for the RACK stack?

I see that when you do rack resends, that the sack_rxmit is also set - can you confirm that this should always be the case (also for TLP resends)?

Did not find any problem in bsd11.

This revision is now accepted and ready to land.Jan 25 2020, 1:28 PM