Paolo Abeni 5969856ae8 mptcp: fix races between shutdown and recvmsg
The msk sk_shutdown flag is set by a workqueue, possibly
introducing some delay in user-space notification. If the last
subflow carries some data with the fin packet, the user space
can wake-up before RCV_SHUTDOWN is set. If it executes unblocking
recvmsg(), it may return with an error instead of eof.

Address the issue explicitly checking for eof in recvmsg(), when
no data is found.

Fixes: 59832e246515 ("mptcp: subflow: check parent mptcp socket on subflow state change")
Signed-off-by: Paolo Abeni <pabeni@redhat.com>
Reviewed-by: Matthieu Baerts <matthieu.baerts@tessares.net>
Signed-off-by: David S. Miller <davem@davemloft.net>
2020-06-10 13:34:14 -07:00
..
2019-09-26 08:56:17 +02:00
2020-06-10 13:18:40 -07:00
2020-05-12 18:12:40 -07:00
2020-06-05 14:05:57 -07:00
2020-06-08 19:13:37 -07:00
2020-06-05 14:05:57 -07:00
2020-05-28 11:11:46 -07:00
2020-05-29 13:10:39 -07:00