mptcp: relax check on MPC passive fallback
authorPaolo Abeni <pabeni@redhat.com>
Tue, 16 Jan 2024 17:18:47 +0000 (18:18 +0100)
committerDavid S. Miller <davem@davemloft.net>
Wed, 17 Jan 2024 10:55:54 +0000 (10:55 +0000)
While testing the blamed commit below, I was able to miss (!)
packetdrill failures in the fastopen test-cases.

On passive fastopen the child socket is created by incoming TCP MPC syn,
allow for both MPC_SYN and MPC_ACK header.

Fixes: 724b00c12957 ("mptcp: refine opt_mp_capable determination")
Reviewed-by: Matthieu Baerts <matttbe@kernel.org>
Signed-off-by: Paolo Abeni <pabeni@redhat.com>
Reviewed-by: Eric Dumazet <edumazet@google.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/mptcp/subflow.c

index 1117d1e84274a5ea1ede990566f67c0073fd86a0..0dcb721c89d193e8943aa414610fcf4284d51f38 100644 (file)
@@ -783,7 +783,8 @@ static struct sock *subflow_syn_recv_sock(const struct sock *sk,
                 * options.
                 */
                mptcp_get_options(skb, &mp_opt);
-               if (!(mp_opt.suboptions & OPTION_MPTCP_MPC_ACK))
+               if (!(mp_opt.suboptions &
+                     (OPTION_MPTCP_MPC_SYN | OPTION_MPTCP_MPC_ACK)))
                        fallback = true;
 
        } else if (subflow_req->mp_join) {