Page MenuHomeFreeBSD

tcp: Rack in a rare case we can get stuck sending a very small amount.
ClosedPublic

Authored by rrs on Dec 7 2021, 7:52 PM.
Tags
None
Referenced Files
Unknown Object (File)
Dec 19 2024, 6:25 AM
Unknown Object (File)
Dec 19 2024, 3:02 AM
Unknown Object (File)
Dec 10 2024, 3:48 PM
Unknown Object (File)
Nov 22 2024, 3:04 AM
Unknown Object (File)
Nov 6 2024, 8:31 PM
Unknown Object (File)
Oct 5 2024, 5:52 AM
Unknown Object (File)
Oct 4 2024, 5:51 PM
Unknown Object (File)
Oct 2 2024, 11:14 AM

Details

Summary

If a tlp sending new data fails, and then the peer starts
talking to us again, we can be in a situation where the
tlp_new_data count is set, we are not in recovery and
we always send one packet every RTT. The failure
has to occur when we send the TLP initially from the ip_output()
which is rare. But if it occurs you are basically stuck.

This fixes it so we use the new_data count and clear it so
we know it will be cleared. If a failure occurs the tlp timer
will regenerate a new amount anyway so it is un-needed to
carry the value on.

Test Plan

This one is tricky to recreate since you must have a way
to have ip_output() fail on a new data tlp. This cannot
be simulated with packet drill so the only way would be
to hack in changes to make it occur.

Diff Detail

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