Page MenuHomeFreeBSD

tcp: avoid useless calculations in tcp_account_for_send() when len is 0
ClosedPublic

Authored by gallatin on Sep 14 2021, 2:54 PM.
Tags
None
Referenced Files
Unknown Object (File)
Mon, Nov 17, 1:20 AM
Unknown Object (File)
Mon, Nov 17, 1:20 AM
Unknown Object (File)
Mon, Nov 17, 1:19 AM
Unknown Object (File)
Sun, Nov 16, 11:25 PM
Unknown Object (File)
Sat, Nov 15, 10:07 PM
Unknown Object (File)
Sun, Nov 9, 6:17 PM
Unknown Object (File)
Mon, Nov 3, 1:16 PM
Unknown Object (File)
Fri, Oct 31, 2:20 AM
Subscribers

Details

Summary

When the length is 0, the retransmit rate could not have changed, so avoid doing math to determine if we need to move a TLS connection from hardware to software.

This also fixes a potential bug when switching from an old or buggy TCP stack which does not call into tcp_account_for_send(). In this case, the first call into tcp_account_for_send() will find the t_sndbytes and t_snd_rxt_bytes as 0, and if that first call is for a rexmit, we'll hit a divide-by-zero bug unless we guard against a zero length.

Diff Detail

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