Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux
fork

Configure Feed

Select the types of activity you want to include in your feed.

at v5.16-rc1 231 lines 6.6 kB view raw
1/* SPDX-License-Identifier: GPL-2.0+ WITH Linux-syscall-note */ 2#ifndef _UAPI_MPTCP_H 3#define _UAPI_MPTCP_H 4 5#include <linux/const.h> 6#include <linux/types.h> 7#include <linux/in.h> /* for sockaddr_in */ 8#include <linux/in6.h> /* for sockaddr_in6 */ 9#include <linux/socket.h> /* for sockaddr_storage and sa_family */ 10 11#ifndef __KERNEL__ 12#include <sys/socket.h> /* for struct sockaddr */ 13#endif 14 15#define MPTCP_SUBFLOW_FLAG_MCAP_REM _BITUL(0) 16#define MPTCP_SUBFLOW_FLAG_MCAP_LOC _BITUL(1) 17#define MPTCP_SUBFLOW_FLAG_JOIN_REM _BITUL(2) 18#define MPTCP_SUBFLOW_FLAG_JOIN_LOC _BITUL(3) 19#define MPTCP_SUBFLOW_FLAG_BKUP_REM _BITUL(4) 20#define MPTCP_SUBFLOW_FLAG_BKUP_LOC _BITUL(5) 21#define MPTCP_SUBFLOW_FLAG_FULLY_ESTABLISHED _BITUL(6) 22#define MPTCP_SUBFLOW_FLAG_CONNECTED _BITUL(7) 23#define MPTCP_SUBFLOW_FLAG_MAPVALID _BITUL(8) 24 25enum { 26 MPTCP_SUBFLOW_ATTR_UNSPEC, 27 MPTCP_SUBFLOW_ATTR_TOKEN_REM, 28 MPTCP_SUBFLOW_ATTR_TOKEN_LOC, 29 MPTCP_SUBFLOW_ATTR_RELWRITE_SEQ, 30 MPTCP_SUBFLOW_ATTR_MAP_SEQ, 31 MPTCP_SUBFLOW_ATTR_MAP_SFSEQ, 32 MPTCP_SUBFLOW_ATTR_SSN_OFFSET, 33 MPTCP_SUBFLOW_ATTR_MAP_DATALEN, 34 MPTCP_SUBFLOW_ATTR_FLAGS, 35 MPTCP_SUBFLOW_ATTR_ID_REM, 36 MPTCP_SUBFLOW_ATTR_ID_LOC, 37 MPTCP_SUBFLOW_ATTR_PAD, 38 __MPTCP_SUBFLOW_ATTR_MAX 39}; 40 41#define MPTCP_SUBFLOW_ATTR_MAX (__MPTCP_SUBFLOW_ATTR_MAX - 1) 42 43/* netlink interface */ 44#define MPTCP_PM_NAME "mptcp_pm" 45#define MPTCP_PM_CMD_GRP_NAME "mptcp_pm_cmds" 46#define MPTCP_PM_EV_GRP_NAME "mptcp_pm_events" 47#define MPTCP_PM_VER 0x1 48 49/* 50 * ATTR types defined for MPTCP 51 */ 52enum { 53 MPTCP_PM_ATTR_UNSPEC, 54 55 MPTCP_PM_ATTR_ADDR, /* nested address */ 56 MPTCP_PM_ATTR_RCV_ADD_ADDRS, /* u32 */ 57 MPTCP_PM_ATTR_SUBFLOWS, /* u32 */ 58 59 __MPTCP_PM_ATTR_MAX 60}; 61 62#define MPTCP_PM_ATTR_MAX (__MPTCP_PM_ATTR_MAX - 1) 63 64enum { 65 MPTCP_PM_ADDR_ATTR_UNSPEC, 66 67 MPTCP_PM_ADDR_ATTR_FAMILY, /* u16 */ 68 MPTCP_PM_ADDR_ATTR_ID, /* u8 */ 69 MPTCP_PM_ADDR_ATTR_ADDR4, /* struct in_addr */ 70 MPTCP_PM_ADDR_ATTR_ADDR6, /* struct in6_addr */ 71 MPTCP_PM_ADDR_ATTR_PORT, /* u16 */ 72 MPTCP_PM_ADDR_ATTR_FLAGS, /* u32 */ 73 MPTCP_PM_ADDR_ATTR_IF_IDX, /* s32 */ 74 75 __MPTCP_PM_ADDR_ATTR_MAX 76}; 77 78#define MPTCP_PM_ADDR_ATTR_MAX (__MPTCP_PM_ADDR_ATTR_MAX - 1) 79 80#define MPTCP_PM_ADDR_FLAG_SIGNAL (1 << 0) 81#define MPTCP_PM_ADDR_FLAG_SUBFLOW (1 << 1) 82#define MPTCP_PM_ADDR_FLAG_BACKUP (1 << 2) 83#define MPTCP_PM_ADDR_FLAG_FULLMESH (1 << 3) 84 85enum { 86 MPTCP_PM_CMD_UNSPEC, 87 88 MPTCP_PM_CMD_ADD_ADDR, 89 MPTCP_PM_CMD_DEL_ADDR, 90 MPTCP_PM_CMD_GET_ADDR, 91 MPTCP_PM_CMD_FLUSH_ADDRS, 92 MPTCP_PM_CMD_SET_LIMITS, 93 MPTCP_PM_CMD_GET_LIMITS, 94 MPTCP_PM_CMD_SET_FLAGS, 95 96 __MPTCP_PM_CMD_AFTER_LAST 97}; 98 99#define MPTCP_INFO_FLAG_FALLBACK _BITUL(0) 100#define MPTCP_INFO_FLAG_REMOTE_KEY_RECEIVED _BITUL(1) 101 102struct mptcp_info { 103 __u8 mptcpi_subflows; 104 __u8 mptcpi_add_addr_signal; 105 __u8 mptcpi_add_addr_accepted; 106 __u8 mptcpi_subflows_max; 107 __u8 mptcpi_add_addr_signal_max; 108 __u8 mptcpi_add_addr_accepted_max; 109 __u32 mptcpi_flags; 110 __u32 mptcpi_token; 111 __u64 mptcpi_write_seq; 112 __u64 mptcpi_snd_una; 113 __u64 mptcpi_rcv_nxt; 114 __u8 mptcpi_local_addr_used; 115 __u8 mptcpi_local_addr_max; 116 __u8 mptcpi_csum_enabled; 117}; 118 119/* 120 * MPTCP_EVENT_CREATED: token, family, saddr4 | saddr6, daddr4 | daddr6, 121 * sport, dport 122 * A new MPTCP connection has been created. It is the good time to allocate 123 * memory and send ADD_ADDR if needed. Depending on the traffic-patterns 124 * it can take a long time until the MPTCP_EVENT_ESTABLISHED is sent. 125 * 126 * MPTCP_EVENT_ESTABLISHED: token, family, saddr4 | saddr6, daddr4 | daddr6, 127 * sport, dport 128 * A MPTCP connection is established (can start new subflows). 129 * 130 * MPTCP_EVENT_CLOSED: token 131 * A MPTCP connection has stopped. 132 * 133 * MPTCP_EVENT_ANNOUNCED: token, rem_id, family, daddr4 | daddr6 [, dport] 134 * A new address has been announced by the peer. 135 * 136 * MPTCP_EVENT_REMOVED: token, rem_id 137 * An address has been lost by the peer. 138 * 139 * MPTCP_EVENT_SUB_ESTABLISHED: token, family, saddr4 | saddr6, 140 * daddr4 | daddr6, sport, dport, backup, 141 * if_idx [, error] 142 * A new subflow has been established. 'error' should not be set. 143 * 144 * MPTCP_EVENT_SUB_CLOSED: token, family, saddr4 | saddr6, daddr4 | daddr6, 145 * sport, dport, backup, if_idx [, error] 146 * A subflow has been closed. An error (copy of sk_err) could be set if an 147 * error has been detected for this subflow. 148 * 149 * MPTCP_EVENT_SUB_PRIORITY: token, family, saddr4 | saddr6, daddr4 | daddr6, 150 * sport, dport, backup, if_idx [, error] 151 * The priority of a subflow has changed. 'error' should not be set. 152 */ 153enum mptcp_event_type { 154 MPTCP_EVENT_UNSPEC = 0, 155 MPTCP_EVENT_CREATED = 1, 156 MPTCP_EVENT_ESTABLISHED = 2, 157 MPTCP_EVENT_CLOSED = 3, 158 159 MPTCP_EVENT_ANNOUNCED = 6, 160 MPTCP_EVENT_REMOVED = 7, 161 162 MPTCP_EVENT_SUB_ESTABLISHED = 10, 163 MPTCP_EVENT_SUB_CLOSED = 11, 164 165 MPTCP_EVENT_SUB_PRIORITY = 13, 166}; 167 168enum mptcp_event_attr { 169 MPTCP_ATTR_UNSPEC = 0, 170 171 MPTCP_ATTR_TOKEN, /* u32 */ 172 MPTCP_ATTR_FAMILY, /* u16 */ 173 MPTCP_ATTR_LOC_ID, /* u8 */ 174 MPTCP_ATTR_REM_ID, /* u8 */ 175 MPTCP_ATTR_SADDR4, /* be32 */ 176 MPTCP_ATTR_SADDR6, /* struct in6_addr */ 177 MPTCP_ATTR_DADDR4, /* be32 */ 178 MPTCP_ATTR_DADDR6, /* struct in6_addr */ 179 MPTCP_ATTR_SPORT, /* be16 */ 180 MPTCP_ATTR_DPORT, /* be16 */ 181 MPTCP_ATTR_BACKUP, /* u8 */ 182 MPTCP_ATTR_ERROR, /* u8 */ 183 MPTCP_ATTR_FLAGS, /* u16 */ 184 MPTCP_ATTR_TIMEOUT, /* u32 */ 185 MPTCP_ATTR_IF_IDX, /* s32 */ 186 MPTCP_ATTR_RESET_REASON,/* u32 */ 187 MPTCP_ATTR_RESET_FLAGS, /* u32 */ 188 189 __MPTCP_ATTR_AFTER_LAST 190}; 191 192#define MPTCP_ATTR_MAX (__MPTCP_ATTR_AFTER_LAST - 1) 193 194/* MPTCP Reset reason codes, rfc8684 */ 195#define MPTCP_RST_EUNSPEC 0 196#define MPTCP_RST_EMPTCP 1 197#define MPTCP_RST_ERESOURCE 2 198#define MPTCP_RST_EPROHIBIT 3 199#define MPTCP_RST_EWQ2BIG 4 200#define MPTCP_RST_EBADPERF 5 201#define MPTCP_RST_EMIDDLEBOX 6 202 203struct mptcp_subflow_data { 204 __u32 size_subflow_data; /* size of this structure in userspace */ 205 __u32 num_subflows; /* must be 0, set by kernel */ 206 __u32 size_kernel; /* must be 0, set by kernel */ 207 __u32 size_user; /* size of one element in data[] */ 208} __attribute__((aligned(8))); 209 210struct mptcp_subflow_addrs { 211 union { 212 __kernel_sa_family_t sa_family; 213 struct sockaddr sa_local; 214 struct sockaddr_in sin_local; 215 struct sockaddr_in6 sin6_local; 216 struct __kernel_sockaddr_storage ss_local; 217 }; 218 union { 219 struct sockaddr sa_remote; 220 struct sockaddr_in sin_remote; 221 struct sockaddr_in6 sin6_remote; 222 struct __kernel_sockaddr_storage ss_remote; 223 }; 224}; 225 226/* MPTCP socket options */ 227#define MPTCP_INFO 1 228#define MPTCP_TCPINFO 2 229#define MPTCP_SUBFLOW_ADDRS 3 230 231#endif /* _UAPI_MPTCP_H */