Page MenuHomeFreeBSD

tcp: The rack stack can incorrectly have an overflow when calculating a burst delay.
ClosedPublic

Authored by rrs on Oct 26 2021, 11:47 AM.
Tags
None
Referenced Files
F108572863: D32668.diff
Sun, Jan 26, 12:23 PM
Unknown Object (File)
Fri, Jan 17, 1:07 PM
Unknown Object (File)
Wed, Jan 15, 10:00 PM
Unknown Object (File)
Wed, Jan 15, 7:46 PM
Unknown Object (File)
Sun, Jan 12, 12:48 PM
Unknown Object (File)
Wed, Jan 8, 7:29 AM
Unknown Object (File)
Tue, Jan 7, 3:54 AM
Unknown Object (File)
Nov 20 2024, 11:01 AM
Subscribers

Details

Summary

If the congestion window is very large the fact that we multiply it by 1000 (for microseconds) can
cause the uint32_t to overflow and we incorrectly calculate a very small divisor. This will then
cause the burst timer to be very large when it should be 0. Instead lets make the three variables
uint64_t and avoid the issue.

Diff Detail

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

Event Timeline

rrs requested review of this revision.Oct 26 2021, 11:47 AM

While where at it, there is a duplicate srtt that should be just one var at the higher scope. Lets fix
that and make the needed casts when comparing to slot. That way we never can get a
confused compiler :)

This revision is now accepted and ready to land.Oct 26 2021, 3:37 PM