From: Neal Cardwell Date: Fri, 20 Feb 2015 18:33:16 +0000 (-0500) Subject: tcp: fix tcp_should_expand_sndbuf() to use tcp_packets_in_flight() X-Git-Tag: Ubuntu-snapdragon-4.4.0-1050.54~8618^2~57 X-Git-Url: https://git.proxmox.com/?a=commitdiff_plain;h=6514890f7aa8dd75fa46e282a1c7a8615e86f363;p=mirror_ubuntu-artful-kernel.git tcp: fix tcp_should_expand_sndbuf() to use tcp_packets_in_flight() tcp_should_expand_sndbuf() does not expand the send buffer if we have filled the congestion window. However, it should use tcp_packets_in_flight() instead of tp->packets_out to make this check. Testing has established that the difference matters a lot if there are many SACKed packets, causing a needless performance shortfall. Signed-off-by: Neal Cardwell Signed-off-by: Yuchung Cheng Signed-off-by: Eric Dumazet Signed-off-by: Nandita Dukkipati Signed-off-by: David S. Miller --- diff --git a/net/ipv4/tcp_input.c b/net/ipv4/tcp_input.c index 8fdd27b17306..fb4cf8b8e121 100644 --- a/net/ipv4/tcp_input.c +++ b/net/ipv4/tcp_input.c @@ -4770,7 +4770,7 @@ static bool tcp_should_expand_sndbuf(const struct sock *sk) return false; /* If we filled the congestion window, do not expand. */ - if (tp->packets_out >= tp->snd_cwnd) + if (tcp_packets_in_flight(tp) >= tp->snd_cwnd) return false; return true;