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