xref: /linux/include/uapi/linux/mptcp.h (revision 9d1ed17f93ce873cda16698267bdee096a768839)
15147dfb5SDavide Caratti /* SPDX-License-Identifier: GPL-2.0+ WITH Linux-syscall-note */
25147dfb5SDavide Caratti #ifndef _UAPI_MPTCP_H
35147dfb5SDavide Caratti #define _UAPI_MPTCP_H
45147dfb5SDavide Caratti 
506e445f7SOssama Othman #ifndef __KERNEL__
606e445f7SOssama Othman #include <netinet/in.h>		/* for sockaddr_in and sockaddr_in6	*/
706e445f7SOssama Othman #include <sys/socket.h>		/* for struct sockaddr			*/
806e445f7SOssama Othman #endif
906e445f7SOssama Othman 
105147dfb5SDavide Caratti #include <linux/const.h>
115147dfb5SDavide Caratti #include <linux/types.h>
12c11c5906SFlorian Westphal #include <linux/in.h>		/* for sockaddr_in			*/
13c11c5906SFlorian Westphal #include <linux/in6.h>		/* for sockaddr_in6			*/
14c11c5906SFlorian Westphal #include <linux/socket.h>	/* for sockaddr_storage and sa_family	*/
15c11c5906SFlorian Westphal 
165147dfb5SDavide Caratti #define MPTCP_SUBFLOW_FLAG_MCAP_REM		_BITUL(0)
175147dfb5SDavide Caratti #define MPTCP_SUBFLOW_FLAG_MCAP_LOC		_BITUL(1)
185147dfb5SDavide Caratti #define MPTCP_SUBFLOW_FLAG_JOIN_REM		_BITUL(2)
195147dfb5SDavide Caratti #define MPTCP_SUBFLOW_FLAG_JOIN_LOC		_BITUL(3)
205147dfb5SDavide Caratti #define MPTCP_SUBFLOW_FLAG_BKUP_REM		_BITUL(4)
215147dfb5SDavide Caratti #define MPTCP_SUBFLOW_FLAG_BKUP_LOC		_BITUL(5)
225147dfb5SDavide Caratti #define MPTCP_SUBFLOW_FLAG_FULLY_ESTABLISHED	_BITUL(6)
235147dfb5SDavide Caratti #define MPTCP_SUBFLOW_FLAG_CONNECTED		_BITUL(7)
245147dfb5SDavide Caratti #define MPTCP_SUBFLOW_FLAG_MAPVALID		_BITUL(8)
255147dfb5SDavide Caratti 
2601cacb00SPaolo Abeni #define MPTCP_PM_CMD_GRP_NAME	"mptcp_pm_cmds"
27b911c97cSFlorian Westphal #define MPTCP_PM_EV_GRP_NAME	"mptcp_pm_events"
2801cacb00SPaolo Abeni 
29*9d1ed17fSDavide Caratti #include <linux/mptcp_pm.h>
3001cacb00SPaolo Abeni 
31*9d1ed17fSDavide Caratti /* for backward compatibility */
32*9d1ed17fSDavide Caratti #define	__MPTCP_PM_CMD_AFTER_LAST	__MPTCP_PM_CMD_MAX
33*9d1ed17fSDavide Caratti #define	__MPTCP_ATTR_AFTER_LAST		__MPTCP_ATTR_MAX
3401cacb00SPaolo Abeni 
35*9d1ed17fSDavide Caratti #define MPTCP_INFO_FLAG_FALLBACK		_BITUL(0)
36*9d1ed17fSDavide Caratti #define MPTCP_INFO_FLAG_REMOTE_KEY_RECEIVED	_BITUL(1)
3701cacb00SPaolo Abeni 
3801cacb00SPaolo Abeni #define MPTCP_PM_ADDR_FLAG_SIGNAL                      (1 << 0)
3901cacb00SPaolo Abeni #define MPTCP_PM_ADDR_FLAG_SUBFLOW                     (1 << 1)
4001cacb00SPaolo Abeni #define MPTCP_PM_ADDR_FLAG_BACKUP                      (1 << 2)
412843ff6fSGeliang Tang #define MPTCP_PM_ADDR_FLAG_FULLMESH                    (1 << 3)
42d045b9ebSPaolo Abeni #define MPTCP_PM_ADDR_FLAG_IMPLICIT                    (1 << 4)
4301cacb00SPaolo Abeni 
44ac3b45f6SPaolo Abeni struct mptcp_info {
45ac3b45f6SPaolo Abeni 	__u8	mptcpi_subflows;
46ac3b45f6SPaolo Abeni 	__u8	mptcpi_add_addr_signal;
47ac3b45f6SPaolo Abeni 	__u8	mptcpi_add_addr_accepted;
48ac3b45f6SPaolo Abeni 	__u8	mptcpi_subflows_max;
49ac3b45f6SPaolo Abeni 	__u8	mptcpi_add_addr_signal_max;
50ac3b45f6SPaolo Abeni 	__u8	mptcpi_add_addr_accepted_max;
51ac3b45f6SPaolo Abeni 	__u32	mptcpi_flags;
52ac3b45f6SPaolo Abeni 	__u32	mptcpi_token;
53ac3b45f6SPaolo Abeni 	__u64	mptcpi_write_seq;
54ac3b45f6SPaolo Abeni 	__u64	mptcpi_snd_una;
55ac3b45f6SPaolo Abeni 	__u64	mptcpi_rcv_nxt;
560caf3adaSGeliang Tang 	__u8	mptcpi_local_addr_used;
570caf3adaSGeliang Tang 	__u8	mptcpi_local_addr_max;
58752e9067SGeliang Tang 	__u8	mptcpi_csum_enabled;
5938967f42SPaolo Abeni 	__u32	mptcpi_retransmits;
6038967f42SPaolo Abeni 	__u64	mptcpi_bytes_retrans;
6138967f42SPaolo Abeni 	__u64	mptcpi_bytes_sent;
6238967f42SPaolo Abeni 	__u64	mptcpi_bytes_received;
6338967f42SPaolo Abeni 	__u64	mptcpi_bytes_acked;
64ac3b45f6SPaolo Abeni };
65ac3b45f6SPaolo Abeni 
66dc87efdbSFlorian Westphal /* MPTCP Reset reason codes, rfc8684 */
67dc87efdbSFlorian Westphal #define MPTCP_RST_EUNSPEC	0
68dc87efdbSFlorian Westphal #define MPTCP_RST_EMPTCP	1
69dc87efdbSFlorian Westphal #define MPTCP_RST_ERESOURCE	2
70dc87efdbSFlorian Westphal #define MPTCP_RST_EPROHIBIT	3
71dc87efdbSFlorian Westphal #define MPTCP_RST_EWQ2BIG	4
72dc87efdbSFlorian Westphal #define MPTCP_RST_EBADPERF	5
73dc87efdbSFlorian Westphal #define MPTCP_RST_EMIDDLEBOX	6
74dc87efdbSFlorian Westphal 
7506f15ceeSFlorian Westphal struct mptcp_subflow_data {
7606f15ceeSFlorian Westphal 	__u32		size_subflow_data;		/* size of this structure in userspace */
7706f15ceeSFlorian Westphal 	__u32		num_subflows;			/* must be 0, set by kernel */
7806f15ceeSFlorian Westphal 	__u32		size_kernel;			/* must be 0, set by kernel */
7906f15ceeSFlorian Westphal 	__u32		size_user;			/* size of one element in data[] */
8006f15ceeSFlorian Westphal } __attribute__((aligned(8)));
8106f15ceeSFlorian Westphal 
82c11c5906SFlorian Westphal struct mptcp_subflow_addrs {
83c11c5906SFlorian Westphal 	union {
84c11c5906SFlorian Westphal 		__kernel_sa_family_t sa_family;
85c11c5906SFlorian Westphal 		struct sockaddr sa_local;
86c11c5906SFlorian Westphal 		struct sockaddr_in sin_local;
87c11c5906SFlorian Westphal 		struct sockaddr_in6 sin6_local;
88c11c5906SFlorian Westphal 		struct __kernel_sockaddr_storage ss_local;
89c11c5906SFlorian Westphal 	};
90c11c5906SFlorian Westphal 	union {
91c11c5906SFlorian Westphal 		struct sockaddr sa_remote;
92c11c5906SFlorian Westphal 		struct sockaddr_in sin_remote;
93c11c5906SFlorian Westphal 		struct sockaddr_in6 sin6_remote;
94c11c5906SFlorian Westphal 		struct __kernel_sockaddr_storage ss_remote;
95c11c5906SFlorian Westphal 	};
96c11c5906SFlorian Westphal };
97c11c5906SFlorian Westphal 
9849243207SPaolo Abeni struct mptcp_subflow_info {
9949243207SPaolo Abeni 	__u32				id;
10049243207SPaolo Abeni 	struct mptcp_subflow_addrs	addrs;
10149243207SPaolo Abeni };
10249243207SPaolo Abeni 
10349243207SPaolo Abeni struct mptcp_full_info {
10449243207SPaolo Abeni 	__u32		size_tcpinfo_kernel;	/* must be 0, set by kernel */
10549243207SPaolo Abeni 	__u32		size_tcpinfo_user;
10649243207SPaolo Abeni 	__u32		size_sfinfo_kernel;	/* must be 0, set by kernel */
10749243207SPaolo Abeni 	__u32		size_sfinfo_user;
10849243207SPaolo Abeni 	__u32		num_subflows;		/* must be 0, set by kernel (real subflow count) */
10949243207SPaolo Abeni 	__u32		size_arrays_user;	/* max subflows that userspace is interested in;
11049243207SPaolo Abeni 						 * the buffers at subflow_info/tcp_info
11149243207SPaolo Abeni 						 * are respectively at least:
11249243207SPaolo Abeni 						 *  size_arrays * size_sfinfo_user
11349243207SPaolo Abeni 						 *  size_arrays * size_tcpinfo_user
11449243207SPaolo Abeni 						 * bytes wide
11549243207SPaolo Abeni 						 */
11649243207SPaolo Abeni 	__aligned_u64		subflow_info;
11749243207SPaolo Abeni 	__aligned_u64		tcp_info;
11849243207SPaolo Abeni 	struct mptcp_info	mptcp_info;
11949243207SPaolo Abeni };
12049243207SPaolo Abeni 
12155c42fa7SFlorian Westphal /* MPTCP socket options */
12255c42fa7SFlorian Westphal #define MPTCP_INFO		1
12306f15ceeSFlorian Westphal #define MPTCP_TCPINFO		2
124c11c5906SFlorian Westphal #define MPTCP_SUBFLOW_ADDRS	3
12549243207SPaolo Abeni #define MPTCP_FULL_INFO		4
12655c42fa7SFlorian Westphal 
1275147dfb5SDavide Caratti #endif /* _UAPI_MPTCP_H */
128