1/* Copyright (C) 1991-2022 Free Software Foundation, Inc.
2 This file is part of the GNU C Library.
3
4 The GNU C Library is free software; you can redistribute it and/or
5 modify it under the terms of the GNU Lesser General Public
6 License as published by the Free Software Foundation; either
7 version 2.1 of the License, or (at your option) any later version.
8
9 The GNU C Library is distributed in the hope that it will be useful,
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 Lesser General Public License for more details.
13
14 You should have received a copy of the GNU Lesser General Public
15 License along with the GNU C Library; if not, see
16 <https://www.gnu.org/licenses/>. */
17
18/* Linux version. */
19
20#ifndef _NETINET_IN_H
21# error "Never use <bits/in.h> directly; include <netinet/in.h> instead."
22#endif
23
24/* If the application has already included linux/in6.h from a linux-based
25 kernel then we will not define the IPv6 IPPROTO_* defines, in6_addr (nor the
26 defines), sockaddr_in6, or ipv6_mreq. Same for in6_ptkinfo or ip6_mtuinfo
27 in linux/ipv6.h. The ABI used by the linux-kernel and glibc match exactly.
28 Neither the linux kernel nor glibc should break this ABI without coordination.
29 In upstream kernel 56c176c9 the _UAPI prefix was stripped so we need to check
30 for _LINUX_IN6_H and _IPV6_H now, and keep checking the old versions for
31 maximum backwards compatibility. */
32#if defined _UAPI_LINUX_IN6_H \
33 || defined _UAPI_IPV6_H \
34 || defined _LINUX_IN6_H \
35 || defined _IPV6_H
36/* This is not quite the same API since the kernel always defines s6_addr16 and
37 s6_addr32. This is not a violation of POSIX since POSIX says "at least the
38 following member" and that holds true. */
39# define __USE_KERNEL_IPV6_DEFS 1
40#else
41# define __USE_KERNEL_IPV6_DEFS 0
42#endif
43
44/* Options for use with `getsockopt' and `setsockopt' at the IP level.
45 The first word in the comment at the right is the data type used;
46 "bool" means a boolean value stored in an `int'. */
47#define IP_OPTIONS 4 /* ip_opts; IP per-packet options. */
48#define IP_HDRINCL 3 /* int; Header is included with data. */
49#define IP_TOS 1 /* int; IP type of service and precedence. */
50#define IP_TTL 2 /* int; IP time to live. */
51#define IP_RECVOPTS 6 /* bool; Receive all IP options w/datagram. */
52/* For BSD compatibility. */
53#define IP_RECVRETOPTS IP_RETOPTS /* bool; Receive IP options for response. */
54#define IP_RETOPTS 7 /* ip_opts; Set/get IP per-packet options. */
55#define IP_MULTICAST_IF 32 /* in_addr; set/get IP multicast i/f */
56#define IP_MULTICAST_TTL 33 /* unsigned char; set/get IP multicast ttl */
57#define IP_MULTICAST_LOOP 34 /* bool; set/get IP multicast loopback */
58#define IP_ADD_MEMBERSHIP 35 /* ip_mreq; add an IP group membership */
59#define IP_DROP_MEMBERSHIP 36 /* ip_mreq; drop an IP group membership */
60#define IP_UNBLOCK_SOURCE 37 /* ip_mreq_source: unblock data from source */
61#define IP_BLOCK_SOURCE 38 /* ip_mreq_source: block data from source */
62#define IP_ADD_SOURCE_MEMBERSHIP 39 /* ip_mreq_source: join source group */
63#define IP_DROP_SOURCE_MEMBERSHIP 40 /* ip_mreq_source: leave source group */
64#define IP_MSFILTER 41
65#ifdef __USE_MISC
66# define MCAST_JOIN_GROUP 42 /* group_req: join any-source group */
67# define MCAST_BLOCK_SOURCE 43 /* group_source_req: block from given group */
68# define MCAST_UNBLOCK_SOURCE 44 /* group_source_req: unblock from given group*/
69# define MCAST_LEAVE_GROUP 45 /* group_req: leave any-source group */
70# define MCAST_JOIN_SOURCE_GROUP 46 /* group_source_req: join source-spec gr */
71# define MCAST_LEAVE_SOURCE_GROUP 47 /* group_source_req: leave source-spec gr*/
72# define MCAST_MSFILTER 48
73# define IP_MULTICAST_ALL 49
74# define IP_UNICAST_IF 50
75
76# define MCAST_EXCLUDE 0
77# define MCAST_INCLUDE 1
78#endif
79
80#define IP_ROUTER_ALERT 5 /* bool */
81#define IP_PKTINFO 8 /* bool */
82#define IP_PKTOPTIONS 9
83#define IP_PMTUDISC 10 /* obsolete name? */
84#define IP_MTU_DISCOVER 10 /* int; see below */
85#define IP_RECVERR 11 /* bool */
86#define IP_RECVTTL 12 /* bool */
87#define IP_RECVTOS 13 /* bool */
88#define IP_MTU 14 /* int */
89#define IP_FREEBIND 15
90#define IP_IPSEC_POLICY 16
91#define IP_XFRM_POLICY 17
92#define IP_PASSSEC 18
93#define IP_TRANSPARENT 19
94#define IP_MULTICAST_ALL 49 /* bool */
95
96/* TProxy original addresses */
97#define IP_ORIGDSTADDR 20
98#define IP_RECVORIGDSTADDR IP_ORIGDSTADDR
99
100#define IP_MINTTL 21
101#define IP_NODEFRAG 22
102#define IP_CHECKSUM 23
103#define IP_BIND_ADDRESS_NO_PORT 24
104#define IP_RECVFRAGSIZE 25
105#define IP_RECVERR_RFC4884 26
106
107/* IP_MTU_DISCOVER arguments. */
108#define IP_PMTUDISC_DONT 0 /* Never send DF frames. */
109#define IP_PMTUDISC_WANT 1 /* Use per route hints. */
110#define IP_PMTUDISC_DO 2 /* Always DF. */
111#define IP_PMTUDISC_PROBE 3 /* Ignore dst pmtu. */
112/* Always use interface mtu (ignores dst pmtu) but don't set DF flag.
113 Also incoming ICMP frag_needed notifications will be ignored on
114 this socket to prevent accepting spoofed ones. */
115#define IP_PMTUDISC_INTERFACE 4
116/* Like IP_PMTUDISC_INTERFACE but allow packets to be fragmented. */
117#define IP_PMTUDISC_OMIT 5
118
119#define IP_MULTICAST_IF 32
120#define IP_MULTICAST_TTL 33
121#define IP_MULTICAST_LOOP 34
122#define IP_ADD_MEMBERSHIP 35
123#define IP_DROP_MEMBERSHIP 36
124#define IP_UNBLOCK_SOURCE 37
125#define IP_BLOCK_SOURCE 38
126#define IP_ADD_SOURCE_MEMBERSHIP 39
127#define IP_DROP_SOURCE_MEMBERSHIP 40
128#define IP_MSFILTER 41
129#define IP_MULTICAST_ALL 49
130#define IP_UNICAST_IF 50
131
132/* To select the IP level. */
133#define SOL_IP 0
134
135#define IP_DEFAULT_MULTICAST_TTL 1
136#define IP_DEFAULT_MULTICAST_LOOP 1
137#define IP_MAX_MEMBERSHIPS 20
138
139#ifdef __USE_MISC
140/* Structure used to describe IP options for IP_OPTIONS and IP_RETOPTS.
141 The `ip_dst' field is used for the first-hop gateway when using a
142 source route (this gets put into the header proper). */
143struct ip_opts
144 {
145 struct in_addr ip_dst; /* First hop; zero without source route. */
146 char ip_opts[40]; /* Actually variable in size. */
147 };
148
149/* Like `struct ip_mreq' but including interface specification by index. */
150struct ip_mreqn
151 {
152 struct in_addr imr_multiaddr; /* IP multicast address of group */
153 struct in_addr imr_address; /* local IP address of interface */
154 int imr_ifindex; /* Interface index */
155 };
156
157/* Structure used for IP_PKTINFO. */
158struct in_pktinfo
159 {
160 int ipi_ifindex; /* Interface index */
161 struct in_addr ipi_spec_dst; /* Routing destination address */
162 struct in_addr ipi_addr; /* Header destination address */
163 };
164#endif
165
166/* Options for use with `getsockopt' and `setsockopt' at the IPv6 level.
167 The first word in the comment at the right is the data type used;
168 "bool" means a boolean value stored in an `int'. */
169#define IPV6_ADDRFORM 1
170#define IPV6_2292PKTINFO 2
171#define IPV6_2292HOPOPTS 3
172#define IPV6_2292DSTOPTS 4
173#define IPV6_2292RTHDR 5
174#define IPV6_2292PKTOPTIONS 6
175#define IPV6_CHECKSUM 7
176#define IPV6_2292HOPLIMIT 8
177
178#define SCM_SRCRT IPV6_RXSRCRT
179
180#define IPV6_NEXTHOP 9
181#define IPV6_AUTHHDR 10
182#define IPV6_UNICAST_HOPS 16
183#define IPV6_MULTICAST_IF 17
184#define IPV6_MULTICAST_HOPS 18
185#define IPV6_MULTICAST_LOOP 19
186#define IPV6_JOIN_GROUP 20
187#define IPV6_LEAVE_GROUP 21
188#define IPV6_ROUTER_ALERT 22
189#define IPV6_MTU_DISCOVER 23
190#define IPV6_MTU 24
191#define IPV6_RECVERR 25
192#define IPV6_V6ONLY 26
193#define IPV6_JOIN_ANYCAST 27
194#define IPV6_LEAVE_ANYCAST 28
195#define IPV6_MULTICAST_ALL 29
196#define IPV6_ROUTER_ALERT_ISOLATE 30
197#define IPV6_RECVERR_RFC4884 31
198#define IPV6_IPSEC_POLICY 34
199#define IPV6_XFRM_POLICY 35
200#define IPV6_HDRINCL 36
201
202/* Advanced API (RFC3542) (1). */
203#define IPV6_RECVPKTINFO 49
204#define IPV6_PKTINFO 50
205#define IPV6_RECVHOPLIMIT 51
206#define IPV6_HOPLIMIT 52
207#define IPV6_RECVHOPOPTS 53
208#define IPV6_HOPOPTS 54
209#define IPV6_RTHDRDSTOPTS 55
210#define IPV6_RECVRTHDR 56
211#define IPV6_RTHDR 57
212#define IPV6_RECVDSTOPTS 58
213#define IPV6_DSTOPTS 59
214#define IPV6_RECVPATHMTU 60
215#define IPV6_PATHMTU 61
216#define IPV6_DONTFRAG 62
217
218/* Advanced API (RFC3542) (2). */
219#define IPV6_RECVTCLASS 66
220#define IPV6_TCLASS 67
221
222#define IPV6_AUTOFLOWLABEL 70
223
224/* RFC5014. */
225#define IPV6_ADDR_PREFERENCES 72
226
227/* RFC5082. */
228#define IPV6_MINHOPCOUNT 73
229
230#define IPV6_ORIGDSTADDR 74
231#define IPV6_RECVORIGDSTADDR IPV6_ORIGDSTADDR
232#define IPV6_TRANSPARENT 75
233#define IPV6_UNICAST_IF 76
234#define IPV6_RECVFRAGSIZE 77
235#define IPV6_FREEBIND 78
236
237/* Obsolete synonyms for the above. */
238#if !__USE_KERNEL_IPV6_DEFS
239# define IPV6_ADD_MEMBERSHIP IPV6_JOIN_GROUP
240# define IPV6_DROP_MEMBERSHIP IPV6_LEAVE_GROUP
241#endif
242#define IPV6_RXHOPOPTS IPV6_HOPOPTS
243#define IPV6_RXDSTOPTS IPV6_DSTOPTS
244
245/* IPV6_MTU_DISCOVER values. */
246#define IPV6_PMTUDISC_DONT 0 /* Never send DF frames. */
247#define IPV6_PMTUDISC_WANT 1 /* Use per route hints. */
248#define IPV6_PMTUDISC_DO 2 /* Always DF. */
249#define IPV6_PMTUDISC_PROBE 3 /* Ignore dst pmtu. */
250#define IPV6_PMTUDISC_INTERFACE 4 /* See IP_PMTUDISC_INTERFACE. */
251#define IPV6_PMTUDISC_OMIT 5 /* See IP_PMTUDISC_OMIT. */
252
253/* Socket level values for IPv6. */
254#define SOL_IPV6 41
255#define SOL_ICMPV6 58
256
257/* Routing header options for IPv6. */
258#define IPV6_RTHDR_LOOSE 0 /* Hop doesn't need to be neighbour. */
259#define IPV6_RTHDR_STRICT 1 /* Hop must be a neighbour. */
260
261#define IPV6_RTHDR_TYPE_0 0 /* IPv6 Routing header type 0. */
262