| 1 | /* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */ | 
|---|
| 2 | /* | 
|---|
| 3 | * L2TP-over-IP socket for L2TPv3. | 
|---|
| 4 | * | 
|---|
| 5 | * Author: James Chapman <jchapman@katalix.com> | 
|---|
| 6 | */ | 
|---|
| 7 |  | 
|---|
| 8 | #ifndef _UAPI_LINUX_L2TP_H_ | 
|---|
| 9 | #define _UAPI_LINUX_L2TP_H_ | 
|---|
| 10 |  | 
|---|
| 11 | #include <linux/types.h> | 
|---|
| 12 | #include <linux/socket.h> | 
|---|
| 13 | #include <linux/in.h> | 
|---|
| 14 | #include <linux/in6.h> | 
|---|
| 15 |  | 
|---|
| 16 | /** | 
|---|
| 17 | * struct sockaddr_l2tpip - the sockaddr structure for L2TP-over-IP sockets | 
|---|
| 18 | * @l2tp_family:  address family number AF_L2TPIP. | 
|---|
| 19 | * @l2tp_addr:    protocol specific address information | 
|---|
| 20 | * @l2tp_conn_id: connection id of tunnel | 
|---|
| 21 | */ | 
|---|
| 22 | #define __SOCK_SIZE__	16		/* sizeof(struct sockaddr)	*/ | 
|---|
| 23 | struct sockaddr_l2tpip { | 
|---|
| 24 | /* The first fields must match struct sockaddr_in */ | 
|---|
| 25 | __kernel_sa_family_t l2tp_family; /* AF_INET */ | 
|---|
| 26 | __be16		l2tp_unused;	/* INET port number (unused) */ | 
|---|
| 27 | struct in_addr	l2tp_addr;	/* Internet address */ | 
|---|
| 28 |  | 
|---|
| 29 | __u32		l2tp_conn_id;	/* Connection ID of tunnel */ | 
|---|
| 30 |  | 
|---|
| 31 | /* Pad to size of `struct sockaddr'. */ | 
|---|
| 32 | unsigned char	__pad[__SOCK_SIZE__ - | 
|---|
| 33 | sizeof(__kernel_sa_family_t) - | 
|---|
| 34 | sizeof(__be16) - sizeof(struct in_addr) - | 
|---|
| 35 | sizeof(__u32)]; | 
|---|
| 36 | }; | 
|---|
| 37 |  | 
|---|
| 38 | /** | 
|---|
| 39 | * struct sockaddr_l2tpip6 - the sockaddr structure for L2TP-over-IPv6 sockets | 
|---|
| 40 | * @l2tp_family:  address family number AF_L2TPIP. | 
|---|
| 41 | * @l2tp_addr:    protocol specific address information | 
|---|
| 42 | * @l2tp_conn_id: connection id of tunnel | 
|---|
| 43 | */ | 
|---|
| 44 | struct sockaddr_l2tpip6 { | 
|---|
| 45 | /* The first fields must match struct sockaddr_in6 */ | 
|---|
| 46 | __kernel_sa_family_t l2tp_family; /* AF_INET6 */ | 
|---|
| 47 | __be16		l2tp_unused;	/* INET port number (unused) */ | 
|---|
| 48 | __be32		l2tp_flowinfo;	/* IPv6 flow information */ | 
|---|
| 49 | struct in6_addr	l2tp_addr;	/* IPv6 address */ | 
|---|
| 50 | __u32		l2tp_scope_id;	/* scope id (new in RFC2553) */ | 
|---|
| 51 | __u32		l2tp_conn_id;	/* Connection ID of tunnel */ | 
|---|
| 52 | }; | 
|---|
| 53 |  | 
|---|
| 54 | /***************************************************************************** | 
|---|
| 55 | *  NETLINK_GENERIC netlink family. | 
|---|
| 56 | *****************************************************************************/ | 
|---|
| 57 |  | 
|---|
| 58 | /* | 
|---|
| 59 | * Commands. | 
|---|
| 60 | * Valid TLVs of each command are:- | 
|---|
| 61 | * TUNNEL_CREATE	- CONN_ID, pw_type, netns, ifname, ipinfo, udpinfo, udpcsum | 
|---|
| 62 | * TUNNEL_DELETE	- CONN_ID | 
|---|
| 63 | * TUNNEL_MODIFY	- CONN_ID, udpcsum | 
|---|
| 64 | * TUNNEL_GETSTATS	- CONN_ID, (stats) | 
|---|
| 65 | * TUNNEL_GET		- CONN_ID, (...) | 
|---|
| 66 | * SESSION_CREATE	- SESSION_ID, PW_TYPE, cookie, peer_cookie, l2spec | 
|---|
| 67 | * SESSION_DELETE	- SESSION_ID | 
|---|
| 68 | * SESSION_MODIFY	- SESSION_ID | 
|---|
| 69 | * SESSION_GET		- SESSION_ID, (...) | 
|---|
| 70 | * SESSION_GETSTATS	- SESSION_ID, (stats) | 
|---|
| 71 | * | 
|---|
| 72 | */ | 
|---|
| 73 | enum { | 
|---|
| 74 | L2TP_CMD_NOOP, | 
|---|
| 75 | L2TP_CMD_TUNNEL_CREATE, | 
|---|
| 76 | L2TP_CMD_TUNNEL_DELETE, | 
|---|
| 77 | L2TP_CMD_TUNNEL_MODIFY, | 
|---|
| 78 | L2TP_CMD_TUNNEL_GET, | 
|---|
| 79 | L2TP_CMD_SESSION_CREATE, | 
|---|
| 80 | L2TP_CMD_SESSION_DELETE, | 
|---|
| 81 | L2TP_CMD_SESSION_MODIFY, | 
|---|
| 82 | L2TP_CMD_SESSION_GET, | 
|---|
| 83 | __L2TP_CMD_MAX, | 
|---|
| 84 | }; | 
|---|
| 85 |  | 
|---|
| 86 | #define L2TP_CMD_MAX			(__L2TP_CMD_MAX - 1) | 
|---|
| 87 |  | 
|---|
| 88 | /* | 
|---|
| 89 | * ATTR types defined for L2TP | 
|---|
| 90 | */ | 
|---|
| 91 | enum { | 
|---|
| 92 | L2TP_ATTR_NONE,			/* no data */ | 
|---|
| 93 | L2TP_ATTR_PW_TYPE,		/* u16, enum l2tp_pwtype */ | 
|---|
| 94 | L2TP_ATTR_ENCAP_TYPE,		/* u16, enum l2tp_encap_type */ | 
|---|
| 95 | L2TP_ATTR_OFFSET,		/* u16 (not used) */ | 
|---|
| 96 | L2TP_ATTR_DATA_SEQ,		/* u16 (not used) */ | 
|---|
| 97 | L2TP_ATTR_L2SPEC_TYPE,		/* u8, enum l2tp_l2spec_type */ | 
|---|
| 98 | L2TP_ATTR_L2SPEC_LEN,		/* u8 (not used) */ | 
|---|
| 99 | L2TP_ATTR_PROTO_VERSION,	/* u8 */ | 
|---|
| 100 | L2TP_ATTR_IFNAME,		/* string */ | 
|---|
| 101 | L2TP_ATTR_CONN_ID,		/* u32 */ | 
|---|
| 102 | L2TP_ATTR_PEER_CONN_ID,		/* u32 */ | 
|---|
| 103 | L2TP_ATTR_SESSION_ID,		/* u32 */ | 
|---|
| 104 | L2TP_ATTR_PEER_SESSION_ID,	/* u32 */ | 
|---|
| 105 | L2TP_ATTR_UDP_CSUM,		/* u8 */ | 
|---|
| 106 | L2TP_ATTR_VLAN_ID,		/* u16 (not used) */ | 
|---|
| 107 | L2TP_ATTR_COOKIE,		/* 0, 4 or 8 bytes */ | 
|---|
| 108 | L2TP_ATTR_PEER_COOKIE,		/* 0, 4 or 8 bytes */ | 
|---|
| 109 | L2TP_ATTR_DEBUG,		/* u32, enum l2tp_debug_flags (not used) */ | 
|---|
| 110 | L2TP_ATTR_RECV_SEQ,		/* u8 */ | 
|---|
| 111 | L2TP_ATTR_SEND_SEQ,		/* u8 */ | 
|---|
| 112 | L2TP_ATTR_LNS_MODE,		/* u8 */ | 
|---|
| 113 | L2TP_ATTR_USING_IPSEC,		/* u8 */ | 
|---|
| 114 | L2TP_ATTR_RECV_TIMEOUT,		/* msec */ | 
|---|
| 115 | L2TP_ATTR_FD,			/* int */ | 
|---|
| 116 | L2TP_ATTR_IP_SADDR,		/* u32 */ | 
|---|
| 117 | L2TP_ATTR_IP_DADDR,		/* u32 */ | 
|---|
| 118 | L2TP_ATTR_UDP_SPORT,		/* u16 */ | 
|---|
| 119 | L2TP_ATTR_UDP_DPORT,		/* u16 */ | 
|---|
| 120 | L2TP_ATTR_MTU,			/* u16 (not used) */ | 
|---|
| 121 | L2TP_ATTR_MRU,			/* u16 (not used) */ | 
|---|
| 122 | L2TP_ATTR_STATS,		/* nested */ | 
|---|
| 123 | L2TP_ATTR_IP6_SADDR,		/* struct in6_addr */ | 
|---|
| 124 | L2TP_ATTR_IP6_DADDR,		/* struct in6_addr */ | 
|---|
| 125 | L2TP_ATTR_UDP_ZERO_CSUM6_TX,	/* flag */ | 
|---|
| 126 | L2TP_ATTR_UDP_ZERO_CSUM6_RX,	/* flag */ | 
|---|
| 127 | L2TP_ATTR_PAD, | 
|---|
| 128 | __L2TP_ATTR_MAX, | 
|---|
| 129 | }; | 
|---|
| 130 |  | 
|---|
| 131 | #define L2TP_ATTR_MAX			(__L2TP_ATTR_MAX - 1) | 
|---|
| 132 |  | 
|---|
| 133 | /* Nested in L2TP_ATTR_STATS */ | 
|---|
| 134 | enum { | 
|---|
| 135 | L2TP_ATTR_STATS_NONE,		/* no data */ | 
|---|
| 136 | L2TP_ATTR_TX_PACKETS,		/* u64 */ | 
|---|
| 137 | L2TP_ATTR_TX_BYTES,		/* u64 */ | 
|---|
| 138 | L2TP_ATTR_TX_ERRORS,		/* u64 */ | 
|---|
| 139 | L2TP_ATTR_RX_PACKETS,		/* u64 */ | 
|---|
| 140 | L2TP_ATTR_RX_BYTES,		/* u64 */ | 
|---|
| 141 | L2TP_ATTR_RX_SEQ_DISCARDS,	/* u64 */ | 
|---|
| 142 | L2TP_ATTR_RX_OOS_PACKETS,	/* u64 */ | 
|---|
| 143 | L2TP_ATTR_RX_ERRORS,		/* u64 */ | 
|---|
| 144 | L2TP_ATTR_STATS_PAD, | 
|---|
| 145 | L2TP_ATTR_RX_COOKIE_DISCARDS,	/* u64 */ | 
|---|
| 146 | L2TP_ATTR_RX_INVALID,		/* u64 */ | 
|---|
| 147 | __L2TP_ATTR_STATS_MAX, | 
|---|
| 148 | }; | 
|---|
| 149 |  | 
|---|
| 150 | #define L2TP_ATTR_STATS_MAX		(__L2TP_ATTR_STATS_MAX - 1) | 
|---|
| 151 |  | 
|---|
| 152 | enum l2tp_pwtype { | 
|---|
| 153 | L2TP_PWTYPE_NONE = 0x0000, | 
|---|
| 154 | L2TP_PWTYPE_ETH_VLAN = 0x0004, | 
|---|
| 155 | L2TP_PWTYPE_ETH = 0x0005, | 
|---|
| 156 | L2TP_PWTYPE_PPP = 0x0007, | 
|---|
| 157 | L2TP_PWTYPE_PPP_AC = 0x0008, | 
|---|
| 158 | L2TP_PWTYPE_IP = 0x000b, | 
|---|
| 159 | __L2TP_PWTYPE_MAX | 
|---|
| 160 | }; | 
|---|
| 161 |  | 
|---|
| 162 | enum l2tp_l2spec_type { | 
|---|
| 163 | L2TP_L2SPECTYPE_NONE, | 
|---|
| 164 | L2TP_L2SPECTYPE_DEFAULT, | 
|---|
| 165 | }; | 
|---|
| 166 |  | 
|---|
| 167 | enum l2tp_encap_type { | 
|---|
| 168 | L2TP_ENCAPTYPE_UDP, | 
|---|
| 169 | L2TP_ENCAPTYPE_IP, | 
|---|
| 170 | }; | 
|---|
| 171 |  | 
|---|
| 172 | /* For L2TP_ATTR_DATA_SEQ. Unused. */ | 
|---|
| 173 | enum l2tp_seqmode { | 
|---|
| 174 | L2TP_SEQ_NONE = 0, | 
|---|
| 175 | L2TP_SEQ_IP = 1, | 
|---|
| 176 | L2TP_SEQ_ALL = 2, | 
|---|
| 177 | }; | 
|---|
| 178 |  | 
|---|
| 179 | /** | 
|---|
| 180 | * enum l2tp_debug_flags - debug message categories for L2TP tunnels/sessions. | 
|---|
| 181 | * | 
|---|
| 182 | * Unused. | 
|---|
| 183 | * | 
|---|
| 184 | * @L2TP_MSG_DEBUG: verbose debug (if compiled in) | 
|---|
| 185 | * @L2TP_MSG_CONTROL: userspace - kernel interface | 
|---|
| 186 | * @L2TP_MSG_SEQ: sequence numbers | 
|---|
| 187 | * @L2TP_MSG_DATA: data packets | 
|---|
| 188 | */ | 
|---|
| 189 | enum l2tp_debug_flags { | 
|---|
| 190 | L2TP_MSG_DEBUG		= (1 << 0), | 
|---|
| 191 | L2TP_MSG_CONTROL	= (1 << 1), | 
|---|
| 192 | L2TP_MSG_SEQ		= (1 << 2), | 
|---|
| 193 | L2TP_MSG_DATA		= (1 << 3), | 
|---|
| 194 | }; | 
|---|
| 195 |  | 
|---|
| 196 | /* | 
|---|
| 197 | * NETLINK_GENERIC related info | 
|---|
| 198 | */ | 
|---|
| 199 | #define L2TP_GENL_NAME		"l2tp" | 
|---|
| 200 | #define L2TP_GENL_VERSION	0x1 | 
|---|
| 201 | #define L2TP_GENL_MCGROUP       "l2tp" | 
|---|
| 202 |  | 
|---|
| 203 | #endif /* _UAPI_LINUX_L2TP_H_ */ | 
|---|
| 204 |  | 
|---|