in.h revision 1.14 1 1.14 cgd /* $NetBSD: in.h,v 1.14 1995/04/13 06:27:30 cgd Exp $ */
2 1.12 cgd
3 1.1 cgd /*
4 1.9 mycroft * Copyright (c) 1982, 1986, 1990, 1993
5 1.9 mycroft * The Regents of the University of California. All rights reserved.
6 1.1 cgd *
7 1.1 cgd * Redistribution and use in source and binary forms, with or without
8 1.1 cgd * modification, are permitted provided that the following conditions
9 1.1 cgd * are met:
10 1.1 cgd * 1. Redistributions of source code must retain the above copyright
11 1.1 cgd * notice, this list of conditions and the following disclaimer.
12 1.1 cgd * 2. Redistributions in binary form must reproduce the above copyright
13 1.1 cgd * notice, this list of conditions and the following disclaimer in the
14 1.1 cgd * documentation and/or other materials provided with the distribution.
15 1.1 cgd * 3. All advertising materials mentioning features or use of this software
16 1.1 cgd * must display the following acknowledgement:
17 1.1 cgd * This product includes software developed by the University of
18 1.1 cgd * California, Berkeley and its contributors.
19 1.1 cgd * 4. Neither the name of the University nor the names of its contributors
20 1.1 cgd * may be used to endorse or promote products derived from this software
21 1.1 cgd * without specific prior written permission.
22 1.1 cgd *
23 1.1 cgd * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
24 1.1 cgd * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
25 1.1 cgd * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
26 1.1 cgd * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
27 1.1 cgd * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
28 1.1 cgd * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
29 1.1 cgd * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
30 1.1 cgd * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
31 1.1 cgd * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
32 1.1 cgd * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
33 1.1 cgd * SUCH DAMAGE.
34 1.1 cgd *
35 1.12 cgd * @(#)in.h 8.3 (Berkeley) 1/3/94
36 1.1 cgd */
37 1.1 cgd
38 1.1 cgd /*
39 1.1 cgd * Constants and structures defined by the internet system,
40 1.9 mycroft * Per RFC 790, September 1981, and numerous additions.
41 1.1 cgd */
42 1.1 cgd
43 1.11 cgd #ifndef _NETINET_IN_H_
44 1.11 cgd #define _NETINET_IN_H_
45 1.10 cgd
46 1.1 cgd /*
47 1.1 cgd * Protocols
48 1.1 cgd */
49 1.1 cgd #define IPPROTO_IP 0 /* dummy for IP */
50 1.1 cgd #define IPPROTO_ICMP 1 /* control message protocol */
51 1.5 mycroft #define IPPROTO_IGMP 2 /* group mgmt protocol */
52 1.1 cgd #define IPPROTO_GGP 3 /* gateway^2 (deprecated) */
53 1.1 cgd #define IPPROTO_TCP 6 /* tcp */
54 1.1 cgd #define IPPROTO_EGP 8 /* exterior gateway protocol */
55 1.1 cgd #define IPPROTO_PUP 12 /* pup */
56 1.1 cgd #define IPPROTO_UDP 17 /* user datagram protocol */
57 1.1 cgd #define IPPROTO_IDP 22 /* xns idp */
58 1.1 cgd #define IPPROTO_TP 29 /* tp-4 w/ class negotiation */
59 1.1 cgd #define IPPROTO_EON 80 /* ISO cnlp */
60 1.9 mycroft #define IPPROTO_ENCAP 98 /* encapsulation header */
61 1.1 cgd
62 1.1 cgd #define IPPROTO_RAW 255 /* raw IP packet */
63 1.1 cgd #define IPPROTO_MAX 256
64 1.1 cgd
65 1.1 cgd
66 1.1 cgd /*
67 1.1 cgd * Local port number conventions:
68 1.1 cgd * Ports < IPPORT_RESERVED are reserved for
69 1.1 cgd * privileged processes (e.g. root).
70 1.1 cgd * Ports > IPPORT_USERRESERVED are reserved
71 1.1 cgd * for servers, not necessarily privileged.
72 1.1 cgd */
73 1.1 cgd #define IPPORT_RESERVED 1024
74 1.1 cgd #define IPPORT_USERRESERVED 5000
75 1.1 cgd
76 1.1 cgd /*
77 1.1 cgd * Internet address (a structure for historical reasons)
78 1.1 cgd */
79 1.1 cgd struct in_addr {
80 1.14 cgd u_int32_t s_addr;
81 1.1 cgd };
82 1.1 cgd
83 1.1 cgd /*
84 1.1 cgd * Definitions of bits in internet address integers.
85 1.1 cgd * On subnets, the decomposition of addresses to host and net parts
86 1.1 cgd * is done according to subnet mask, not the masks here.
87 1.1 cgd */
88 1.14 cgd #define IN_CLASSA(i) (((int32_t)(i) & 0x80000000) == 0)
89 1.1 cgd #define IN_CLASSA_NET 0xff000000
90 1.1 cgd #define IN_CLASSA_NSHIFT 24
91 1.1 cgd #define IN_CLASSA_HOST 0x00ffffff
92 1.1 cgd #define IN_CLASSA_MAX 128
93 1.1 cgd
94 1.14 cgd #define IN_CLASSB(i) (((int32_t)(i) & 0xc0000000) == 0x80000000)
95 1.1 cgd #define IN_CLASSB_NET 0xffff0000
96 1.1 cgd #define IN_CLASSB_NSHIFT 16
97 1.1 cgd #define IN_CLASSB_HOST 0x0000ffff
98 1.1 cgd #define IN_CLASSB_MAX 65536
99 1.1 cgd
100 1.14 cgd #define IN_CLASSC(i) (((int32_t)(i) & 0xe0000000) == 0xc0000000)
101 1.1 cgd #define IN_CLASSC_NET 0xffffff00
102 1.1 cgd #define IN_CLASSC_NSHIFT 8
103 1.1 cgd #define IN_CLASSC_HOST 0x000000ff
104 1.1 cgd
105 1.14 cgd #define IN_CLASSD(i) (((int32_t)(i) & 0xf0000000) == 0xe0000000)
106 1.5 mycroft #define IN_CLASSD_NET 0xf0000000 /* These ones aren't really */
107 1.5 mycroft #define IN_CLASSD_NSHIFT 28 /* net and host fields, but */
108 1.9 mycroft #define IN_CLASSD_HOST 0x0fffffff /* routing needn't know. */
109 1.1 cgd #define IN_MULTICAST(i) IN_CLASSD(i)
110 1.1 cgd
111 1.14 cgd #define IN_EXPERIMENTAL(i) (((int32_t)(i) & 0xf0000000) == 0xf0000000)
112 1.14 cgd #define IN_BADCLASS(i) (((int32_t)(i) & 0xf0000000) == 0xf0000000)
113 1.1 cgd
114 1.14 cgd #define INADDR_ANY (u_int32_t)0x00000000
115 1.14 cgd #define INADDR_LOOPBACK (u_int32_t)0x7f000001
116 1.14 cgd #define INADDR_BROADCAST (u_int32_t)0xffffffff /* must be masked */
117 1.13 jtc #ifndef _KERNEL
118 1.1 cgd #define INADDR_NONE 0xffffffff /* -1 return */
119 1.1 cgd #endif
120 1.1 cgd
121 1.14 cgd #define INADDR_UNSPEC_GROUP (u_int32_t)0xe0000000 /* 224.0.0.0 */
122 1.14 cgd #define INADDR_ALLHOSTS_GROUP (u_int32_t)0xe0000001 /* 224.0.0.1 */
123 1.14 cgd #define INADDR_MAX_LOCAL_GROUP (u_int32_t)0xe00000ff /* 224.0.0.255 */
124 1.4 hpeyerl
125 1.1 cgd #define IN_LOOPBACKNET 127 /* official! */
126 1.1 cgd
127 1.1 cgd /*
128 1.1 cgd * Socket address, internet style.
129 1.1 cgd */
130 1.1 cgd struct sockaddr_in {
131 1.14 cgd u_int8_t sin_len;
132 1.14 cgd u_int8_t sin_family;
133 1.14 cgd u_int16_t sin_port;
134 1.14 cgd struct in_addr sin_addr;
135 1.14 cgd int8_t sin_zero[8];
136 1.1 cgd };
137 1.1 cgd
138 1.1 cgd /*
139 1.1 cgd * Structure used to describe IP options.
140 1.1 cgd * Used to store options internally, to pass them to a process,
141 1.1 cgd * or to restore options retrieved earlier.
142 1.1 cgd * The ip_dst is used for the first-hop gateway when using a source route
143 1.1 cgd * (this gets put into the header proper).
144 1.1 cgd */
145 1.1 cgd struct ip_opts {
146 1.14 cgd struct in_addr ip_dst; /* first hop, 0 w/o src rt */
147 1.14 cgd int8_t ip_opts[40]; /* actually variable in size */
148 1.1 cgd };
149 1.1 cgd
150 1.1 cgd /*
151 1.1 cgd * Options for use with [gs]etsockopt at the IP level.
152 1.1 cgd * First word of comment is data type; bool is stored in int.
153 1.1 cgd */
154 1.9 mycroft #define IP_OPTIONS 1 /* buf/ip_opts; set/get IP options */
155 1.9 mycroft #define IP_HDRINCL 2 /* int; header is included with data */
156 1.9 mycroft #define IP_TOS 3 /* int; IP type of service and preced. */
157 1.9 mycroft #define IP_TTL 4 /* int; IP time to live */
158 1.9 mycroft #define IP_RECVOPTS 5 /* bool; receive all IP opts w/dgram */
159 1.9 mycroft #define IP_RECVRETOPTS 6 /* bool; receive IP opts for response */
160 1.9 mycroft #define IP_RECVDSTADDR 7 /* bool; receive IP dst addr w/dgram */
161 1.9 mycroft #define IP_RETOPTS 8 /* ip_opts; set/get IP options */
162 1.9 mycroft #define IP_MULTICAST_IF 9 /* u_char; set/get IP multicast i/f */
163 1.9 mycroft #define IP_MULTICAST_TTL 10 /* u_char; set/get IP multicast ttl */
164 1.9 mycroft #define IP_MULTICAST_LOOP 11 /* u_char; set/get IP multicast loopback */
165 1.9 mycroft #define IP_ADD_MEMBERSHIP 12 /* ip_mreq; add an IP group membership */
166 1.9 mycroft #define IP_DROP_MEMBERSHIP 13 /* ip_mreq; drop an IP group membership */
167 1.9 mycroft
168 1.9 mycroft /*
169 1.9 mycroft * Defaults and limits for options
170 1.9 mycroft */
171 1.9 mycroft #define IP_DEFAULT_MULTICAST_TTL 1 /* normally limit m'casts to 1 hop */
172 1.9 mycroft #define IP_DEFAULT_MULTICAST_LOOP 1 /* normally hear sends if a member */
173 1.9 mycroft #define IP_MAX_MEMBERSHIPS 20 /* per socket; must fit in one mbuf */
174 1.4 hpeyerl
175 1.4 hpeyerl /*
176 1.4 hpeyerl * Argument structure for IP_ADD_MEMBERSHIP and IP_DROP_MEMBERSHIP.
177 1.4 hpeyerl */
178 1.4 hpeyerl struct ip_mreq {
179 1.5 mycroft struct in_addr imr_multiaddr; /* IP multicast address of group */
180 1.5 mycroft struct in_addr imr_interface; /* local IP address of interface */
181 1.4 hpeyerl };
182 1.1 cgd
183 1.9 mycroft /*
184 1.9 mycroft * Definitions for inet sysctl operations.
185 1.9 mycroft *
186 1.9 mycroft * Third level is protocol number.
187 1.9 mycroft * Fourth level is desired variable within that protocol.
188 1.9 mycroft */
189 1.9 mycroft #define IPPROTO_MAXID (IPPROTO_IDP + 1) /* don't list to IPPROTO_MAX */
190 1.9 mycroft
191 1.9 mycroft #define CTL_IPPROTO_NAMES { \
192 1.9 mycroft { "ip", CTLTYPE_NODE }, \
193 1.9 mycroft { "icmp", CTLTYPE_NODE }, \
194 1.9 mycroft { "igmp", CTLTYPE_NODE }, \
195 1.9 mycroft { "ggp", CTLTYPE_NODE }, \
196 1.9 mycroft { 0, 0 }, \
197 1.9 mycroft { 0, 0 }, \
198 1.9 mycroft { "tcp", CTLTYPE_NODE }, \
199 1.9 mycroft { 0, 0 }, \
200 1.9 mycroft { "egp", CTLTYPE_NODE }, \
201 1.9 mycroft { 0, 0 }, \
202 1.9 mycroft { 0, 0 }, \
203 1.9 mycroft { 0, 0 }, \
204 1.9 mycroft { "pup", CTLTYPE_NODE }, \
205 1.9 mycroft { 0, 0 }, \
206 1.9 mycroft { 0, 0 }, \
207 1.9 mycroft { 0, 0 }, \
208 1.9 mycroft { 0, 0 }, \
209 1.9 mycroft { "udp", CTLTYPE_NODE }, \
210 1.9 mycroft { 0, 0 }, \
211 1.9 mycroft { 0, 0 }, \
212 1.9 mycroft { 0, 0 }, \
213 1.9 mycroft { 0, 0 }, \
214 1.9 mycroft { "idp", CTLTYPE_NODE }, \
215 1.9 mycroft }
216 1.9 mycroft
217 1.9 mycroft /*
218 1.9 mycroft * Names for IP sysctl objects
219 1.9 mycroft */
220 1.9 mycroft #define IPCTL_FORWARDING 1 /* act as router */
221 1.9 mycroft #define IPCTL_SENDREDIRECTS 2 /* may send redirects when forwarding */
222 1.9 mycroft #define IPCTL_DEFTTL 3 /* default TTL */
223 1.9 mycroft #ifdef notyet
224 1.9 mycroft #define IPCTL_DEFMTU 4 /* default MTU */
225 1.9 mycroft #endif
226 1.9 mycroft #define IPCTL_MAXID 5
227 1.9 mycroft
228 1.9 mycroft #define IPCTL_NAMES { \
229 1.9 mycroft { 0, 0 }, \
230 1.9 mycroft { "forwarding", CTLTYPE_INT }, \
231 1.9 mycroft { "redirect", CTLTYPE_INT }, \
232 1.9 mycroft { "ttl", CTLTYPE_INT }, \
233 1.9 mycroft { "mtu", CTLTYPE_INT }, \
234 1.9 mycroft }
235 1.8 deraadt
236 1.6 mycroft
237 1.13 jtc #ifdef _KERNEL
238 1.14 cgd int in_broadcast __P((struct in_addr, struct ifnet *));
239 1.14 cgd int in_canforward __P((struct in_addr));
240 1.14 cgd int in_cksum __P((struct mbuf *, int));
241 1.14 cgd int in_localaddr __P((struct in_addr));
242 1.14 cgd u_int32_t in_netof __P((struct in_addr));
243 1.14 cgd void in_socktrim __P((struct sockaddr_in *));
244 1.1 cgd #endif
245 1.11 cgd #endif /* !_NETINET_IN_H_ */
246