]> git.baikalelectronics.ru Git - kernel.git/commit
strparser: Remove early eaten to fix full tcp receive buffer stall
authorDoron Roberts-Kedes <doronrk@fb.com>
Wed, 27 Jun 2018 01:33:33 +0000 (18:33 -0700)
committerDavid S. Miller <davem@davemloft.net>
Thu, 28 Jun 2018 12:37:26 +0000 (21:37 +0900)
commit5a4bc5c29ae41bcc6a4ade30b5f96f2673d0a53f
tree68e42d70c25e7ee758a2b5bf7d4231fa4aa7fc8d
parent86aae6c088a435e0f66dcb8ceed889f2e258c5a0
strparser: Remove early eaten to fix full tcp receive buffer stall

On receving an incomplete message, the existing code stores the
remaining length of the cloned skb in the early_eaten field instead of
incrementing the value returned by __strp_recv. This defers invocation
of sock_rfree for the current skb until the next invocation of
__strp_recv, which returns early_eaten if early_eaten is non-zero.

This behavior causes a stall when the current message occupies the very
tail end of a massive skb, and strp_peek/need_bytes indicates that the
remainder of the current message has yet to arrive on the socket. The
TCP receive buffer is totally full, causing the TCP window to go to
zero, so the remainder of the message will never arrive.

Incrementing the value returned by __strp_recv by the amount otherwise
stored in early_eaten prevents stalls of this nature.

Signed-off-by: Doron Roberts-Kedes <doronrk@fb.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/strparser/strparser.c