net: tcp: allow zero-window ACK update the window
authorMenglong Dong <imagedong@tencent.com>
Fri, 11 Aug 2023 02:55:28 +0000 (10:55 +0800)
committerDavid S. Miller <davem@davemloft.net>
Sun, 13 Aug 2023 11:21:37 +0000 (12:21 +0100)
Fow now, an ACK can update the window in following case, according to
the tcp_may_update_window():

1. the ACK acknowledged new data
2. the ACK has new data
3. the ACK expand the window and the seq of it is valid

Now, we allow the ACK update the window if the window is 0, and the
seq/ack of it is valid. This is for the case that the receiver replies
an zero-window ACK when it is under memory stress and can't queue the new
data.

Signed-off-by: Menglong Dong <imagedong@tencent.com>
Reviewed-by: Eric Dumazet <edumazet@google.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/ipv4/tcp_input.c

index 2ac05948341014afc6dbf14b3dce22172a1f59e4..d34d52fdfdb1e0fe25c6c9a0885e581d197aa701 100644 (file)
@@ -3525,7 +3525,7 @@ static inline bool tcp_may_update_window(const struct tcp_sock *tp,
 {
        return  after(ack, tp->snd_una) ||
                after(ack_seq, tp->snd_wl1) ||
-               (ack_seq == tp->snd_wl1 && nwin > tp->snd_wnd);
+               (ack_seq == tp->snd_wl1 && (nwin > tp->snd_wnd || !nwin));
 }
 
 /* If we update tp->snd_una, also update tp->bytes_acked */