Page MenuHomeFreeBSD

tcp: properly initialize LRD while accepting session in syncache
ClosedPublic

Authored by rscheff on Dec 1 2023, 10:40 PM.
Tags
None
Referenced Files
F108225222: D42874.diff
Wed, Jan 22, 8:32 PM
F108157920: D42874.diff
Wed, Jan 22, 12:15 AM
Unknown Object (File)
Tue, Jan 21, 2:43 AM
Unknown Object (File)
Mon, Jan 20, 12:16 AM
Unknown Object (File)
Fri, Jan 17, 6:02 AM
Unknown Object (File)
Wed, Jan 8, 6:52 PM
Unknown Object (File)
Fri, Dec 27, 9:08 AM
Unknown Object (File)
Dec 23 2024, 1:49 AM
Subscribers

Details

Summary

After the recent LRD related changes, I noted that accept()ed
sessions would not honor the per-session TF_LRD flag.

Initialize this not only in tcp_newtcpcb, but also in syncache_socket.

Test Plan

drop a data segment and the retransmission on a SACK session,
verify that another retransmission happens well before the
retransmission timeout.

MFC: 2 weeks

Diff Detail

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

Event Timeline

sys/netinet/tcp_syncache.c
955–956

Alternatively, the TF_LRD flag could be inherited from the listen socket here with (TF_LRD|TF_NOPUSH|TF_NODELAY)

sys/netinet/tcp_syncache.c
955–956

Inheriting is what I would prefer.

  • inherit LRD setting from listening socket
This revision is now accepted and ready to land.Dec 2 2023, 11:13 AM