diff options
author | Mike Perry <mikeperry-git@torproject.org> | 2022-07-26 22:28:02 +0000 |
---|---|---|
committer | Mike Perry <mikeperry-git@torproject.org> | 2022-08-02 18:13:42 +0000 |
commit | 533fe36957e2fc78e2c76fb1a91f5b17c3dfb85e (patch) | |
tree | 8a5afd7aa6a21c6d1c1ad8f4d30fed08f691d96b /src | |
parent | 7654e12be8d8179505add9a7fe381899f73e1aaf (diff) | |
download | tor-533fe36957e2fc78e2c76fb1a91f5b17c3dfb85e.tar.gz tor-533fe36957e2fc78e2c76fb1a91f5b17c3dfb85e.zip |
Add an underflow check to a cwnd error condition.
Diffstat (limited to 'src')
-rw-r--r-- | src/core/or/congestion_control_common.c | 11 |
1 files changed, 10 insertions, 1 deletions
diff --git a/src/core/or/congestion_control_common.c b/src/core/or/congestion_control_common.c index 71cd666ee2..42f816690f 100644 --- a/src/core/or/congestion_control_common.c +++ b/src/core/or/congestion_control_common.c @@ -882,10 +882,19 @@ congestion_control_update_circuit_bdp(congestion_control_t *cc, if (!cc->ewma_rtt_usec) { uint64_t cwnd = cc->cwnd; + tor_assert_nonfatal(cc->cwnd <= cwnd_max); + /* If the channel is blocked, keep subtracting off the chan_q * until we hit the min cwnd. */ if (blocked_on_chan) { - cwnd = MAX(cwnd - chan_q, cc->cwnd_min); + /* Cast is fine because we're less than int32 */ + if (chan_q >= (int64_t)cwnd) { + log_notice(LD_CIRC, + "Clock stall with large chanq: %d %"PRIu64, chan_q, cwnd); + cwnd = cc->cwnd_min; + } else { + cwnd = MAX(cwnd - chan_q, cc->cwnd_min); + } cc->blocked_chan = 1; } else { cc->blocked_chan = 0; |