Home
last modified time | relevance | path

Searched refs:subflow (Results 1 – 21 of 21) sorted by relevance

/linux/net/mptcp/
A Dsubflow.c419 subflow->remote_nonce, subflow->local_nonce, in subflow_thmac_valid()
424 subflow, subflow->token, thmac, subflow->thmac); in subflow_thmac_valid()
575 subflow, subflow->thmac, subflow->remote_nonce, in subflow_finish_connect()
980 ssn, subflow->map_subflow_seq, subflow->map_data_len); in dbg_bad_map()
1031 if (subflow->map_csum_len == subflow->map_data_len) in validate_data_csum()
1039 delta = subflow->map_data_len - subflow->map_csum_len; in validate_data_csum()
1087 subflow->map_data_len + subflow->map_data_fin, in validate_data_csum()
1226 subflow->map_seq, subflow->map_subflow_seq, in get_mapping_status()
1227 subflow->map_data_len, subflow->map_csum_reqd, in get_mapping_status()
1381 (subflow->mp_join || subflow->valid_csum_seen)) { in subflow_check_data_avail()
[all …]
A Doptions.c421 subflow->local_nonce); in mptcp_syn_options()
469 if (subflow->mp_capable) { in mptcp_established_options_mp()
504 subflow, subflow->local_key, subflow->remote_key, in mptcp_established_options_mp()
952 if (subflow->mp_join) in check_fully_established()
974 if (subflow->mp_join) in check_fully_established()
976 subflow->mp_capable = 0; in check_fully_established()
999 if (likely(subflow->pm_notified) || list_empty(&subflow->node)) in check_fully_established()
1002 subflow->pm_notified = 1; in check_fully_established()
1003 if (subflow->mp_join) { in check_fully_established()
1188 subflow->reset_seen = 1; in mptcp_incoming_options()
[all …]
A Dprotocol.c84 subflow->request_mptcp = 1; in __mptcp_socket_create()
1397 if (!subflow->stale) in mptcp_subflow_set_active()
1400 subflow->stale = 0; in mptcp_subflow_set_active()
1443 bool backup = subflow->backup || subflow->request_bkup; in mptcp_subflow_get_send()
1494 subflow->avg_pacing_rate = div_u64((u64)subflow->avg_pacing_rate * wmem + in mptcp_subflow_get_send()
2353 if (subflow->backup || subflow->request_bkup) { in mptcp_subflow_get_retrans()
2484 subflow->disposable = 1; in __mptcp_close_ssk()
2492 kfree_rcu(subflow, rcu); in __mptcp_close_ssk()
3405 __mptcp_close_ssk(sk, mptcp_subflow_tcp_sock(subflow), subflow, flags); in mptcp_destroy_common()
3595 sk = subflow->conn; in mptcp_finish_connect()
[all …]
A Dprotocol.h590 return subflow->tcp_sock; in mptcp_subflow_tcp_sock()
596 memset(&subflow->reset, 0, sizeof(subflow->reset)); in mptcp_subflow_ctx_reset()
597 subflow->request_mptcp = 1; in mptcp_subflow_ctx_reset()
642 subflow->ssn_offset - in mptcp_subflow_get_map_offset()
643 subflow->map_subflow_seq; in mptcp_subflow_get_map_offset()
649 return subflow->map_seq + mptcp_subflow_get_map_offset(subflow); in mptcp_subflow_get_mapped_dsn()
783 if (subflow->request_join && !subflow->fully_established) in __mptcp_subflow_active()
1205 struct sock *sk = subflow->conn; in mptcp_do_fallback()
1229 subflow->request_mptcp = 0; in mptcp_subflow_early_fallback()
1246 return (subflow->request_mptcp || subflow->request_join); in is_active_ssk()
[all …]
A Dpm.c182 update_subflows = subflow->request_join || subflow->mp_join; in mptcp_pm_subflow_check_next()
288 struct sock *sk = subflow->conn; in mptcp_pm_mp_prio_received()
293 if (subflow->backup != bkup) in mptcp_pm_mp_prio_received()
294 subflow->backup = bkup; in mptcp_pm_mp_prio_received()
309 if (!subflow->fail_tout) { in mptcp_pm_mp_fail_received()
312 subflow->send_mp_fail = 1; in mptcp_pm_mp_fail_received()
313 subflow->send_infinite_map = 1; in mptcp_pm_mp_fail_received()
462 if (!subflow->stale_count) { in mptcp_pm_subflow_chk_stale()
464 subflow->stale_count++; in mptcp_pm_subflow_chk_stale()
467 subflow->stale_count++; in mptcp_pm_subflow_chk_stale()
[all …]
A Dfastopen.c9 void mptcp_fastopen_subflow_synack_set_params(struct mptcp_subflow_context *subflow, in mptcp_fastopen_subflow_synack_set_params() argument
19 if (!subflow) in mptcp_fastopen_subflow_synack_set_params()
22 ssk = subflow->tcp_sock; in mptcp_fastopen_subflow_synack_set_params()
23 sk = subflow->conn; in mptcp_fastopen_subflow_synack_set_params()
26 subflow->is_mptfo = 1; in mptcp_fastopen_subflow_synack_set_params()
41 subflow->ssn_offset += skb->len; in mptcp_fastopen_subflow_synack_set_params()
62 void __mptcp_fastopen_gen_msk_ackseq(struct mptcp_sock *msk, struct mptcp_subflow_context *subflow, in __mptcp_fastopen_gen_msk_ackseq() argument
A Dsockopt.c72 struct mptcp_subflow_context *subflow; in mptcp_sol_socket_sync_intval() local
78 mptcp_for_each_subflow(msk, subflow) { in mptcp_sol_socket_sync_intval()
150 struct mptcp_subflow_context *subflow; in mptcp_setsockopt_sol_socket_tstamp() local
160 mptcp_for_each_subflow(msk, subflow) { in mptcp_setsockopt_sol_socket_tstamp()
210 struct mptcp_subflow_context *subflow; in mptcp_setsockopt_sol_socket_timestamping() local
236 mptcp_for_each_subflow(msk, subflow) { in mptcp_setsockopt_sol_socket_timestamping()
252 struct mptcp_subflow_context *subflow; in mptcp_setsockopt_sol_socket_linger() local
271 mptcp_for_each_subflow(msk, subflow) { in mptcp_setsockopt_sol_socket_linger()
585 struct mptcp_subflow_context *subflow; in mptcp_setsockopt_sol_tcp_congestion() local
606 mptcp_for_each_subflow(msk, subflow) { in mptcp_setsockopt_sol_tcp_congestion()
[all …]
A Dsched.c140 void mptcp_subflow_set_scheduled(struct mptcp_subflow_context *subflow, in mptcp_subflow_set_scheduled() argument
143 WRITE_ONCE(subflow->scheduled, scheduled); in mptcp_subflow_set_scheduled()
148 struct mptcp_subflow_context *subflow; in mptcp_sched_get_send() local
164 mptcp_for_each_subflow(msk, subflow) { in mptcp_sched_get_send()
165 if (READ_ONCE(subflow->scheduled)) in mptcp_sched_get_send()
177 struct mptcp_subflow_context *subflow; in mptcp_sched_get_retrans() local
186 mptcp_for_each_subflow(msk, subflow) { in mptcp_sched_get_retrans()
187 if (READ_ONCE(subflow->scheduled)) in mptcp_sched_get_retrans()
A Dtoken.c153 struct mptcp_subflow_context *subflow = mptcp_subflow_ctx(ssk); in mptcp_token_new_connect() local
154 struct mptcp_sock *msk = mptcp_sk(subflow->conn); in mptcp_token_new_connect()
156 struct sock *sk = subflow->conn; in mptcp_token_new_connect()
160 mptcp_crypto_key_gen_sha(&subflow->local_key, &subflow->token, in mptcp_token_new_connect()
161 &subflow->idsn); in mptcp_token_new_connect()
163 bucket = token_bucket(subflow->token); in mptcp_token_new_connect()
165 if (__token_bucket_busy(bucket, subflow->token)) { in mptcp_token_new_connect()
173 ssk, subflow->local_key, subflow->token, subflow->idsn); in mptcp_token_new_connect()
175 WRITE_ONCE(msk->token, subflow->token); in mptcp_token_new_connect()
A Dpm_netlink.c113 struct mptcp_subflow_context *subflow; in lookup_subflow_by_saddr() local
131 struct mptcp_subflow_context *subflow; in lookup_subflow_by_daddr() local
452 mptcp_for_each_subflow(msk, subflow) in fill_remote_addresses_vec()
494 subflow->send_mp_prio = 1; in __mptcp_pm_send_ack()
495 subflow->request_bkup = backup; in __mptcp_pm_send_ack()
592 goto subflow; in mptcp_pm_create_subflow_or_signal_addr()
614 subflow: in mptcp_pm_create_subflow_or_signal_addr()
877 removed |= subflow->request_join; in mptcp_pm_nl_rm_addr_or_subflow()
880 mptcp_close_ssk(sk, ssk, subflow); in mptcp_pm_nl_rm_addr_or_subflow()
1208 if (subflow->stale || !stale_loss_cnt || subflow->stale_count <= stale_loss_cnt) in mptcp_pm_nl_subflow_chk_stale()
[all …]
A Dctrl.c393 struct mptcp_subflow_context *subflow; in mptcp_active_detect_blackhole() local
400 subflow = mptcp_subflow_ctx(ssk); in mptcp_active_detect_blackhole()
402 if (subflow->request_mptcp && ssk->sk_state == TCP_SYN_SENT) { in mptcp_active_detect_blackhole()
405 subflow->mpc_drop = 1; in mptcp_active_detect_blackhole()
406 mptcp_subflow_early_fallback(mptcp_sk(subflow->conn), subflow); in mptcp_active_detect_blackhole()
408 subflow->mpc_drop = 0; in mptcp_active_detect_blackhole()
A Dpm_userspace.c240 struct mptcp_subflow_context *subflow; in mptcp_userspace_pm_remove_id_zero_address() local
246 mptcp_for_each_subflow(msk, subflow) { in mptcp_userspace_pm_remove_id_zero_address()
247 if (READ_ONCE(subflow->local_id) == 0) { in mptcp_userspace_pm_remove_id_zero_address()
425 struct mptcp_subflow_context *subflow; in mptcp_nl_find_ssk() local
430 mptcp_for_each_subflow(msk, subflow) { in mptcp_nl_find_ssk()
434 ssk = mptcp_subflow_tcp_sock(subflow); in mptcp_nl_find_ssk()
538 struct mptcp_subflow_context *subflow = mptcp_subflow_ctx(ssk); in mptcp_pm_nl_subflow_destroy_doit() local
545 mptcp_close_ssk(sk, ssk, subflow); in mptcp_pm_nl_subflow_destroy_doit()
A DMakefile4 mptcp-y := protocol.o subflow.o options.o token.o crypto.o ctrl.o pm.o diag.o \
A DKconfig10 subflows in order to utilize multiple network paths. Each subflow
/linux/tools/testing/selftests/net/mptcp/
A Dmptcp_join.sh1669 local subflow="client"
1683 subflow="server"
1696 print_check "rm subflow ${subflow}"
1942 pm_nl_add_endpoint $ns2 10.0.3.2 flags subflow
1951 pm_nl_add_endpoint $ns2 10.0.3.2 flags subflow
1960 pm_nl_add_endpoint $ns2 10.0.3.2 flags subflow
1969 pm_nl_add_endpoint $ns2 10.0.3.2 flags subflow
1970 pm_nl_add_endpoint $ns2 10.0.2.2 flags subflow
1979 pm_nl_add_endpoint $ns2 10.0.3.2 flags subflow
1980 pm_nl_add_endpoint $ns2 10.0.2.2 flags subflow
[all …]
A Dpm_netlink.sh150 add_endpoint 10.0.1.2 flags subflow dev lo
156 "2,10.0.1.2,subflow,lo" \
242 add_endpoint 10.0.1.1 flags subflow
244 check "show_endpoints" "$(format_endpoints "1,10.0.1.1,subflow backup")" \
247 check "show_endpoints" "$(format_endpoints "1,10.0.1.1,subflow")" \
254 check "show_endpoints" "$(format_endpoints "1,10.0.1.1,subflow fullmesh")" \
257 check "show_endpoints" "$(format_endpoints "1,10.0.1.1,subflow")" \
260 check "show_endpoints" "$(format_endpoints "1,10.0.1.1,subflow backup fullmesh")" \
A Dsimult_flows.sh90 mptcp_lib_pm_nl_add_endpoint "${ns1}" 10.0.2.1 dev ns1eth2 flags subflow
/linux/include/trace/events/
A Dmptcp.h20 TP_PROTO(struct mptcp_subflow_context *subflow),
22 TP_ARGS(subflow),
36 __entry->active = mptcp_subflow_active(subflow);
37 __entry->backup = subflow->backup || subflow->request_bkup;
39 if (subflow->tcp_sock && sk_fullsock(subflow->tcp_sock))
40 __entry->free = sk_stream_memory_free(subflow->tcp_sock);
44 ssk = mptcp_subflow_tcp_sock(subflow);
/linux/Documentation/netlink/specs/
A Dmptcp_pm.yaml58 A new subflow has been established. 'error' should not be set.
64 A subflow has been closed. An error (copy of sk_err) could be set if an
65 error has been detected for this subflow.
72 The priority of a subflow has changed. 'error' should not be set.
119 name: subflow-attribute
120 name-prefix: mptcp-subflow-attr-
375 name: subflow-create
387 name: subflow-destroy
/linux/Documentation/networking/
A Dmptcp-sysctl.rst22 by the initial subflow if the value is 1. This controls a flag that is
59 unchanged for such time, after the last subflow removal, before
77 socket. In-kernel path management will control subflow
80 API. Userspace path management puts per-MPTCP-connection subflow
102 pending outstanding data on a given subflow required to declare it stale.
A Dmptcp.rst41 (Linux-specific), a *subflow* (or *path*) is created. This *subflow* consists of
45 *option* field of the underlying TCP *subflow*. This field contains, amongst
79 The Packet Scheduler is in charge of selecting which available *subflow(s)* to
127 values per subflow.
151 kernel is in charge of creating subflow sockets: they are TCP sockets where the

Completed in 59 milliseconds