Page MenuHomeFreeBSD

Several LRO fixes
ClosedPublic

Authored by kbowling on Feb 28 2018, 7:48 AM.
Referenced Files
F108842279: D14540.diff
Tue, Jan 28, 2:08 PM
Unknown Object (File)
Dec 6 2024, 11:31 AM
Unknown Object (File)
Dec 3 2024, 6:22 AM
Unknown Object (File)
Nov 18 2024, 1:32 AM
Unknown Object (File)
Nov 17 2024, 2:36 AM
Unknown Object (File)
Oct 3 2024, 7:00 AM
Unknown Object (File)
Sep 29 2024, 8:45 PM
Unknown Object (File)
Sep 29 2024, 8:45 PM

Details

Summary

This changeset contains a few tightly intermingled and additive bugfixes from Netflix and LLNW:

  1. rrs - Lets make the LRO code look for true dup-acks and window update acks fly on through and combine.
  2. rrs - Make the LRO engine a bit more aware of ack-only seq space. Lets not have it incorrectly wipe out newer acks for older acks when we have out-of-order acks (common in wifi environments).
  3. jeggleston - LRO eating window updates

Based on all of the above I think we are RFC compliant doing it this way:

https://tools.ietf.org/html/rfc1122

section 4.2.2.16

"Note that TCP has a heuristic to select the latest window update despite possible datagram reordering; as a result, it may ignore a window update with a smaller window than previously offered if neither the sequence number nor the acknowledgment number is increased."

Test Plan

These changes are in use at LLNW and Netflix

Diff Detail

Lint
Lint Skipped
Unit
Tests Skipped

Event Timeline

rstone added a subscriber: rstone.

I've written some unit tests that covering these cases here:

https://github.com/rysto32/sysunit/blob/master/netinet/tcp_lro.gtest.cpp#L850

I can confirm that the new behaviour is much more sane than the older behaviour.

sys/netinet/tcp_lro.c
826

I think that you mean "old ack" here. As far as I can tell, the only way to reach this point is to have a packet with no payload and th_ack < le->ack_seq.

sys/netinet/tcp_lro.c
826

Agreed.

Fix comment per rstone and jegg

sys/netinet/tcp_lro.c
819

Technically we should only do this (or look at th->th_ack at all) if TH_ACK is set

sys/netinet/tcp_lro.c
819

On the transport call we discussed that this should probably be handled in another patch as it is a generic issue with the LRO code.

sbruno added a subscriber: sbruno.

I'll grab this and shovel it in after builds are done.

This revision was not accepted when it landed; it landed in state Needs Review.Mar 9 2018, 12:08 AM
This revision was automatically updated to reflect the committed changes.