Linux kernel mirror (for testing)
git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel
os
linux
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#define MPTCP_PM_ADDR_FLAG_IMPLICIT (1 << 4)
85
86enum {
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
103struct 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 */
156enum 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
171enum 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
206struct 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
213struct 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 */