Lines Matching refs:subflow
335 struct mptcp_subflow_context *subflow = mptcp_subflow_ctx(sk); in mptcp_syn_options() local
340 subflow->snd_isn = TCP_SKB_CB(skb)->end_seq; in mptcp_syn_options()
341 if (subflow->request_mptcp) { in mptcp_syn_options()
345 } else if (subflow->request_join) { in mptcp_syn_options()
346 pr_debug("remote_token=%u, nonce=%u", subflow->remote_token, in mptcp_syn_options()
347 subflow->local_nonce); in mptcp_syn_options()
349 opts->join_id = subflow->local_id; in mptcp_syn_options()
350 opts->token = subflow->remote_token; in mptcp_syn_options()
351 opts->nonce = subflow->local_nonce; in mptcp_syn_options()
352 opts->backup = subflow->request_bkup; in mptcp_syn_options()
397 struct mptcp_subflow_context *subflow = mptcp_subflow_ctx(sk); in mptcp_established_options_mp() local
411 if (subflow->fully_established || in mptcp_established_options_mp()
412 subflow->snd_isn != TCP_SKB_CB(skb)->seq) in mptcp_established_options_mp()
415 if (subflow->mp_capable) { in mptcp_established_options_mp()
425 opts->sndr_key = subflow->local_key; in mptcp_established_options_mp()
426 opts->rcvr_key = subflow->remote_key; in mptcp_established_options_mp()
439 subflow, subflow->local_key, subflow->remote_key, in mptcp_established_options_mp()
443 } else if (subflow->mp_join) { in mptcp_established_options_mp()
445 memcpy(opts->hmac, subflow->hmac, MPTCPOPT_HMAC_LEN); in mptcp_established_options_mp()
447 pr_debug("subflow=%p", subflow); in mptcp_established_options_mp()
455 static void mptcp_write_data_fin(struct mptcp_subflow_context *subflow, in mptcp_write_data_fin() argument
461 u64 data_fin_tx_seq = READ_ONCE(mptcp_sk(subflow->conn)->write_seq) - 1; in mptcp_write_data_fin()
488 struct mptcp_subflow_context *subflow = mptcp_subflow_ctx(sk); in mptcp_established_options_dss() local
489 struct mptcp_sock *msk = mptcp_sk(subflow->conn); in mptcp_established_options_dss()
510 mptcp_write_data_fin(subflow, skb, &opts->ext_copy); in mptcp_established_options_dss()
583 struct mptcp_subflow_context *subflow = mptcp_subflow_ctx(sk); in mptcp_established_options_add_addr() local
584 struct mptcp_sock *msk = mptcp_sk(subflow->conn); in mptcp_established_options_add_addr()
631 struct mptcp_subflow_context *subflow = mptcp_subflow_ctx(sk); in mptcp_established_options_rm_addr() local
632 struct mptcp_sock *msk = mptcp_sk(subflow->conn); in mptcp_established_options_rm_addr()
724 struct mptcp_subflow_context *subflow, in check_fully_established() argument
731 if (likely(subflow->fully_established)) { in check_fully_established()
736 if (TCP_SKB_CB(skb)->seq == subflow->ssn_offset + 1 && in check_fully_established()
738 subflow->mp_join && mp_opt->mp_join && in check_fully_established()
749 if (TCP_SKB_CB(skb)->seq != subflow->ssn_offset + 1) { in check_fully_established()
750 if (subflow->mp_join) in check_fully_established()
752 return subflow->mp_capable; in check_fully_established()
759 subflow->fully_established = 1; in check_fully_established()
769 if (subflow->mp_join) in check_fully_established()
771 subflow->mp_capable = 0; in check_fully_established()
779 mptcp_subflow_fully_established(subflow, mp_opt); in check_fully_established()
782 if (likely(subflow->pm_notified)) in check_fully_established()
785 subflow->pm_notified = 1; in check_fully_established()
786 if (subflow->mp_join) { in check_fully_established()
788 mptcp_pm_subflow_established(msk, subflow); in check_fully_established()
886 struct mptcp_subflow_context *subflow = mptcp_subflow_ctx(sk); in mptcp_incoming_options() local
887 struct mptcp_sock *msk = mptcp_sk(subflow->conn); in mptcp_incoming_options()
895 if (!check_fully_established(msk, sk, subflow, skb, &mp_opt)) in mptcp_incoming_options()
946 sock_hold(subflow->conn); in mptcp_incoming_options()
962 mptcp_crypto_key_sha(subflow->remote_key, NULL, in mptcp_incoming_options()