aboutsummaryrefslogtreecommitdiffstats
path: root/net/core/sock.c
diff options
context:
space:
mode:
authorEric Dumazet <edumazet@google.com>2019-04-16 10:55:20 -0700
committerDavid S. Miller <davem@davemloft.net>2019-04-16 21:47:39 -0700
commit50ce163a72d817a99e8974222dcf2886d5deb1ae (patch)
treed23ffa9fbfcba49b44e070227d300534ab97f3ab /net/core/sock.c
parentocelot: Clean up stats update deferred work (diff)
downloadlinux-dev-50ce163a72d817a99e8974222dcf2886d5deb1ae.tar.xz
linux-dev-50ce163a72d817a99e8974222dcf2886d5deb1ae.zip
tcp: tcp_grow_window() needs to respect tcp_space()
For some reason, tcp_grow_window() correctly tests if enough room is present before attempting to increase tp->rcv_ssthresh, but does not prevent it to grow past tcp_space() This is causing hard to debug issues, like failing the (__tcp_select_window(sk) >= tp->rcv_wnd) test in __tcp_ack_snd_check(), causing ACK delays and possibly slow flows. Depending on tcp_rmem[2], MTU, skb->len/skb->truesize ratio, we can see the problem happening on "netperf -t TCP_RR -- -r 2000,2000" after about 60 round trips, when the active side no longer sends immediate acks. This bug predates git history. Signed-off-by: Eric Dumazet <edumazet@google.com> Acked-by: Soheil Hassas Yeganeh <soheil@google.com> Acked-by: Neal Cardwell <ncardwell@google.com> Acked-by: Wei Wang <weiwan@google.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/core/sock.c')
0 files changed, 0 insertions, 0 deletions