xref: /OK3568_Linux_fs/kernel/include/uapi/linux/in6.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0+ WITH Linux-syscall-note */
2*4882a593Smuzhiyun /*
3*4882a593Smuzhiyun  *	Types and definitions for AF_INET6
4*4882a593Smuzhiyun  *	Linux INET6 implementation
5*4882a593Smuzhiyun  *
6*4882a593Smuzhiyun  *	Authors:
7*4882a593Smuzhiyun  *	Pedro Roque		<roque@di.fc.ul.pt>
8*4882a593Smuzhiyun  *
9*4882a593Smuzhiyun  *	Sources:
10*4882a593Smuzhiyun  *	IPv6 Program Interfaces for BSD Systems
11*4882a593Smuzhiyun  *      <draft-ietf-ipngwg-bsd-api-05.txt>
12*4882a593Smuzhiyun  *
13*4882a593Smuzhiyun  *	Advanced Sockets API for IPv6
14*4882a593Smuzhiyun  *	<draft-stevens-advanced-api-00.txt>
15*4882a593Smuzhiyun  *
16*4882a593Smuzhiyun  *	This program is free software; you can redistribute it and/or
17*4882a593Smuzhiyun  *      modify it under the terms of the GNU General Public License
18*4882a593Smuzhiyun  *      as published by the Free Software Foundation; either version
19*4882a593Smuzhiyun  *      2 of the License, or (at your option) any later version.
20*4882a593Smuzhiyun  */
21*4882a593Smuzhiyun 
22*4882a593Smuzhiyun #ifndef _UAPI_LINUX_IN6_H
23*4882a593Smuzhiyun #define _UAPI_LINUX_IN6_H
24*4882a593Smuzhiyun 
25*4882a593Smuzhiyun #include <linux/types.h>
26*4882a593Smuzhiyun #include <linux/libc-compat.h>
27*4882a593Smuzhiyun 
28*4882a593Smuzhiyun /*
29*4882a593Smuzhiyun  *	IPv6 address structure
30*4882a593Smuzhiyun  */
31*4882a593Smuzhiyun 
32*4882a593Smuzhiyun #if __UAPI_DEF_IN6_ADDR
33*4882a593Smuzhiyun struct in6_addr {
34*4882a593Smuzhiyun 	union {
35*4882a593Smuzhiyun 		__u8		u6_addr8[16];
36*4882a593Smuzhiyun #if __UAPI_DEF_IN6_ADDR_ALT
37*4882a593Smuzhiyun 		__be16		u6_addr16[8];
38*4882a593Smuzhiyun 		__be32		u6_addr32[4];
39*4882a593Smuzhiyun #endif
40*4882a593Smuzhiyun 	} in6_u;
41*4882a593Smuzhiyun #define s6_addr			in6_u.u6_addr8
42*4882a593Smuzhiyun #if __UAPI_DEF_IN6_ADDR_ALT
43*4882a593Smuzhiyun #define s6_addr16		in6_u.u6_addr16
44*4882a593Smuzhiyun #define s6_addr32		in6_u.u6_addr32
45*4882a593Smuzhiyun #endif
46*4882a593Smuzhiyun };
47*4882a593Smuzhiyun #endif /* __UAPI_DEF_IN6_ADDR */
48*4882a593Smuzhiyun 
49*4882a593Smuzhiyun #if __UAPI_DEF_SOCKADDR_IN6
50*4882a593Smuzhiyun struct sockaddr_in6 {
51*4882a593Smuzhiyun 	unsigned short int	sin6_family;    /* AF_INET6 */
52*4882a593Smuzhiyun 	__be16			sin6_port;      /* Transport layer port # */
53*4882a593Smuzhiyun 	__be32			sin6_flowinfo;  /* IPv6 flow information */
54*4882a593Smuzhiyun 	struct in6_addr		sin6_addr;      /* IPv6 address */
55*4882a593Smuzhiyun 	__u32			sin6_scope_id;  /* scope id (new in RFC2553) */
56*4882a593Smuzhiyun };
57*4882a593Smuzhiyun #endif /* __UAPI_DEF_SOCKADDR_IN6 */
58*4882a593Smuzhiyun 
59*4882a593Smuzhiyun #if __UAPI_DEF_IPV6_MREQ
60*4882a593Smuzhiyun struct ipv6_mreq {
61*4882a593Smuzhiyun 	/* IPv6 multicast address of group */
62*4882a593Smuzhiyun 	struct in6_addr ipv6mr_multiaddr;
63*4882a593Smuzhiyun 
64*4882a593Smuzhiyun 	/* local IPv6 address of interface */
65*4882a593Smuzhiyun 	int		ipv6mr_ifindex;
66*4882a593Smuzhiyun };
67*4882a593Smuzhiyun #endif /* __UAPI_DEF_IVP6_MREQ */
68*4882a593Smuzhiyun 
69*4882a593Smuzhiyun #define ipv6mr_acaddr	ipv6mr_multiaddr
70*4882a593Smuzhiyun 
71*4882a593Smuzhiyun struct in6_flowlabel_req {
72*4882a593Smuzhiyun 	struct in6_addr	flr_dst;
73*4882a593Smuzhiyun 	__be32	flr_label;
74*4882a593Smuzhiyun 	__u8	flr_action;
75*4882a593Smuzhiyun 	__u8	flr_share;
76*4882a593Smuzhiyun 	__u16	flr_flags;
77*4882a593Smuzhiyun 	__u16 	flr_expires;
78*4882a593Smuzhiyun 	__u16	flr_linger;
79*4882a593Smuzhiyun 	__u32	__flr_pad;
80*4882a593Smuzhiyun 	/* Options in format of IPV6_PKTOPTIONS */
81*4882a593Smuzhiyun };
82*4882a593Smuzhiyun 
83*4882a593Smuzhiyun #define IPV6_FL_A_GET	0
84*4882a593Smuzhiyun #define IPV6_FL_A_PUT	1
85*4882a593Smuzhiyun #define IPV6_FL_A_RENEW	2
86*4882a593Smuzhiyun 
87*4882a593Smuzhiyun #define IPV6_FL_F_CREATE	1
88*4882a593Smuzhiyun #define IPV6_FL_F_EXCL		2
89*4882a593Smuzhiyun #define IPV6_FL_F_REFLECT	4
90*4882a593Smuzhiyun #define IPV6_FL_F_REMOTE	8
91*4882a593Smuzhiyun 
92*4882a593Smuzhiyun #define IPV6_FL_S_NONE		0
93*4882a593Smuzhiyun #define IPV6_FL_S_EXCL		1
94*4882a593Smuzhiyun #define IPV6_FL_S_PROCESS	2
95*4882a593Smuzhiyun #define IPV6_FL_S_USER		3
96*4882a593Smuzhiyun #define IPV6_FL_S_ANY		255
97*4882a593Smuzhiyun 
98*4882a593Smuzhiyun 
99*4882a593Smuzhiyun /*
100*4882a593Smuzhiyun  *	Bitmask constant declarations to help applications select out the
101*4882a593Smuzhiyun  *	flow label and priority fields.
102*4882a593Smuzhiyun  *
103*4882a593Smuzhiyun  *	Note that this are in host byte order while the flowinfo field of
104*4882a593Smuzhiyun  *	sockaddr_in6 is in network byte order.
105*4882a593Smuzhiyun  */
106*4882a593Smuzhiyun 
107*4882a593Smuzhiyun #define IPV6_FLOWINFO_FLOWLABEL		0x000fffff
108*4882a593Smuzhiyun #define IPV6_FLOWINFO_PRIORITY		0x0ff00000
109*4882a593Smuzhiyun 
110*4882a593Smuzhiyun /* These definitions are obsolete */
111*4882a593Smuzhiyun #define IPV6_PRIORITY_UNCHARACTERIZED	0x0000
112*4882a593Smuzhiyun #define IPV6_PRIORITY_FILLER		0x0100
113*4882a593Smuzhiyun #define IPV6_PRIORITY_UNATTENDED	0x0200
114*4882a593Smuzhiyun #define IPV6_PRIORITY_RESERVED1		0x0300
115*4882a593Smuzhiyun #define IPV6_PRIORITY_BULK		0x0400
116*4882a593Smuzhiyun #define IPV6_PRIORITY_RESERVED2		0x0500
117*4882a593Smuzhiyun #define IPV6_PRIORITY_INTERACTIVE	0x0600
118*4882a593Smuzhiyun #define IPV6_PRIORITY_CONTROL		0x0700
119*4882a593Smuzhiyun #define IPV6_PRIORITY_8			0x0800
120*4882a593Smuzhiyun #define IPV6_PRIORITY_9			0x0900
121*4882a593Smuzhiyun #define IPV6_PRIORITY_10		0x0a00
122*4882a593Smuzhiyun #define IPV6_PRIORITY_11		0x0b00
123*4882a593Smuzhiyun #define IPV6_PRIORITY_12		0x0c00
124*4882a593Smuzhiyun #define IPV6_PRIORITY_13		0x0d00
125*4882a593Smuzhiyun #define IPV6_PRIORITY_14		0x0e00
126*4882a593Smuzhiyun #define IPV6_PRIORITY_15		0x0f00
127*4882a593Smuzhiyun 
128*4882a593Smuzhiyun /*
129*4882a593Smuzhiyun  *	IPV6 extension headers
130*4882a593Smuzhiyun  */
131*4882a593Smuzhiyun #if __UAPI_DEF_IPPROTO_V6
132*4882a593Smuzhiyun #define IPPROTO_HOPOPTS		0	/* IPv6 hop-by-hop options	*/
133*4882a593Smuzhiyun #define IPPROTO_ROUTING		43	/* IPv6 routing header		*/
134*4882a593Smuzhiyun #define IPPROTO_FRAGMENT	44	/* IPv6 fragmentation header	*/
135*4882a593Smuzhiyun #define IPPROTO_ICMPV6		58	/* ICMPv6			*/
136*4882a593Smuzhiyun #define IPPROTO_NONE		59	/* IPv6 no next header		*/
137*4882a593Smuzhiyun #define IPPROTO_DSTOPTS		60	/* IPv6 destination options	*/
138*4882a593Smuzhiyun #define IPPROTO_MH		135	/* IPv6 mobility header		*/
139*4882a593Smuzhiyun #endif /* __UAPI_DEF_IPPROTO_V6 */
140*4882a593Smuzhiyun 
141*4882a593Smuzhiyun /*
142*4882a593Smuzhiyun  *	IPv6 TLV options.
143*4882a593Smuzhiyun  */
144*4882a593Smuzhiyun #define IPV6_TLV_PAD1		0
145*4882a593Smuzhiyun #define IPV6_TLV_PADN		1
146*4882a593Smuzhiyun #define IPV6_TLV_ROUTERALERT	5
147*4882a593Smuzhiyun #define IPV6_TLV_CALIPSO	7	/* RFC 5570 */
148*4882a593Smuzhiyun #define IPV6_TLV_JUMBO		194
149*4882a593Smuzhiyun #define IPV6_TLV_HAO		201	/* home address option */
150*4882a593Smuzhiyun 
151*4882a593Smuzhiyun /*
152*4882a593Smuzhiyun  *	IPV6 socket options
153*4882a593Smuzhiyun  */
154*4882a593Smuzhiyun #if __UAPI_DEF_IPV6_OPTIONS
155*4882a593Smuzhiyun #define IPV6_ADDRFORM		1
156*4882a593Smuzhiyun #define IPV6_2292PKTINFO	2
157*4882a593Smuzhiyun #define IPV6_2292HOPOPTS	3
158*4882a593Smuzhiyun #define IPV6_2292DSTOPTS	4
159*4882a593Smuzhiyun #define IPV6_2292RTHDR		5
160*4882a593Smuzhiyun #define IPV6_2292PKTOPTIONS	6
161*4882a593Smuzhiyun #define IPV6_CHECKSUM		7
162*4882a593Smuzhiyun #define IPV6_2292HOPLIMIT	8
163*4882a593Smuzhiyun #define IPV6_NEXTHOP		9
164*4882a593Smuzhiyun #define IPV6_AUTHHDR		10	/* obsolete */
165*4882a593Smuzhiyun #define IPV6_FLOWINFO		11
166*4882a593Smuzhiyun 
167*4882a593Smuzhiyun #define IPV6_UNICAST_HOPS	16
168*4882a593Smuzhiyun #define IPV6_MULTICAST_IF	17
169*4882a593Smuzhiyun #define IPV6_MULTICAST_HOPS	18
170*4882a593Smuzhiyun #define IPV6_MULTICAST_LOOP	19
171*4882a593Smuzhiyun #define IPV6_ADD_MEMBERSHIP	20
172*4882a593Smuzhiyun #define IPV6_DROP_MEMBERSHIP	21
173*4882a593Smuzhiyun #define IPV6_ROUTER_ALERT	22
174*4882a593Smuzhiyun #define IPV6_MTU_DISCOVER	23
175*4882a593Smuzhiyun #define IPV6_MTU		24
176*4882a593Smuzhiyun #define IPV6_RECVERR		25
177*4882a593Smuzhiyun #define IPV6_V6ONLY		26
178*4882a593Smuzhiyun #define IPV6_JOIN_ANYCAST	27
179*4882a593Smuzhiyun #define IPV6_LEAVE_ANYCAST	28
180*4882a593Smuzhiyun #define IPV6_MULTICAST_ALL	29
181*4882a593Smuzhiyun #define IPV6_ROUTER_ALERT_ISOLATE	30
182*4882a593Smuzhiyun #define IPV6_RECVERR_RFC4884	31
183*4882a593Smuzhiyun 
184*4882a593Smuzhiyun /* IPV6_MTU_DISCOVER values */
185*4882a593Smuzhiyun #define IPV6_PMTUDISC_DONT		0
186*4882a593Smuzhiyun #define IPV6_PMTUDISC_WANT		1
187*4882a593Smuzhiyun #define IPV6_PMTUDISC_DO		2
188*4882a593Smuzhiyun #define IPV6_PMTUDISC_PROBE		3
189*4882a593Smuzhiyun /* same as IPV6_PMTUDISC_PROBE, provided for symetry with IPv4
190*4882a593Smuzhiyun  * also see comments on IP_PMTUDISC_INTERFACE
191*4882a593Smuzhiyun  */
192*4882a593Smuzhiyun #define IPV6_PMTUDISC_INTERFACE		4
193*4882a593Smuzhiyun /* weaker version of IPV6_PMTUDISC_INTERFACE, which allows packets to
194*4882a593Smuzhiyun  * get fragmented if they exceed the interface mtu
195*4882a593Smuzhiyun  */
196*4882a593Smuzhiyun #define IPV6_PMTUDISC_OMIT		5
197*4882a593Smuzhiyun 
198*4882a593Smuzhiyun /* Flowlabel */
199*4882a593Smuzhiyun #define IPV6_FLOWLABEL_MGR	32
200*4882a593Smuzhiyun #define IPV6_FLOWINFO_SEND	33
201*4882a593Smuzhiyun 
202*4882a593Smuzhiyun #define IPV6_IPSEC_POLICY	34
203*4882a593Smuzhiyun #define IPV6_XFRM_POLICY	35
204*4882a593Smuzhiyun #define IPV6_HDRINCL		36
205*4882a593Smuzhiyun #endif
206*4882a593Smuzhiyun 
207*4882a593Smuzhiyun /*
208*4882a593Smuzhiyun  * Multicast:
209*4882a593Smuzhiyun  * Following socket options are shared between IPv4 and IPv6.
210*4882a593Smuzhiyun  *
211*4882a593Smuzhiyun  * MCAST_JOIN_GROUP		42
212*4882a593Smuzhiyun  * MCAST_BLOCK_SOURCE		43
213*4882a593Smuzhiyun  * MCAST_UNBLOCK_SOURCE		44
214*4882a593Smuzhiyun  * MCAST_LEAVE_GROUP		45
215*4882a593Smuzhiyun  * MCAST_JOIN_SOURCE_GROUP	46
216*4882a593Smuzhiyun  * MCAST_LEAVE_SOURCE_GROUP	47
217*4882a593Smuzhiyun  * MCAST_MSFILTER		48
218*4882a593Smuzhiyun  */
219*4882a593Smuzhiyun 
220*4882a593Smuzhiyun /*
221*4882a593Smuzhiyun  * Advanced API (RFC3542) (1)
222*4882a593Smuzhiyun  *
223*4882a593Smuzhiyun  * Note: IPV6_RECVRTHDRDSTOPTS does not exist. see net/ipv6/datagram.c.
224*4882a593Smuzhiyun  */
225*4882a593Smuzhiyun 
226*4882a593Smuzhiyun #define IPV6_RECVPKTINFO	49
227*4882a593Smuzhiyun #define IPV6_PKTINFO		50
228*4882a593Smuzhiyun #define IPV6_RECVHOPLIMIT	51
229*4882a593Smuzhiyun #define IPV6_HOPLIMIT		52
230*4882a593Smuzhiyun #define IPV6_RECVHOPOPTS	53
231*4882a593Smuzhiyun #define IPV6_HOPOPTS		54
232*4882a593Smuzhiyun #define IPV6_RTHDRDSTOPTS	55
233*4882a593Smuzhiyun #define IPV6_RECVRTHDR		56
234*4882a593Smuzhiyun #define IPV6_RTHDR		57
235*4882a593Smuzhiyun #define IPV6_RECVDSTOPTS	58
236*4882a593Smuzhiyun #define IPV6_DSTOPTS		59
237*4882a593Smuzhiyun #define IPV6_RECVPATHMTU	60
238*4882a593Smuzhiyun #define IPV6_PATHMTU		61
239*4882a593Smuzhiyun #define IPV6_DONTFRAG		62
240*4882a593Smuzhiyun #if 0	/* not yet */
241*4882a593Smuzhiyun #define IPV6_USE_MIN_MTU	63
242*4882a593Smuzhiyun #endif
243*4882a593Smuzhiyun 
244*4882a593Smuzhiyun /*
245*4882a593Smuzhiyun  * Netfilter (1)
246*4882a593Smuzhiyun  *
247*4882a593Smuzhiyun  * Following socket options are used in ip6_tables;
248*4882a593Smuzhiyun  * see include/linux/netfilter_ipv6/ip6_tables.h.
249*4882a593Smuzhiyun  *
250*4882a593Smuzhiyun  * IP6T_SO_SET_REPLACE / IP6T_SO_GET_INFO		64
251*4882a593Smuzhiyun  * IP6T_SO_SET_ADD_COUNTERS / IP6T_SO_GET_ENTRIES	65
252*4882a593Smuzhiyun  */
253*4882a593Smuzhiyun 
254*4882a593Smuzhiyun /*
255*4882a593Smuzhiyun  * Advanced API (RFC3542) (2)
256*4882a593Smuzhiyun  */
257*4882a593Smuzhiyun #define IPV6_RECVTCLASS		66
258*4882a593Smuzhiyun #define IPV6_TCLASS		67
259*4882a593Smuzhiyun 
260*4882a593Smuzhiyun /*
261*4882a593Smuzhiyun  * Netfilter (2)
262*4882a593Smuzhiyun  *
263*4882a593Smuzhiyun  * Following socket options are used in ip6_tables;
264*4882a593Smuzhiyun  * see include/linux/netfilter_ipv6/ip6_tables.h.
265*4882a593Smuzhiyun  *
266*4882a593Smuzhiyun  * IP6T_SO_GET_REVISION_MATCH	68
267*4882a593Smuzhiyun  * IP6T_SO_GET_REVISION_TARGET	69
268*4882a593Smuzhiyun  * IP6T_SO_ORIGINAL_DST		80
269*4882a593Smuzhiyun  */
270*4882a593Smuzhiyun 
271*4882a593Smuzhiyun #define IPV6_AUTOFLOWLABEL	70
272*4882a593Smuzhiyun /* RFC5014: Source address selection */
273*4882a593Smuzhiyun #define IPV6_ADDR_PREFERENCES	72
274*4882a593Smuzhiyun 
275*4882a593Smuzhiyun #define IPV6_PREFER_SRC_TMP		0x0001
276*4882a593Smuzhiyun #define IPV6_PREFER_SRC_PUBLIC		0x0002
277*4882a593Smuzhiyun #define IPV6_PREFER_SRC_PUBTMP_DEFAULT	0x0100
278*4882a593Smuzhiyun #define IPV6_PREFER_SRC_COA		0x0004
279*4882a593Smuzhiyun #define IPV6_PREFER_SRC_HOME		0x0400
280*4882a593Smuzhiyun #define IPV6_PREFER_SRC_CGA		0x0008
281*4882a593Smuzhiyun #define IPV6_PREFER_SRC_NONCGA		0x0800
282*4882a593Smuzhiyun 
283*4882a593Smuzhiyun /* RFC5082: Generalized Ttl Security Mechanism */
284*4882a593Smuzhiyun #define IPV6_MINHOPCOUNT		73
285*4882a593Smuzhiyun 
286*4882a593Smuzhiyun #define IPV6_ORIGDSTADDR        74
287*4882a593Smuzhiyun #define IPV6_RECVORIGDSTADDR    IPV6_ORIGDSTADDR
288*4882a593Smuzhiyun #define IPV6_TRANSPARENT        75
289*4882a593Smuzhiyun #define IPV6_UNICAST_IF         76
290*4882a593Smuzhiyun #define IPV6_RECVFRAGSIZE	77
291*4882a593Smuzhiyun #define IPV6_FREEBIND		78
292*4882a593Smuzhiyun 
293*4882a593Smuzhiyun /*
294*4882a593Smuzhiyun  * Multicast Routing:
295*4882a593Smuzhiyun  * see include/uapi/linux/mroute6.h.
296*4882a593Smuzhiyun  *
297*4882a593Smuzhiyun  * MRT6_BASE			200
298*4882a593Smuzhiyun  * ...
299*4882a593Smuzhiyun  * MRT6_MAX
300*4882a593Smuzhiyun  */
301*4882a593Smuzhiyun #endif /* _UAPI_LINUX_IN6_H */
302