| /linux/net/mptcp/ |
| H A D | subflow.c | 347 struct mptcp_subflow_context *subflow = mptcp_subflow_ctx(sk); in subflow_prep_synack() local 355 mptcp_fastopen_subflow_synack_set_params(subflow, req); in subflow_prep_synack() 414 static bool subflow_thmac_valid(struct mptcp_subflow_context *subflow) in subflow_thmac_valid() argument 419 subflow_generate_hmac(subflow->remote_key, subflow->local_key, in subflow_thmac_valid() 420 subflow->remote_nonce, subflow->local_nonce, in subflow_thmac_valid() 424 pr_debug("subflow=%p, token=%u, thmac=%llu, subflow->thmac=%llu\n", in subflow_thmac_valid() 425 subflow, subflow->token, thmac, subflow->thmac); in subflow_thmac_valid() 427 return thmac == subflow->thmac; in subflow_thmac_valid() 432 struct mptcp_subflow_context *subflow = mptcp_subflow_ctx(ssk); in mptcp_subflow_reset() local 433 struct sock *sk = subflow->conn; in mptcp_subflow_reset() [all …]
|
| H A D | pm.c | 121 struct mptcp_subflow_context *subflow; in mptcp_lookup_subflow_by_saddr() local 125 list_for_each_entry(subflow, list, node) { in mptcp_lookup_subflow_by_saddr() 126 skc = (struct sock_common *)mptcp_subflow_tcp_sock(subflow); in mptcp_lookup_subflow_by_saddr() 187 struct mptcp_subflow_context *subflow, in __mptcp_pm_send_ack() argument 190 struct sock *ssk = mptcp_subflow_tcp_sock(subflow); in __mptcp_pm_send_ack() 199 subflow->send_mp_prio = 1; in __mptcp_pm_send_ack() 200 subflow->request_bkup = backup; in __mptcp_pm_send_ack() 208 struct mptcp_subflow_context *subflow, in mptcp_pm_send_ack() argument 212 __mptcp_pm_send_ack(msk, subflow, prio, backup); in mptcp_pm_send_ack() 216 static bool subflow_in_rm_list(const struct mptcp_subflow_context *subflow, in subflow_in_rm_list() argument [all …]
|
| H A D | protocol.c | 84 * in the fallback case only the current subflow is touching in __mptcp_try_fallback() 105 struct mptcp_subflow_context *subflow; in __mptcp_socket_create() local 116 subflow = mptcp_subflow_ctx(ssock->sk); in __mptcp_socket_create() 117 list_add(&subflow->node, &msk->conn_list); in __mptcp_socket_create() 119 subflow->request_mptcp = 1; in __mptcp_socket_create() 120 subflow->subflow_id = msk->subflow_id++; in __mptcp_socket_create() 122 /* This is the first subflow, always with id 0 */ in __mptcp_socket_create() 123 WRITE_ONCE(subflow->local_id, 0); in __mptcp_socket_create() 130 /* If the MPC handshake is not started, returns the first subflow, 357 struct mptcp_subflow_context *subflow = mptcp_subflow_ctx(ssk); in mptcp_init_skb() local [all …]
|
| H A D | options.c | 56 * close the subflow with a RST, as it is not behaving as negotiated. in mptcp_parse_option() 58 * receiver MUST close the subflow with a RST, as it is considered in mptcp_parse_option() 404 struct mptcp_subflow_context *subflow = mptcp_subflow_ctx(sk); in mptcp_syn_options() local 409 subflow->snd_isn = TCP_SKB_CB(skb)->end_seq; in mptcp_syn_options() 410 if (subflow->request_mptcp) { in mptcp_syn_options() 417 subflow->request_mptcp = 0; in mptcp_syn_options() 426 } else if (subflow->request_join) { in mptcp_syn_options() 427 pr_debug("remote_token=%u, nonce=%u\n", subflow->remote_token, in mptcp_syn_options() 428 subflow->local_nonce); in mptcp_syn_options() 430 opts->join_id = subflow->local_id; in mptcp_syn_options() [all …]
|
| H A D | protocol.h | 272 /* Arbitrary compromise between as low as possible to react timely to subflow 274 * samples due to peer sending data on a different subflow WRT to the incoming 283 u64 local_key; /* protected by the first subflow socket lock 312 bool recovery; /* closing subflow write queue reinjected */ 321 u8 pending_state; /* A subflow asked to set this sk_state, 346 * ONCE annotation, the subflow outside the socket 541 /* MPTCP subflow context */ 583 is_mptfo : 1, /* subflow is doing TFO */ 597 u8 hmac[MPTCPOPT_HMAC_LEN]; /* MPJ subflow only */ 641 mptcp_subflow_tcp_sock(const struct mptcp_subflow_context *subflow) in mptcp_subflow_tcp_sock() argument [all …]
|
| H A D | fastopen.c | 9 void mptcp_fastopen_subflow_synack_set_params(struct mptcp_subflow_context *subflow, in mptcp_fastopen_subflow_synack_set_params() argument 17 /* on early fallback the subflow context is deleted by in mptcp_fastopen_subflow_synack_set_params() 20 if (!subflow) in mptcp_fastopen_subflow_synack_set_params() 23 ssk = subflow->tcp_sock; in mptcp_fastopen_subflow_synack_set_params() 24 sk = subflow->conn; in mptcp_fastopen_subflow_synack_set_params() 27 subflow->is_mptfo = 1; in mptcp_fastopen_subflow_synack_set_params() 37 mptcp_subflow_lend_fwdmem(subflow, skb); in mptcp_fastopen_subflow_synack_set_params() 40 * space, need to offset it in the subflow sequence, see mptcp_subflow_get_map_offset() in mptcp_fastopen_subflow_synack_set_params() 43 subflow->ssn_offset += skb->len; in mptcp_fastopen_subflow_synack_set_params()
|
| H A D | sockopt.c | 78 struct mptcp_subflow_context *subflow; in mptcp_sol_socket_sync_intval() local 84 mptcp_for_each_subflow(msk, subflow) { in mptcp_sol_socket_sync_intval() 85 struct sock *ssk = mptcp_subflow_tcp_sock(subflow); in mptcp_sol_socket_sync_intval() 122 subflow->setsockopt_seq = msk->setsockopt_seq; in mptcp_sol_socket_sync_intval() 156 struct mptcp_subflow_context *subflow; in mptcp_setsockopt_sol_socket_tstamp() local 166 mptcp_for_each_subflow(msk, subflow) { in mptcp_setsockopt_sol_socket_tstamp() 167 struct sock *ssk = mptcp_subflow_tcp_sock(subflow); in mptcp_setsockopt_sol_socket_tstamp() 216 struct mptcp_subflow_context *subflow; in mptcp_setsockopt_sol_socket_timestamping() local 242 mptcp_for_each_subflow(msk, subflow) { in mptcp_setsockopt_sol_socket_timestamping() 243 struct sock *ssk = mptcp_subflow_tcp_sock(subflow); in mptcp_setsockopt_sol_socket_timestamping() [all …]
|
| H A D | sched.c | 162 void mptcp_subflow_set_scheduled(struct mptcp_subflow_context *subflow, in mptcp_sched_get_send() 165 WRITE_ONCE(subflow->scheduled, scheduled); in mptcp_sched_get_send() 170 struct mptcp_subflow_context *subflow; in mptcp_sched_get_send() 185 mptcp_for_each_subflow(msk, subflow) { in mptcp_sched_get_retrans() 186 if (READ_ONCE(subflow->scheduled)) in mptcp_sched_get_retrans() 197 struct mptcp_subflow_context *subflow; in mptcp_sched_get_retrans() 205 mptcp_for_each_subflow(msk, subflow) { in mptcp_sched_get_retrans() 206 if (READ_ONCE(subflow->scheduled)) in mptcp_sched_get_retrans() 151 mptcp_subflow_set_scheduled(struct mptcp_subflow_context * subflow,bool scheduled) mptcp_subflow_set_scheduled() argument 159 struct mptcp_subflow_context *subflow; mptcp_sched_get_send() local 187 struct mptcp_subflow_context *subflow; mptcp_sched_get_retrans() local
|
| H A D | pm_kernel.c | 101 struct mptcp_subflow_context *subflow; in lookup_subflow_by_daddr() local 104 list_for_each_entry(subflow, list, node) { in lookup_subflow_by_daddr() 105 struct sock *ssk = mptcp_subflow_tcp_sock(subflow); in lookup_subflow_by_daddr() 210 struct mptcp_subflow_context *subflow; in fill_remote_addresses_fullmesh() local 217 mptcp_for_each_subflow(msk, subflow) in fill_remote_addresses_fullmesh() 218 if (READ_ONCE(subflow->local_id) == local->id) in fill_remote_addresses_fullmesh() 219 __set_bit(subflow->remote_id, unavail_id); in fill_remote_addresses_fullmesh() 221 mptcp_for_each_subflow(msk, subflow) { in fill_remote_addresses_fullmesh() 222 ssk = mptcp_subflow_tcp_sock(subflow); in fill_remote_addresses_fullmesh() 224 addrs[i].id = READ_ONCE(subflow->remote_id); in fill_remote_addresses_fullmesh() [all …]
|
| H A D | mib.h | 33 MPTCP_MIB_DSSCORRUPTIONRESET, /* DSS corruption detected, MPJ subflow reset */ 64 MPTCP_MIB_RMSUBFLOW, /* Remove a subflow */ 75 MPTCP_MIB_SNDWNDSHARED, /* Subflow snd wnd is overridden by msk's one */ 76 MPTCP_MIB_RCVWNDSHARED, /* Subflow rcv wnd is overridden by msk's one */ 77 MPTCP_MIB_RCVWNDCONFLICTUPDATE, /* subflow rcv wnd is overridden by msk's one due to 78 * conflict with another subflow while updating msk rcv wnd
|
| H A D | pm_userspace.c | 93 /* If the subflow is closed from the other peer (not via a 94 * subflow destroy command then), we want to keep the entry 96 * able to send RM_ADDR after the removal of the subflow. 249 struct mptcp_subflow_context *subflow; in mptcp_userspace_pm_remove_id_zero_address() local 255 mptcp_for_each_subflow(msk, subflow) { in mptcp_userspace_pm_remove_id_zero_address() 256 if (READ_ONCE(subflow->local_id) == 0) { in mptcp_userspace_pm_remove_id_zero_address() 283 /* only delete if either announced or matching a subflow */ in mptcp_pm_remove_addr_entry() 436 struct mptcp_subflow_context *subflow; in mptcp_nl_find_ssk() local 441 mptcp_for_each_subflow(msk, subflow) { in mptcp_nl_find_ssk() 445 ssk = mptcp_subflow_tcp_sock(subflow); in mptcp_nl_find_ssk() [all …]
|
| H A D | Makefile | 4 mptcp-y := protocol.o subflow.o options.o token.o crypto.o ctrl.o pm.o diag.o \
|
| H A D | Kconfig | 10 subflows in order to utilize multiple network paths. Each subflow
|
| H A D | syncookies.c | 89 * Caller will check msk can still accept another subflow. The hmac
|
| H A D | pm_netlink.c | 468 struct mptcp_subflow_context *subflow = mptcp_subflow_ctx(ssk); in mptcp_event_addr_announced() local 469 struct mptcp_sock *msk = mptcp_sk(subflow->conn); in mptcp_event_addr_announced()
|
| /linux/tools/testing/selftests/net/mptcp/ |
| H A D | mptcp_join.sh | 765 local flags="subflow" 771 # let the mptcp subflow be established in background before 1596 # the subflow creation 1857 local subflow="client" 1871 subflow="server" 1884 print_check "rm subflow ${subflow}" 1893 # in case of simult flush, the subflow removal count on each side is 2037 # number of all subflows, including the initial subflow. 2126 # subflow limited by client 2127 if reset "single subflow, limited by client"; then [all …]
|
| H A D | pm_netlink.sh | 153 add_endpoint 10.0.1.2 flags subflow dev lo 159 "2,10.0.1.2,subflow,lo" \ 254 add_endpoint 10.0.1.1 flags subflow 256 check "show_endpoints" "$(format_endpoints "1,10.0.1.1,subflow backup")" \ 259 check "show_endpoints" "$(format_endpoints "1,10.0.1.1,subflow")" \ 266 check "show_endpoints" "$(format_endpoints "1,10.0.1.1,subflow fullmesh")" \ 269 check "show_endpoints" "$(format_endpoints "1,10.0.1.1,subflow")" \ 272 check "show_endpoints" "$(format_endpoints "1,10.0.1.1,subflow backup fullmesh")" \
|
| H A D | userspace_pm.sh | 336 # ADD_ADDR from the client to server machine reusing the subflow port 346 # ADD_ADDR6 from the client to server machine reusing the subflow port 368 # ADD_ADDR from the server to client machine reusing the subflow port 376 # ADD_ADDR6 from the server to client machine reusing the subflow port 574 # Attempt to add a listener at 10.0.2.2:<subflow-port> 579 # ADD_ADDR from client to server machine reusing the subflow port 611 # Attempt to add a listener at dead:beef:2::2:<subflow-port> 616 # ADD_ADDR6 from client to server machine reusing the subflow port 690 # Attempt to add a listener at 10.0.2.1:<subflow-port> 695 # ADD_ADDR from server to client machine reusing the subflow por [all...] |
| H A D | mptcp_diag.c | 213 printf("It's a mptcp subflow, the subflow info:\n"); in print_subflow_info()
|
| H A D | pm_nl_ctl.c | 32 fprintf(stderr, "\tadd [flags signal|subflow|backup|fullmesh] [id <nr>] [dev <name>] <ip>\n"); in syntax() 42 fprintf(stderr, "\tlimits [<rcv addr max> <subflow max>]\n"); in syntax() 831 if (!strcmp(tok, "subflow")) in add_addr() 1021 printf("subflow"); in print_addr()
|
| H A D | simult_flows.sh | 90 mptcp_lib_pm_nl_add_endpoint "${ns1}" 10.0.2.1 dev ns1eth2 flags subflow
|
| /linux/include/net/ |
| H A D | rstreason.h | 134 * This is the default error; it implies that the subflow is no 143 * is being sent to close a subflow because of an invalid response. 149 * resources to support the terminated subflow. 154 * This code indicates that the requested subflow is prohibited by 161 * that needs to be transmitted over the terminated subflow while 170 * This code indicates that the performance of this subflow was 177 * Middlebox interference has been detected over this subflow,
|
| /linux/Documentation/networking/ |
| H A D | mptcp.rst | 41 (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
|
| /linux/tools/testing/selftests/bpf/prog_tests/ |
| H A D | mptcp.c | 428 if (endpoint_init("subflow") < 0) in test_subflow() 563 if (endpoint_init("subflow") < 0) in test_mptcp_sockmap() 583 if (test__start_subtest("subflow")) in test_mptcp()
|
| /linux/include/uapi/linux/ |
| H A D | mptcp.h | 123 __u32 num_subflows; /* must be 0, set by kernel (real subflow count) */
|