Page MenuHomeFreeBSD

tcp: Check if we exceed socket send buffer instead of snd_fack
AbandonedPublic

Authored by rscheff on Jun 10 2022, 4:08 PM.
Tags
None
Referenced Files
F108701812: D35446.id106838.diff
Mon, Jan 27, 10:10 AM
Unknown Object (File)
Mon, Jan 13, 9:00 AM
Unknown Object (File)
Mon, Jan 13, 8:53 AM
Unknown Object (File)
Mon, Jan 13, 7:51 AM
Unknown Object (File)
Mon, Jan 13, 7:50 AM
Unknown Object (File)
Mon, Jan 13, 7:42 AM
Unknown Object (File)
Mon, Jan 13, 7:30 AM
Unknown Object (File)
Mon, Jan 13, 5:23 AM

Details

Reviewers
tuexen
Group Reviewers
transport
Summary

SACK rescue retransmission is supposed to be inserted never
exceeding the right edge of the socket sendbuffer. However,
rarely there appear to be instances, when either the rescue
retransmission is created using an incorrect offset (FIN bit?),
or the send buffer retracts (?). In this case, panic an INVARIANTS
kernel as early as possible to track why this may be happening,
or skip over SACK retransmission processing altogether and revert
to NewReno loss recovery from snd_una.

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 45937
Build 42825: arc lint + arc unit

Event Timeline

  • verify the creation of the rescue retransmission hole in the scoreboard
  • make sure that snd_max is never more than 1 beyond so_snd
  • make snd_max sane in non INVARIANTS build while warning
sys/netinet/tcp_output.c
1572

Please declare so at the beginning of a block.

1575

Use top + 1 instead of top+1.

1652

Please declare so at the beginning of a block.

sys/netinet/tcp_sack.c
908

Please declare so at the beginning of a block.

978–984

Why do you start a block here?

979

Please declare so at the beginning of a block; assuming you remove the start of the current block.

rscheff marked 6 inline comments as done.
  • align code with style rules

thanks for the feedback, addressed the comments.

  • revive D2970 - adjust snd_nxt properly if FIN packet fails to be sent
  • add logging, when D2970 fix activates - to check incidence rate

The combination of D36626, D36631 and D36637 addressed the root cause (and incidential, connected issues). This symptomatic fix is not needed.