sl@0
|
1 |
/* IN.H
|
sl@0
|
2 |
*
|
sl@0
|
3 |
* Portions Copyright (c) 1997-2006 Nokia Corporation and/or its subsidiary(-ies).
|
sl@0
|
4 |
* All rights reserved.
|
sl@0
|
5 |
*/
|
sl@0
|
6 |
|
sl@0
|
7 |
/** @file
|
sl@0
|
8 |
@PublishedAll
|
sl@0
|
9 |
*/
|
sl@0
|
10 |
|
sl@0
|
11 |
/*
|
sl@0
|
12 |
* Copyright (c) 1982, 1986 Regents of the University of California.
|
sl@0
|
13 |
* All rights reserved.
|
sl@0
|
14 |
*
|
sl@0
|
15 |
* Redistribution and use in source and binary forms are permitted
|
sl@0
|
16 |
* provided that this notice is preserved and that due credit is given
|
sl@0
|
17 |
* to the University of California at Berkeley. The name of the University
|
sl@0
|
18 |
* may not be used to endorse or promote products derived from this
|
sl@0
|
19 |
* software without specific prior written permission. This software
|
sl@0
|
20 |
* is provided ``as is'' without express or implied warranty.
|
sl@0
|
21 |
*/
|
sl@0
|
22 |
|
sl@0
|
23 |
/*
|
sl@0
|
24 |
* Constants and structures defined by the internet system,
|
sl@0
|
25 |
* Per RFC 790, September 1981.
|
sl@0
|
26 |
*/
|
sl@0
|
27 |
|
sl@0
|
28 |
#ifndef _NETINET_IN_H
|
sl@0
|
29 |
#define _NETINET_IN_H
|
sl@0
|
30 |
|
sl@0
|
31 |
#ifdef __cplusplus
|
sl@0
|
32 |
extern "C" {
|
sl@0
|
33 |
#endif
|
sl@0
|
34 |
#include <_ansi.h>
|
sl@0
|
35 |
|
sl@0
|
36 |
/**
|
sl@0
|
37 |
Protocols
|
sl@0
|
38 |
*/
|
sl@0
|
39 |
#define IPPROTO_IP 0x100 /* dummy for IP */
|
sl@0
|
40 |
#define IPPROTO_ICMP 1 /* control message protocol */
|
sl@0
|
41 |
#define IPPROTO_IGMP 2 /* group control protocol */
|
sl@0
|
42 |
#define IPPROTO_GGP 3 /* gateway^2 (deprecated) */
|
sl@0
|
43 |
#define IPPROTO_ENCAP 4 /* IP in IP encapsulation */
|
sl@0
|
44 |
#define IPPROTO_TCP 6 /* tcp */
|
sl@0
|
45 |
#define IPPROTO_EGP 8 /* exterior gateway protocol */
|
sl@0
|
46 |
#define IPPROTO_PUP 12 /* pup */
|
sl@0
|
47 |
#define IPPROTO_UDP 17 /* user datagram protocol */
|
sl@0
|
48 |
#define IPPROTO_IDP 22 /* xns idp */
|
sl@0
|
49 |
#define IPPROTO_HELLO 63 /* "hello" routing protocol */
|
sl@0
|
50 |
#define IPPROTO_ND 77 /* UNOFFICIAL net disk proto */
|
sl@0
|
51 |
#define IPPROTO_EON 80 /* ISO clnp */
|
sl@0
|
52 |
#define IPPROTO_RAW 255 /* raw IP packet */
|
sl@0
|
53 |
#define IPPROTO_MAX 0x101
|
sl@0
|
54 |
|
sl@0
|
55 |
/**
|
sl@0
|
56 |
Port/socket numbers: network standard functions
|
sl@0
|
57 |
*/
|
sl@0
|
58 |
#define IPPORT_ECHO 7
|
sl@0
|
59 |
#define IPPORT_DISCARD 9
|
sl@0
|
60 |
#define IPPORT_SYSTAT 11
|
sl@0
|
61 |
#define IPPORT_DAYTIME 13
|
sl@0
|
62 |
#define IPPORT_NETSTAT 15
|
sl@0
|
63 |
#define IPPORT_FTP 21
|
sl@0
|
64 |
#define IPPORT_TELNET 23
|
sl@0
|
65 |
#define IPPORT_SMTP 25
|
sl@0
|
66 |
#define IPPORT_TIMESERVER 37
|
sl@0
|
67 |
#define IPPORT_NAMESERVER 42
|
sl@0
|
68 |
#define IPPORT_WHOIS 43
|
sl@0
|
69 |
#define IPPORT_MTP 57
|
sl@0
|
70 |
|
sl@0
|
71 |
/**
|
sl@0
|
72 |
Port/socket numbers: host specific functions
|
sl@0
|
73 |
*/
|
sl@0
|
74 |
#define IPPORT_TFTP 69
|
sl@0
|
75 |
#define IPPORT_RJE 77
|
sl@0
|
76 |
#define IPPORT_FINGER 79
|
sl@0
|
77 |
#define IPPORT_TTYLINK 87
|
sl@0
|
78 |
#define IPPORT_SUPDUP 95
|
sl@0
|
79 |
|
sl@0
|
80 |
/**
|
sl@0
|
81 |
UNIX TCP sockets
|
sl@0
|
82 |
*/
|
sl@0
|
83 |
#define IPPORT_EXECSERVER 512
|
sl@0
|
84 |
#define IPPORT_LOGINSERVER 513
|
sl@0
|
85 |
#define IPPORT_CMDSERVER 514
|
sl@0
|
86 |
#define IPPORT_EFSSERVER 520
|
sl@0
|
87 |
|
sl@0
|
88 |
/**
|
sl@0
|
89 |
UNIX UDP sockets
|
sl@0
|
90 |
*/
|
sl@0
|
91 |
#define IPPORT_BIFFUDP 512
|
sl@0
|
92 |
#define IPPORT_WHOSERVER 513
|
sl@0
|
93 |
#define IPPORT_ROUTESERVER 520 /* 520+1 also used */
|
sl@0
|
94 |
|
sl@0
|
95 |
/**
|
sl@0
|
96 |
Ports < IPPORT_RESERVED are reserved for
|
sl@0
|
97 |
privileged processes (e.g. root).
|
sl@0
|
98 |
Ports > IPPORT_USERRESERVED are reserved
|
sl@0
|
99 |
for servers, not necessarily privileged.
|
sl@0
|
100 |
*/
|
sl@0
|
101 |
#define IPPORT_RESERVED 1024
|
sl@0
|
102 |
#define IPPORT_USERRESERVED 5000
|
sl@0
|
103 |
|
sl@0
|
104 |
/**
|
sl@0
|
105 |
Link numbers
|
sl@0
|
106 |
*/
|
sl@0
|
107 |
#define IMPLINK_IP 155
|
sl@0
|
108 |
#define IMPLINK_LOWEXPER 156
|
sl@0
|
109 |
#define IMPLINK_HIGHEXPER 158
|
sl@0
|
110 |
|
sl@0
|
111 |
/**
|
sl@0
|
112 |
Internet address
|
sl@0
|
113 |
This definition contains obsolete fields for compatibility
|
sl@0
|
114 |
with SunOS 3.x and 4.2bsd. The presence of subnets renders
|
sl@0
|
115 |
divisions into fixed fields misleading at best. New code
|
sl@0
|
116 |
should use only the s_addr field.
|
sl@0
|
117 |
@publishedAll
|
sl@0
|
118 |
@released
|
sl@0
|
119 |
*/
|
sl@0
|
120 |
struct in_addr {
|
sl@0
|
121 |
union {
|
sl@0
|
122 |
struct { u_char s_b1, s_b2, s_b3, s_b4; } S_un_b;
|
sl@0
|
123 |
struct { u_short s_w1, s_w2; } S_un_w;
|
sl@0
|
124 |
u_long S_addr;
|
sl@0
|
125 |
} S_un;
|
sl@0
|
126 |
/**
|
sl@0
|
127 |
@publishedAll
|
sl@0
|
128 |
@released
|
sl@0
|
129 |
*/
|
sl@0
|
130 |
#define s_addr S_un.S_addr /* should be used for all code */
|
sl@0
|
131 |
/**
|
sl@0
|
132 |
@publishedAll
|
sl@0
|
133 |
@released
|
sl@0
|
134 |
*/
|
sl@0
|
135 |
#define s_host S_un.S_un_b.s_b2 /* OBSOLETE: host on imp */
|
sl@0
|
136 |
/**
|
sl@0
|
137 |
@publishedAll
|
sl@0
|
138 |
@released
|
sl@0
|
139 |
*/
|
sl@0
|
140 |
#define s_net S_un.S_un_b.s_b1 /* OBSOLETE: network */
|
sl@0
|
141 |
/**
|
sl@0
|
142 |
@publishedAll
|
sl@0
|
143 |
@released
|
sl@0
|
144 |
*/
|
sl@0
|
145 |
#define s_imp S_un.S_un_w.s_w2 /* OBSOLETE: imp */
|
sl@0
|
146 |
/**
|
sl@0
|
147 |
@publishedAll
|
sl@0
|
148 |
@released
|
sl@0
|
149 |
*/
|
sl@0
|
150 |
#define s_impno S_un.S_un_b.s_b4 /* OBSOLETE: imp # */
|
sl@0
|
151 |
/**
|
sl@0
|
152 |
@publishedAll
|
sl@0
|
153 |
@released
|
sl@0
|
154 |
*/
|
sl@0
|
155 |
#define s_lh S_un.S_un_b.s_b3 /* OBSOLETE: logical host */
|
sl@0
|
156 |
};
|
sl@0
|
157 |
|
sl@0
|
158 |
/**
|
sl@0
|
159 |
Definitions of bits in internet address integers.
|
sl@0
|
160 |
On subnets, the decomposition of addresses to host and net parts
|
sl@0
|
161 |
is done according to subnet mask, not the masks here.
|
sl@0
|
162 |
*/
|
sl@0
|
163 |
#define IN_CLASSA(i) (((long)(i) & 0x80000000) == 0)
|
sl@0
|
164 |
#define IN_CLASSA_NET 0xff000000
|
sl@0
|
165 |
#define IN_CLASSA_NSHIFT 24
|
sl@0
|
166 |
#define IN_CLASSA_HOST 0x00ffffff
|
sl@0
|
167 |
#define IN_CLASSA_MAX 128
|
sl@0
|
168 |
|
sl@0
|
169 |
#define IN_CLASSB(i) (((long)(i) & 0xc0000000) == 0x80000000)
|
sl@0
|
170 |
#define IN_CLASSB_NET 0xffff0000
|
sl@0
|
171 |
#define IN_CLASSB_NSHIFT 16
|
sl@0
|
172 |
#define IN_CLASSB_HOST 0x0000ffff
|
sl@0
|
173 |
#define IN_CLASSB_MAX 65536
|
sl@0
|
174 |
|
sl@0
|
175 |
#define IN_CLASSC(i) (((long)(i) & 0xe0000000) == 0xc0000000)
|
sl@0
|
176 |
#define IN_CLASSC_NET 0xffffff00
|
sl@0
|
177 |
#define IN_CLASSC_NSHIFT 8
|
sl@0
|
178 |
#define IN_CLASSC_HOST 0x000000ff
|
sl@0
|
179 |
#define IN_CLASSC_MAX 16777216L
|
sl@0
|
180 |
|
sl@0
|
181 |
#define IN_CLASSD(i) (((long)(i) & 0xf0000000) == 0xe0000000)
|
sl@0
|
182 |
#define IN_CLASSD_NET 0xf0000000 /* These ones aren't really */
|
sl@0
|
183 |
#define IN_CLASSD_NSHIFT 28 /* net and host fields, but */
|
sl@0
|
184 |
#define IN_CLASSD_HOST 0x0fffffff /* routing needn't know. */
|
sl@0
|
185 |
#define IN_MULTICAST(i) IN_CLASSD(i)
|
sl@0
|
186 |
|
sl@0
|
187 |
#define IN_EXPERIMENTAL(i) (((long)(i) & 0xe0000000) == 0xe0000000)
|
sl@0
|
188 |
#define IN_BADCLASS(i) (((long)(i) & 0xf0000000) == 0xf0000000)
|
sl@0
|
189 |
|
sl@0
|
190 |
#define INADDR_ANY (u_long)0x00000000
|
sl@0
|
191 |
#define INADDR_LOOPBACK (u_long)0x7F000001
|
sl@0
|
192 |
#define INADDR_BROADCAST (u_long)0xffffffff /* must be masked */
|
sl@0
|
193 |
|
sl@0
|
194 |
#define INADDR_UNSPEC_GROUP (u_long)0xe0000000 /* 224.0.0.0 */
|
sl@0
|
195 |
#define INADDR_ALLHOSTS_GROUP (u_long)0xe0000001 /* 224.0.0.1 */
|
sl@0
|
196 |
#define INADDR_MAX_LOCAL_GROUP (u_long)0xe00000ff /* 224.0.0.255 */
|
sl@0
|
197 |
|
sl@0
|
198 |
#define INADDR_NONE INADDR_BROADCAST /* traditional, but misleading */
|
sl@0
|
199 |
|
sl@0
|
200 |
#define IN_LOOPBACKNET 127 /* official! */
|
sl@0
|
201 |
|
sl@0
|
202 |
/**
|
sl@0
|
203 |
Define a macro to stuff the loopback address into an Internet address
|
sl@0
|
204 |
0x0100007F is htonl(INADDR_LOOPBACK) without the overhead of a function call.
|
sl@0
|
205 |
*/
|
sl@0
|
206 |
#define IN_SET_LOOPBACK_ADDR(a) \
|
sl@0
|
207 |
{ (a)->sin_addr.s_addr = 0x0100007F; (a)->sin_family = AF_INET; }
|
sl@0
|
208 |
|
sl@0
|
209 |
/**
|
sl@0
|
210 |
Socket address, internet style.
|
sl@0
|
211 |
*/
|
sl@0
|
212 |
struct sockaddr_in {
|
sl@0
|
213 |
u_short sin_family;
|
sl@0
|
214 |
u_short sin_port;
|
sl@0
|
215 |
struct in_addr sin_addr;
|
sl@0
|
216 |
char sin_zero[20];
|
sl@0
|
217 |
};
|
sl@0
|
218 |
|
sl@0
|
219 |
/**
|
sl@0
|
220 |
* Options for use with [gs]etsockopt at the IP level.
|
sl@0
|
221 |
* NB. The negative option values below are not supported and must not
|
sl@0
|
222 |
* be used in calls to the [gs]etsockopt() API as they will be ignored
|
sl@0
|
223 |
* or cause an error.
|
sl@0
|
224 |
*/
|
sl@0
|
225 |
#define SOL_IP 0x100 /* options for IP level */
|
sl@0
|
226 |
|
sl@0
|
227 |
#define IP_OPTIONS 0x306 /* set/get IP per-packet options */
|
sl@0
|
228 |
#define IP_HDRINCL 0x308 /* int; header is included with data (raw) */
|
sl@0
|
229 |
#define IP_TOS 0x309 /* int; IP type of service and precedence */
|
sl@0
|
230 |
#define IP_TTL 0x310 /* int; IP time to live */
|
sl@0
|
231 |
#define IP_RECVOPTS -1 /* bool; receive all IP options w/datagram */
|
sl@0
|
232 |
#define IP_RECVRETOPTS -2 /* bool; receive IP options for response */
|
sl@0
|
233 |
#define IP_RECVDSTADDR -3 /* bool; receive IP dst addr w/datagram */
|
sl@0
|
234 |
#define IP_RETOPTS -4 /* ip_opts; set/get IP per-packet options */
|
sl@0
|
235 |
#define IP_MULTICAST_IF -5 /* set/get IP multicast interface */
|
sl@0
|
236 |
#define IP_MULTICAST_TTL -6 /* set/get IP multicast timetolive */
|
sl@0
|
237 |
#define IP_MULTICAST_LOOP -7 /* set/get IP multicast loopback */
|
sl@0
|
238 |
#define IP_ADD_MEMBERSHIP -8 /* add an IP group membership */
|
sl@0
|
239 |
#define IP_DROP_MEMBERSHIP -9 /* drop an IP group membership */
|
sl@0
|
240 |
|
sl@0
|
241 |
#define IP_DEFAULT_MULTICAST_TTL 1 /* normally limit m'casts to 1 hop */
|
sl@0
|
242 |
#define IP_DEFAULT_MULTICAST_LOOP 1 /* normally hear sends if a member */
|
sl@0
|
243 |
|
sl@0
|
244 |
/**
|
sl@0
|
245 |
Options for use with [gs]etsockopt at the TCP level.
|
sl@0
|
246 |
*/
|
sl@0
|
247 |
#define SOL_TCP 0x106 /* options for TCP level */
|
sl@0
|
248 |
|
sl@0
|
249 |
#define TCP_SENDWINDOW 0x301 /* int: send window size in bytes */
|
sl@0
|
250 |
#define TCP_RECVWINDOW 0x302 /* int: recv window size in bytes */
|
sl@0
|
251 |
#define TCP_NODELAY 0x304 /* disable Nagle's algorithm */
|
sl@0
|
252 |
#define TCP_KEEPALIVE 0x305 /* keep connections alive */
|
sl@0
|
253 |
|
sl@0
|
254 |
/**
|
sl@0
|
255 |
Argument structure for IP_ADD_MEMBERSHIP and IP_DROP_MEMBERSHIP.
|
sl@0
|
256 |
@publishedAll
|
sl@0
|
257 |
@released
|
sl@0
|
258 |
*/
|
sl@0
|
259 |
struct ip_mreq {
|
sl@0
|
260 |
struct in_addr imr_multiaddr; /* IP multicast address of group */
|
sl@0
|
261 |
struct in_addr imr_interface; /* local IP address of interface */
|
sl@0
|
262 |
};
|
sl@0
|
263 |
|
sl@0
|
264 |
/*
|
sl@0
|
265 |
EPOC32 is little-endian
|
sl@0
|
266 |
@publishedAll
|
sl@0
|
267 |
@released
|
sl@0
|
268 |
*/
|
sl@0
|
269 |
IMPORT_C unsigned short htons(unsigned short hs);
|
sl@0
|
270 |
/**
|
sl@0
|
271 |
@publishedAll
|
sl@0
|
272 |
@released
|
sl@0
|
273 |
*/
|
sl@0
|
274 |
IMPORT_C unsigned long htonl(unsigned long hl);
|
sl@0
|
275 |
|
sl@0
|
276 |
|
sl@0
|
277 |
#define ntohl htonl
|
sl@0
|
278 |
#define ntohs htons
|
sl@0
|
279 |
|
sl@0
|
280 |
#ifdef __cplusplus
|
sl@0
|
281 |
}
|
sl@0
|
282 |
#endif
|
sl@0
|
283 |
|
sl@0
|
284 |
#endif /* _NETINET_IN_H */
|