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