master
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#define MPTCP_PM_CMD_GRP_NAME "mptcp_pm_cmds"
25#define MPTCP_PM_EV_GRP_NAME "mptcp_pm_events"
26
27#include <linux/mptcp_pm.h>
28
29#define MPTCP_INFO_FLAG_FALLBACK _BITUL(0)
30#define MPTCP_INFO_FLAG_REMOTE_KEY_RECEIVED _BITUL(1)
31
32#define MPTCP_PM_EV_FLAG_DENY_JOIN_ID0 _BITUL(0)
33
34#define MPTCP_PM_ADDR_FLAG_SIGNAL (1 << 0)
35#define MPTCP_PM_ADDR_FLAG_SUBFLOW (1 << 1)
36#define MPTCP_PM_ADDR_FLAG_BACKUP (1 << 2)
37#define MPTCP_PM_ADDR_FLAG_FULLMESH (1 << 3)
38#define MPTCP_PM_ADDR_FLAG_IMPLICIT (1 << 4)
39
40struct mptcp_info {
41 __u8 mptcpi_subflows;
42 __u8 mptcpi_add_addr_signal;
43 __u8 mptcpi_add_addr_accepted;
44 __u8 mptcpi_subflows_max;
45 __u8 mptcpi_add_addr_signal_max;
46 __u8 mptcpi_add_addr_accepted_max;
47 __u32 mptcpi_flags;
48 __u32 mptcpi_token;
49 __u64 mptcpi_write_seq;
50 __u64 mptcpi_snd_una;
51 __u64 mptcpi_rcv_nxt;
52 __u8 mptcpi_local_addr_used;
53 __u8 mptcpi_local_addr_max;
54 __u8 mptcpi_csum_enabled;
55 __u32 mptcpi_retransmits;
56 __u64 mptcpi_bytes_retrans;
57 __u64 mptcpi_bytes_sent;
58 __u64 mptcpi_bytes_received;
59 __u64 mptcpi_bytes_acked;
60 __u8 mptcpi_subflows_total;
61 __u8 reserved[3];
62 __u32 mptcpi_last_data_sent;
63 __u32 mptcpi_last_data_recv;
64 __u32 mptcpi_last_ack_recv;
65};
66
67/* MPTCP Reset reason codes, rfc8684 */
68#define MPTCP_RST_EUNSPEC 0
69#define MPTCP_RST_EMPTCP 1
70#define MPTCP_RST_ERESOURCE 2
71#define MPTCP_RST_EPROHIBIT 3
72#define MPTCP_RST_EWQ2BIG 4
73#define MPTCP_RST_EBADPERF 5
74#define MPTCP_RST_EMIDDLEBOX 6
75
76struct mptcp_subflow_data {
77 __u32 size_subflow_data; /* size of this structure in userspace */
78 __u32 num_subflows; /* must be 0, set by kernel */
79 __u32 size_kernel; /* must be 0, set by kernel */
80 __u32 size_user; /* size of one element in data[] */
81} __attribute__((aligned(8)));
82
83struct mptcp_subflow_addrs {
84 union {
85 __kernel_sa_family_t sa_family;
86 struct sockaddr sa_local;
87 struct sockaddr_in sin_local;
88 struct sockaddr_in6 sin6_local;
89 struct __kernel_sockaddr_storage ss_local;
90 };
91 union {
92 struct sockaddr sa_remote;
93 struct sockaddr_in sin_remote;
94 struct sockaddr_in6 sin6_remote;
95 struct __kernel_sockaddr_storage ss_remote;
96 };
97};
98
99struct mptcp_subflow_info {
100 __u32 id;
101 struct mptcp_subflow_addrs addrs;
102};
103
104struct mptcp_full_info {
105 __u32 size_tcpinfo_kernel; /* must be 0, set by kernel */
106 __u32 size_tcpinfo_user;
107 __u32 size_sfinfo_kernel; /* must be 0, set by kernel */
108 __u32 size_sfinfo_user;
109 __u32 num_subflows; /* must be 0, set by kernel (real subflow count) */
110 __u32 size_arrays_user; /* max subflows that userspace is interested in;
111 * the buffers at subflow_info/tcp_info
112 * are respectively at least:
113 * size_arrays * size_sfinfo_user
114 * size_arrays * size_tcpinfo_user
115 * bytes wide
116 */
117 __aligned_u64 subflow_info;
118 __aligned_u64 tcp_info;
119 struct mptcp_info mptcp_info;
120};
121
122/* MPTCP socket options */
123#define MPTCP_INFO 1
124#define MPTCP_TCPINFO 2
125#define MPTCP_SUBFLOW_ADDRS 3
126#define MPTCP_FULL_INFO 4
127
128#endif /* _MPTCP_H */