Page MenuHomeFreeBSD

tcp: enable LRD by default and move sysctl from tcp.do_lrd tp tcp.sack.lrd
ClosedPublic

Authored by rscheff on Nov 29 2023, 11:00 PM.
Tags
None
Referenced Files
Unknown Object (File)
Thu, Jan 23, 6:47 PM
Unknown Object (File)
Sat, Jan 18, 9:53 PM
Unknown Object (File)
Dec 19 2024, 9:24 AM
Unknown Object (File)
Dec 2 2024, 4:52 PM
Unknown Object (File)
Dec 2 2024, 4:52 PM
Unknown Object (File)
Dec 2 2024, 4:52 PM
Unknown Object (File)
Dec 2 2024, 4:51 PM
Unknown Object (File)
Dec 2 2024, 4:28 PM
Subscribers

Details

Summary

Lost Retransmission Detection was added as a feature in May 2021, but disabled by default.

It is time to enable this feature to reduce the completion time / SRT by avoiding RTOs when retransmissions get lost too by default.

While here, moving the sysctl control to the tcp.sack branch, as LRD only works in conjunction with SACK loss recovery - and update the tcp.4 man page accordingly.

MFC after: 10 weeks

Test Plan

repeatedly loose the same segment - the base stack should (if not running out of cwnd first) retry multiple times to send the repeatedly lost packet again.

Diff Detail

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

Event Timeline

Question: can the moving of the sysctl variable be MFCed? Enabling the feature can, of course.

Question: can the moving of the sysctl variable be MFCed? Enabling the feature can, of course.

It is user visible change. I think it can NOT be MFCed unless it is treated as debugging purpose only knob.

I'm OK with "enable LRD by default" .

In D42845#977248, @zlei wrote:

Question: can the moving of the sysctl variable be MFCed? Enabling the feature can, of course.

It is user visible change. I think it can NOT be MFCed unless it is treated as debugging purpose only knob.

I'm OK with "enable LRD by default" .

While looking at the original commit, I also had a special sockopt added; I don't think that anyone ever used this really, for true A/B testing (whcih was the reason to have it in the first place).

Moving the lrd sysctl to become part of the sack subtree makes IMHO sense (and I should really have done it ffrom the beginnig), as LRD only works with SACK (there exists DupACK counting mechansims to approximate this, but that would be more fragile under some network pathologies).

I could leave out the MFC for the sysctl part (or better: split this into a MFC enable by default, and a non-MFC for all other changes) - but really would like to know if keeping the sockopt makes sense - few other singular mechanisms entertain their own sockopt to be programmatically changed on a session-by-session basis....

In D42845#977248, @zlei wrote:

Question: can the moving of the sysctl variable be MFCed? Enabling the feature can, of course.

It is user visible change. I think it can NOT be MFCed unless it is treated as debugging purpose only knob.

I'm OK with "enable LRD by default" .

While looking at the original commit, I also had a special sockopt added; I don't think that anyone ever used this really, for true A/B testing (whcih was the reason to have it in the first place).

Does this feature apply only to the base stack or also to the RACK/BBR stack?

Moving the lrd sysctl to become part of the sack subtree makes IMHO sense (and I should really have done it ffrom the beginnig), as LRD only works with SACK (there exists DupACK counting mechansims to approximate this, but that would be more fragile under some network pathologies).

I could leave out the MFC for the sysctl part (or better: split this into a MFC enable by default, and a non-MFC for all other changes) - but really would like to know if keeping the sockopt makes sense - few other singular mechanisms entertain their own sockopt to be programmatically changed on a session-by-session basis....

I guess it would be good to split the patch up in two: one changing the default, which can be MFCed, one being the move of the sysctl node, which can't be MFCed.

  • tcp: enable lost retransmission detection by default

Does this feature apply only to the base stack or also to the RACK/BBR stack?

Only the base stack; RACK deals with lost retransmissions as an emergent property of the RACK mechanism and per-segment state itself.

I guess it would be good to split the patch up in two: one changing the default, which can be MFCed, one being the move of the sysctl node, which can't be MFCed.

Yes. Adjusting this Diff accordingly.

This revision is now accepted and ready to land.Nov 30 2023, 2:41 PM

Does this feature apply only to the base stack or also to the RACK/BBR stack?

Only the base stack; RACK deals with lost retransmissions as an emergent property of the RACK mechanism and per-segment state itself.

At least Netflix will then not need the socket option support for A/B testing.

I guess it would be good to split the patch up in two: one changing the default, which can be MFCed, one being the move of the sysctl node, which can't be MFCed.

Yes. Adjusting this Diff accordingly.

Perfect. Approved.

This revision was automatically updated to reflect the committed changes.