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