l2tp.h 5.6 KB

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