diff options
author | Eric Dumazet <edumazet@google.com> | 2019-04-16 10:55:20 -0700 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2019-04-16 21:47:39 -0700 |
commit | 50ce163a72d817a99e8974222dcf2886d5deb1ae (patch) | |
tree | d23ffa9fbfcba49b44e070227d300534ab97f3ab /kernel/nsproxy.c | |
parent | 1e1caa9735f90b5452fc48685c23552e56aa1920 (diff) | |
download | linux-50ce163a72d817a99e8974222dcf2886d5deb1ae.tar.gz linux-50ce163a72d817a99e8974222dcf2886d5deb1ae.tar.bz2 linux-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 'kernel/nsproxy.c')
0 files changed, 0 insertions, 0 deletions