mirror of
https://github.com/followmsi/android_kernel_google_msm.git
synced 2024-11-06 23:17:41 +00:00
tcp: Fix integer-overflows in TCP veno
[ Upstream commit45a07695bc
] In veno we do a multiplication of the cwnd and the rtt. This may overflow and thus their result is stored in a u64. However, we first need to cast the cwnd so that actually 64-bit arithmetic is done. A first attempt at fixing76f1017757
([TCP]: TCP Veno congestion control) was made by159131149c
(tcp: Overflow bug in Vegas), but it failed to add the required cast in tcp_veno_cong_avoid(). Fixes:76f1017757
([TCP]: TCP Veno congestion control) Signed-off-by: Christoph Paasch <christoph.paasch@uclouvain.be> Signed-off-by: David S. Miller <davem@davemloft.net> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
c28d71cac8
commit
1f9480d282
1 changed files with 1 additions and 1 deletions
|
@ -144,7 +144,7 @@ static void tcp_veno_cong_avoid(struct sock *sk, u32 ack, u32 in_flight)
|
|||
|
||||
rtt = veno->minrtt;
|
||||
|
||||
target_cwnd = (tp->snd_cwnd * veno->basertt);
|
||||
target_cwnd = (u64)tp->snd_cwnd * veno->basertt;
|
||||
target_cwnd <<= V_PARAM_SHIFT;
|
||||
do_div(target_cwnd, rtt);
|
||||
|
||||
|
|
Loading…
Reference in a new issue