15147dfb5SDavide Caratti /* SPDX-License-Identifier: GPL-2.0+ WITH Linux-syscall-note */ 25147dfb5SDavide Caratti #ifndef _UAPI_MPTCP_H 35147dfb5SDavide Caratti #define _UAPI_MPTCP_H 45147dfb5SDavide Caratti 506e445f7SOssama Othman #ifndef __KERNEL__ 606e445f7SOssama Othman #include <netinet/in.h> /* for sockaddr_in and sockaddr_in6 */ 706e445f7SOssama Othman #include <sys/socket.h> /* for struct sockaddr */ 806e445f7SOssama Othman #endif 906e445f7SOssama Othman 105147dfb5SDavide Caratti #include <linux/const.h> 115147dfb5SDavide Caratti #include <linux/types.h> 12c11c5906SFlorian Westphal #include <linux/in.h> /* for sockaddr_in */ 13c11c5906SFlorian Westphal #include <linux/in6.h> /* for sockaddr_in6 */ 14c11c5906SFlorian Westphal #include <linux/socket.h> /* for sockaddr_storage and sa_family */ 15c11c5906SFlorian Westphal 165147dfb5SDavide Caratti #define MPTCP_SUBFLOW_FLAG_MCAP_REM _BITUL(0) 175147dfb5SDavide Caratti #define MPTCP_SUBFLOW_FLAG_MCAP_LOC _BITUL(1) 185147dfb5SDavide Caratti #define MPTCP_SUBFLOW_FLAG_JOIN_REM _BITUL(2) 195147dfb5SDavide Caratti #define MPTCP_SUBFLOW_FLAG_JOIN_LOC _BITUL(3) 205147dfb5SDavide Caratti #define MPTCP_SUBFLOW_FLAG_BKUP_REM _BITUL(4) 215147dfb5SDavide Caratti #define MPTCP_SUBFLOW_FLAG_BKUP_LOC _BITUL(5) 225147dfb5SDavide Caratti #define MPTCP_SUBFLOW_FLAG_FULLY_ESTABLISHED _BITUL(6) 235147dfb5SDavide Caratti #define MPTCP_SUBFLOW_FLAG_CONNECTED _BITUL(7) 245147dfb5SDavide Caratti #define MPTCP_SUBFLOW_FLAG_MAPVALID _BITUL(8) 255147dfb5SDavide Caratti 2601cacb00SPaolo Abeni #define MPTCP_PM_CMD_GRP_NAME "mptcp_pm_cmds" 27b911c97cSFlorian Westphal #define MPTCP_PM_EV_GRP_NAME "mptcp_pm_events" 2801cacb00SPaolo Abeni 29*9d1ed17fSDavide Caratti #include <linux/mptcp_pm.h> 3001cacb00SPaolo Abeni 31*9d1ed17fSDavide Caratti /* for backward compatibility */ 32*9d1ed17fSDavide Caratti #define __MPTCP_PM_CMD_AFTER_LAST __MPTCP_PM_CMD_MAX 33*9d1ed17fSDavide Caratti #define __MPTCP_ATTR_AFTER_LAST __MPTCP_ATTR_MAX 3401cacb00SPaolo Abeni 35*9d1ed17fSDavide Caratti #define MPTCP_INFO_FLAG_FALLBACK _BITUL(0) 36*9d1ed17fSDavide Caratti #define MPTCP_INFO_FLAG_REMOTE_KEY_RECEIVED _BITUL(1) 3701cacb00SPaolo Abeni 3801cacb00SPaolo Abeni #define MPTCP_PM_ADDR_FLAG_SIGNAL (1 << 0) 3901cacb00SPaolo Abeni #define MPTCP_PM_ADDR_FLAG_SUBFLOW (1 << 1) 4001cacb00SPaolo Abeni #define MPTCP_PM_ADDR_FLAG_BACKUP (1 << 2) 412843ff6fSGeliang Tang #define MPTCP_PM_ADDR_FLAG_FULLMESH (1 << 3) 42d045b9ebSPaolo Abeni #define MPTCP_PM_ADDR_FLAG_IMPLICIT (1 << 4) 4301cacb00SPaolo Abeni 44ac3b45f6SPaolo Abeni struct mptcp_info { 45ac3b45f6SPaolo Abeni __u8 mptcpi_subflows; 46ac3b45f6SPaolo Abeni __u8 mptcpi_add_addr_signal; 47ac3b45f6SPaolo Abeni __u8 mptcpi_add_addr_accepted; 48ac3b45f6SPaolo Abeni __u8 mptcpi_subflows_max; 49ac3b45f6SPaolo Abeni __u8 mptcpi_add_addr_signal_max; 50ac3b45f6SPaolo Abeni __u8 mptcpi_add_addr_accepted_max; 51ac3b45f6SPaolo Abeni __u32 mptcpi_flags; 52ac3b45f6SPaolo Abeni __u32 mptcpi_token; 53ac3b45f6SPaolo Abeni __u64 mptcpi_write_seq; 54ac3b45f6SPaolo Abeni __u64 mptcpi_snd_una; 55ac3b45f6SPaolo Abeni __u64 mptcpi_rcv_nxt; 560caf3adaSGeliang Tang __u8 mptcpi_local_addr_used; 570caf3adaSGeliang Tang __u8 mptcpi_local_addr_max; 58752e9067SGeliang Tang __u8 mptcpi_csum_enabled; 5938967f42SPaolo Abeni __u32 mptcpi_retransmits; 6038967f42SPaolo Abeni __u64 mptcpi_bytes_retrans; 6138967f42SPaolo Abeni __u64 mptcpi_bytes_sent; 6238967f42SPaolo Abeni __u64 mptcpi_bytes_received; 6338967f42SPaolo Abeni __u64 mptcpi_bytes_acked; 64ac3b45f6SPaolo Abeni }; 65ac3b45f6SPaolo Abeni 66dc87efdbSFlorian Westphal /* MPTCP Reset reason codes, rfc8684 */ 67dc87efdbSFlorian Westphal #define MPTCP_RST_EUNSPEC 0 68dc87efdbSFlorian Westphal #define MPTCP_RST_EMPTCP 1 69dc87efdbSFlorian Westphal #define MPTCP_RST_ERESOURCE 2 70dc87efdbSFlorian Westphal #define MPTCP_RST_EPROHIBIT 3 71dc87efdbSFlorian Westphal #define MPTCP_RST_EWQ2BIG 4 72dc87efdbSFlorian Westphal #define MPTCP_RST_EBADPERF 5 73dc87efdbSFlorian Westphal #define MPTCP_RST_EMIDDLEBOX 6 74dc87efdbSFlorian Westphal 7506f15ceeSFlorian Westphal struct mptcp_subflow_data { 7606f15ceeSFlorian Westphal __u32 size_subflow_data; /* size of this structure in userspace */ 7706f15ceeSFlorian Westphal __u32 num_subflows; /* must be 0, set by kernel */ 7806f15ceeSFlorian Westphal __u32 size_kernel; /* must be 0, set by kernel */ 7906f15ceeSFlorian Westphal __u32 size_user; /* size of one element in data[] */ 8006f15ceeSFlorian Westphal } __attribute__((aligned(8))); 8106f15ceeSFlorian Westphal 82c11c5906SFlorian Westphal struct mptcp_subflow_addrs { 83c11c5906SFlorian Westphal union { 84c11c5906SFlorian Westphal __kernel_sa_family_t sa_family; 85c11c5906SFlorian Westphal struct sockaddr sa_local; 86c11c5906SFlorian Westphal struct sockaddr_in sin_local; 87c11c5906SFlorian Westphal struct sockaddr_in6 sin6_local; 88c11c5906SFlorian Westphal struct __kernel_sockaddr_storage ss_local; 89c11c5906SFlorian Westphal }; 90c11c5906SFlorian Westphal union { 91c11c5906SFlorian Westphal struct sockaddr sa_remote; 92c11c5906SFlorian Westphal struct sockaddr_in sin_remote; 93c11c5906SFlorian Westphal struct sockaddr_in6 sin6_remote; 94c11c5906SFlorian Westphal struct __kernel_sockaddr_storage ss_remote; 95c11c5906SFlorian Westphal }; 96c11c5906SFlorian Westphal }; 97c11c5906SFlorian Westphal 9849243207SPaolo Abeni struct mptcp_subflow_info { 9949243207SPaolo Abeni __u32 id; 10049243207SPaolo Abeni struct mptcp_subflow_addrs addrs; 10149243207SPaolo Abeni }; 10249243207SPaolo Abeni 10349243207SPaolo Abeni struct mptcp_full_info { 10449243207SPaolo Abeni __u32 size_tcpinfo_kernel; /* must be 0, set by kernel */ 10549243207SPaolo Abeni __u32 size_tcpinfo_user; 10649243207SPaolo Abeni __u32 size_sfinfo_kernel; /* must be 0, set by kernel */ 10749243207SPaolo Abeni __u32 size_sfinfo_user; 10849243207SPaolo Abeni __u32 num_subflows; /* must be 0, set by kernel (real subflow count) */ 10949243207SPaolo Abeni __u32 size_arrays_user; /* max subflows that userspace is interested in; 11049243207SPaolo Abeni * the buffers at subflow_info/tcp_info 11149243207SPaolo Abeni * are respectively at least: 11249243207SPaolo Abeni * size_arrays * size_sfinfo_user 11349243207SPaolo Abeni * size_arrays * size_tcpinfo_user 11449243207SPaolo Abeni * bytes wide 11549243207SPaolo Abeni */ 11649243207SPaolo Abeni __aligned_u64 subflow_info; 11749243207SPaolo Abeni __aligned_u64 tcp_info; 11849243207SPaolo Abeni struct mptcp_info mptcp_info; 11949243207SPaolo Abeni }; 12049243207SPaolo Abeni 12155c42fa7SFlorian Westphal /* MPTCP socket options */ 12255c42fa7SFlorian Westphal #define MPTCP_INFO 1 12306f15ceeSFlorian Westphal #define MPTCP_TCPINFO 2 124c11c5906SFlorian Westphal #define MPTCP_SUBFLOW_ADDRS 3 12549243207SPaolo Abeni #define MPTCP_FULL_INFO 4 12655c42fa7SFlorian Westphal 1275147dfb5SDavide Caratti #endif /* _UAPI_MPTCP_H */ 128