xref: /linux-6.15/include/uapi/linux/mptcp.h (revision 66cd9d4e)
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 
25 enum {
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  */
52 enum {
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 
64 enum {
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 #define MPTCP_PM_ADDR_FLAG_IMPLICIT			(1 << 4)
85 
86 enum {
87 	MPTCP_PM_CMD_UNSPEC,
88 
89 	MPTCP_PM_CMD_ADD_ADDR,
90 	MPTCP_PM_CMD_DEL_ADDR,
91 	MPTCP_PM_CMD_GET_ADDR,
92 	MPTCP_PM_CMD_FLUSH_ADDRS,
93 	MPTCP_PM_CMD_SET_LIMITS,
94 	MPTCP_PM_CMD_GET_LIMITS,
95 	MPTCP_PM_CMD_SET_FLAGS,
96 
97 	__MPTCP_PM_CMD_AFTER_LAST
98 };
99 
100 #define MPTCP_INFO_FLAG_FALLBACK		_BITUL(0)
101 #define MPTCP_INFO_FLAG_REMOTE_KEY_RECEIVED	_BITUL(1)
102 
103 struct mptcp_info {
104 	__u8	mptcpi_subflows;
105 	__u8	mptcpi_add_addr_signal;
106 	__u8	mptcpi_add_addr_accepted;
107 	__u8	mptcpi_subflows_max;
108 	__u8	mptcpi_add_addr_signal_max;
109 	__u8	mptcpi_add_addr_accepted_max;
110 	__u32	mptcpi_flags;
111 	__u32	mptcpi_token;
112 	__u64	mptcpi_write_seq;
113 	__u64	mptcpi_snd_una;
114 	__u64	mptcpi_rcv_nxt;
115 	__u8	mptcpi_local_addr_used;
116 	__u8	mptcpi_local_addr_max;
117 	__u8	mptcpi_csum_enabled;
118 };
119 
120 /*
121  * MPTCP_EVENT_CREATED: token, family, saddr4 | saddr6, daddr4 | daddr6,
122  *                      sport, dport
123  * A new MPTCP connection has been created. It is the good time to allocate
124  * memory and send ADD_ADDR if needed. Depending on the traffic-patterns
125  * it can take a long time until the MPTCP_EVENT_ESTABLISHED is sent.
126  *
127  * MPTCP_EVENT_ESTABLISHED: token, family, saddr4 | saddr6, daddr4 | daddr6,
128  *			    sport, dport
129  * A MPTCP connection is established (can start new subflows).
130  *
131  * MPTCP_EVENT_CLOSED: token
132  * A MPTCP connection has stopped.
133  *
134  * MPTCP_EVENT_ANNOUNCED: token, rem_id, family, daddr4 | daddr6 [, dport]
135  * A new address has been announced by the peer.
136  *
137  * MPTCP_EVENT_REMOVED: token, rem_id
138  * An address has been lost by the peer.
139  *
140  * MPTCP_EVENT_SUB_ESTABLISHED: token, family, loc_id, rem_id,
141  *                              saddr4 | saddr6, daddr4 | daddr6, sport,
142  *                              dport, backup, if_idx [, error]
143  * A new subflow has been established. 'error' should not be set.
144  *
145  * MPTCP_EVENT_SUB_CLOSED: token, family, loc_id, rem_id, saddr4 | saddr6,
146  *                         daddr4 | daddr6, sport, dport, backup, if_idx
147  *                         [, error]
148  * A subflow has been closed. An error (copy of sk_err) could be set if an
149  * error has been detected for this subflow.
150  *
151  * MPTCP_EVENT_SUB_PRIORITY: token, family, loc_id, rem_id, saddr4 | saddr6,
152  *                           daddr4 | daddr6, sport, dport, backup, if_idx
153  *                           [, error]
154  * The priority of a subflow has changed. 'error' should not be set.
155  */
156 enum mptcp_event_type {
157 	MPTCP_EVENT_UNSPEC = 0,
158 	MPTCP_EVENT_CREATED = 1,
159 	MPTCP_EVENT_ESTABLISHED = 2,
160 	MPTCP_EVENT_CLOSED = 3,
161 
162 	MPTCP_EVENT_ANNOUNCED = 6,
163 	MPTCP_EVENT_REMOVED = 7,
164 
165 	MPTCP_EVENT_SUB_ESTABLISHED = 10,
166 	MPTCP_EVENT_SUB_CLOSED = 11,
167 
168 	MPTCP_EVENT_SUB_PRIORITY = 13,
169 };
170 
171 enum mptcp_event_attr {
172 	MPTCP_ATTR_UNSPEC = 0,
173 
174 	MPTCP_ATTR_TOKEN,	/* u32 */
175 	MPTCP_ATTR_FAMILY,	/* u16 */
176 	MPTCP_ATTR_LOC_ID,	/* u8 */
177 	MPTCP_ATTR_REM_ID,	/* u8 */
178 	MPTCP_ATTR_SADDR4,	/* be32 */
179 	MPTCP_ATTR_SADDR6,	/* struct in6_addr */
180 	MPTCP_ATTR_DADDR4,	/* be32 */
181 	MPTCP_ATTR_DADDR6,	/* struct in6_addr */
182 	MPTCP_ATTR_SPORT,	/* be16 */
183 	MPTCP_ATTR_DPORT,	/* be16 */
184 	MPTCP_ATTR_BACKUP,	/* u8 */
185 	MPTCP_ATTR_ERROR,	/* u8 */
186 	MPTCP_ATTR_FLAGS,	/* u16 */
187 	MPTCP_ATTR_TIMEOUT,	/* u32 */
188 	MPTCP_ATTR_IF_IDX,	/* s32 */
189 	MPTCP_ATTR_RESET_REASON,/* u32 */
190 	MPTCP_ATTR_RESET_FLAGS, /* u32 */
191 
192 	__MPTCP_ATTR_AFTER_LAST
193 };
194 
195 #define MPTCP_ATTR_MAX (__MPTCP_ATTR_AFTER_LAST - 1)
196 
197 /* MPTCP Reset reason codes, rfc8684 */
198 #define MPTCP_RST_EUNSPEC	0
199 #define MPTCP_RST_EMPTCP	1
200 #define MPTCP_RST_ERESOURCE	2
201 #define MPTCP_RST_EPROHIBIT	3
202 #define MPTCP_RST_EWQ2BIG	4
203 #define MPTCP_RST_EBADPERF	5
204 #define MPTCP_RST_EMIDDLEBOX	6
205 
206 struct mptcp_subflow_data {
207 	__u32		size_subflow_data;		/* size of this structure in userspace */
208 	__u32		num_subflows;			/* must be 0, set by kernel */
209 	__u32		size_kernel;			/* must be 0, set by kernel */
210 	__u32		size_user;			/* size of one element in data[] */
211 } __attribute__((aligned(8)));
212 
213 struct mptcp_subflow_addrs {
214 	union {
215 		__kernel_sa_family_t sa_family;
216 		struct sockaddr sa_local;
217 		struct sockaddr_in sin_local;
218 		struct sockaddr_in6 sin6_local;
219 		struct __kernel_sockaddr_storage ss_local;
220 	};
221 	union {
222 		struct sockaddr sa_remote;
223 		struct sockaddr_in sin_remote;
224 		struct sockaddr_in6 sin6_remote;
225 		struct __kernel_sockaddr_storage ss_remote;
226 	};
227 };
228 
229 /* MPTCP socket options */
230 #define MPTCP_INFO		1
231 #define MPTCP_TCPINFO		2
232 #define MPTCP_SUBFLOW_ADDRS	3
233 
234 #endif /* _UAPI_MPTCP_H */
235