diff options
author | Mat Martineau <mathew.j.martineau@linux.intel.com> | 2020-07-29 00:12:00 +0200 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2020-07-29 02:02:41 +0200 |
commit | 57baaf2875404b555587391608da1625863086fa (patch) | |
tree | c3e53379430b46a00916652aabd22bee8fd78e04 /net/mptcp | |
parent | mptcp: Allow DATA_FIN in headers without TCP FIN (diff) | |
download | linux-57baaf2875404b555587391608da1625863086fa.tar.xz linux-57baaf2875404b555587391608da1625863086fa.zip |
mptcp: Return EPIPE if sending is shut down during a sendmsg
A MPTCP socket where sending has been shut down should not attempt to
send additional data, since DATA_FIN has already been sent.
Signed-off-by: Mat Martineau <mathew.j.martineau@linux.intel.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/mptcp')
-rw-r--r-- | net/mptcp/protocol.c | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/net/mptcp/protocol.c b/net/mptcp/protocol.c index 2891ae8a1028..b3c3dbc89b3f 100644 --- a/net/mptcp/protocol.c +++ b/net/mptcp/protocol.c @@ -748,6 +748,11 @@ static int mptcp_sendmsg(struct sock *sk, struct msghdr *msg, size_t len) restart: mptcp_clean_una(sk); + if (sk->sk_err || (sk->sk_shutdown & SEND_SHUTDOWN)) { + ret = -EPIPE; + goto out; + } + wait_for_sndbuf: __mptcp_flush_join_list(msk); ssk = mptcp_subflow_get_send(msk); |