diff options
author | Paolo Abeni <pabeni@redhat.com> | 2020-04-24 14:15:21 +0300 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2020-04-26 06:38:54 +0300 |
commit | 1200832c6e850a17f36631f6492f953a1b39e6b8 (patch) | |
tree | ac7289c7ae0723ae43b97911c830be0efcac2cab /LICENSES | |
parent | b2768df24ec400dd4f7fa79542f797e904812053 (diff) | |
download | linux-1200832c6e850a17f36631f6492f953a1b39e6b8.tar.xz |
mptcp: fix race in msk status update
Currently subflow_finish_connect() changes unconditionally
any msk socket status other than TCP_ESTABLISHED.
If an unblocking connect() races with close(), we can end-up
triggering:
IPv4: Attempt to release TCP socket in state 1 00000000e32b8b7e
when the msk socket is disposed.
Be sure to enter the established status only from SYN_SENT.
Fixes: c3c123d16c0e ("net: mptcp: don't hang in mptcp_sendmsg() after TCP fallback")
Signed-off-by: Paolo Abeni <pabeni@redhat.com>
Reviewed-by: Mat Martineau <mathew.j.martineau@linux.intel.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'LICENSES')
0 files changed, 0 insertions, 0 deletions