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). */ |
143 | struct 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. */ |
150 | struct 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. */ |
158 | struct 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 | |