Page MenuHomeFreeBSD

tcp: Address goodput and TLP edge cases.
ClosedPublic

Authored by rrs on Jul 6 2021, 2:20 PM.
Tags
None
Referenced Files
Unknown Object (File)
Thu, Jan 23, 10:20 AM
Unknown Object (File)
Mon, Dec 30, 11:06 PM
Unknown Object (File)
Sun, Dec 29, 12:34 PM
Unknown Object (File)
Dec 13 2024, 7:58 PM
Unknown Object (File)
Dec 11 2024, 4:27 PM
Unknown Object (File)
Dec 4 2024, 11:08 PM
Unknown Object (File)
Dec 4 2024, 11:08 PM
Unknown Object (File)
Dec 4 2024, 11:08 PM
Subscribers

Details

Summary

There are several cases where we make a goodput measurement and we are running
out of data when we decide to make the measurement. In reality we should not make
such a measurement if there is no chance we can have "enough" data. There is also
some corner case TLP's that end up not registering as a TLP like they should, we
fix this by pushing the doing_tlp setup to the actual timeout that knows it did
a TLP. This makes it so we always have the appropriate flag on the sendmap
indicating a TLP being done as well as count correctly so we make no more
that two TLP's.

In addressing the goodput lets also add a "quality" metric that can be viewed via
blackbox logs so that a casual observer does not have to figure out how good
of a measurement it is. This is needed due to the fact that we may still make
a measurement that is of a poorer quality as we run out of data but still have
a minimal amount of data to make a measurement.

Test Plan

Inside the NF lab run various test scenarios that create the edge cases
and validate that the quality metric is correct or we discard the measurements
all together. Also validate no cases where we TLP more than twice.

Diff Detail

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