aboutsummaryrefslogtreecommitdiff
path: root/drivers/cdx/controller/mcdi_functions.c
diff options
context:
space:
mode:
authorJohn Fastabend <[email protected]>2023-05-22 19:56:09 -0700
committerDaniel Borkmann <[email protected]>2023-05-23 16:10:18 +0200
commit901546fd8f9ca4b5c481ce00928ab425ce9aacc0 (patch)
treea85fd96272cf2e5f3a8c768fc52fd2ea2e4f3b80 /drivers/cdx/controller/mcdi_functions.c
parent405df89dd52cbcd69a3cd7d9a10d64de38f854b2 (diff)
bpf, sockmap: Handle fin correctly
The sockmap code is returning EAGAIN after a FIN packet is received and no more data is on the receive queue. Correct behavior is to return 0 to the user and the user can then close the socket. The EAGAIN causes many apps to retry which masks the problem. Eventually the socket is evicted from the sockmap because its released from sockmap sock free handling. The issue creates a delay and can cause some errors on application side. To fix this check on sk_msg_recvmsg side if length is zero and FIN flag is set then set return to zero. A selftest will be added to check this condition. Fixes: 04919bed948dc ("tcp: Introduce tcp_read_skb()") Signed-off-by: John Fastabend <[email protected]> Signed-off-by: Daniel Borkmann <[email protected]> Tested-by: William Findlay <[email protected]> Reviewed-by: Jakub Sitnicki <[email protected]> Link: https://lore.kernel.org/bpf/[email protected]
Diffstat (limited to 'drivers/cdx/controller/mcdi_functions.c')
0 files changed, 0 insertions, 0 deletions