]> The Tcpdump Group git mirrors - tcpdump/blob - netdissect-stdinc.h
9b88ce9e0730c6eb7c76c3bab2c1bcbdee0613db
[tcpdump] / netdissect-stdinc.h
1 /*
2 * Copyright (c) 2002 - 2003
3 * NetGroup, Politecnico di Torino (Italy)
4 * All rights reserved.
5 *
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions
8 * are met:
9 *
10 * 1. Redistributions of source code must retain the above copyright
11 * notice, this list of conditions and the following disclaimer.
12 * 2. Redistributions in binary form must reproduce the above copyright
13 * notice, this list of conditions and the following disclaimer in the
14 * documentation and/or other materials provided with the distribution.
15 * 3. Neither the name of the Politecnico di Torino nor the names of its
16 * contributors may be used to endorse or promote products derived from
17 * this software without specific prior written permission.
18 *
19 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
20 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
21 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
22 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
23 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
24 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
25 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
26 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
27 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
28 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
29 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30 */
31
32 /*
33 * Include the appropriate OS header files on Windows and various flavors
34 * of UNIX, include various non-OS header files on Windows, and define
35 * various items as needed, to isolate most of netdissect's platform
36 * differences to this one file.
37 */
38
39 #ifndef netdissect_stdinc_h
40 #define netdissect_stdinc_h
41
42 #include <errno.h>
43
44 /*
45 * Get the C99 types, and the PRI[doux]64 format strings, defined.
46 */
47 #ifdef HAVE_PCAP_PCAP_INTTYPES_H
48 /*
49 * We have pcap/pcap-inttypes.h; use that, as it'll do all the
50 * work, and won't cause problems if a file includes this file
51 * and later includes a pcap header file that also includes
52 * pcap/pcap-inttypes.h.
53 */
54 #include <pcap/pcap-inttypes.h>
55 #else
56 /*
57 * OK, we don't have pcap/pcap-inttypes.h, so we'll have to
58 * do the work ourselves, but at least we don't have to
59 * worry about other headers including it and causing
60 * clashes.
61 */
62 #if defined(_MSC_VER)
63 /*
64 * Compiler is MSVC.
65 */
66 #if _MSC_VER >= 1800
67 /*
68 * VS 2013 or newer; we have <inttypes.h>.
69 */
70 #include <inttypes.h>
71 #else
72 /*
73 * Earlier VS; we have to define this stuff ourselves.
74 */
75 typedef unsigned char uint8_t;
76 typedef signed char int8_t;
77 typedef unsigned short uint16_t;
78 typedef signed short int16_t;
79 typedef unsigned int uint32_t;
80 typedef signed int int32_t;
81 #ifdef _MSC_EXTENSIONS
82 typedef unsigned _int64 uint64_t;
83 typedef _int64 int64_t;
84 #else /* _MSC_EXTENSIONS */
85 typedef unsigned long long uint64_t;
86 typedef long long int64_t;
87 #endif
88 #endif
89
90 /*
91 * Suppress definition of intN_t in bittypes.h, which might be included
92 * by <pcap/pcap.h> in older versions of WinPcap.
93 * (Yes, HAVE_U_INTn_T, as the definition guards are UN*X-oriented, and
94 * we check for u_intN_t in the UN*X configure script.)
95 */
96 #define HAVE_U_INT8_T
97 #define HAVE_U_INT16_T
98 #define HAVE_U_INT32_T
99 #define HAVE_U_INT64_T
100
101 /*
102 * These may be defined by <inttypes.h>. If not, define them
103 * ourselves.
104 *
105 * XXX - for MSVC, we always want the _MSC_EXTENSIONS versions.
106 * What about other compilers? If, as the MinGW Web site says MinGW
107 * does, the other compilers just use Microsoft's run-time library,
108 * then they should probably use the _MSC_EXTENSIONS even if the
109 * compiler doesn't define _MSC_EXTENSIONS.
110 */
111 #ifndef PRId64
112 #ifdef _MSC_EXTENSIONS
113 #define PRId64 "I64d"
114 #else
115 #define PRId64 "lld"
116 #endif
117 #endif /* PRId64 */
118
119 #ifndef PRIo64
120 #ifdef _MSC_EXTENSIONS
121 #define PRIo64 "I64o"
122 #else
123 #define PRIo64 "llo"
124 #endif
125 #endif /* PRIo64 */
126
127 #ifndef PRIx64
128 #ifdef _MSC_EXTENSIONS
129 #define PRIx64 "I64x"
130 #else
131 #define PRIx64 "llx"
132 #endif
133 #endif
134
135 #ifndef PRIu64
136 #ifdef _MSC_EXTENSIONS
137 #define PRIu64 "I64u"
138 #else
139 #define PRIu64 "llu"
140 #endif
141 #endif
142 #elif defined(__MINGW32__) || !defined(_WIN32)
143 /*
144 * Compiler is MinGW or target is UN*X or MS-DOS. Just use
145 * <inttypes.h>.
146 */
147 #include <inttypes.h>
148 #endif
149 #endif /* HAVE_PCAP_PCAP_INTTYPES_H */
150
151 #ifdef _WIN32
152
153 /*
154 * Includes and definitions for Windows.
155 */
156
157 #include <stdio.h>
158 #include <winsock2.h>
159 #include <ws2tcpip.h>
160 #include <ctype.h>
161 #include <time.h>
162 #include <io.h>
163 #include <fcntl.h>
164 #include <sys/types.h>
165
166 #ifdef _MSC_VER
167 #define stat _stat
168 #define open _open
169 #define fstat _fstat
170 #define read _read
171 #define close _close
172 #define O_RDONLY _O_RDONLY
173 #endif /* _MSC_VER */
174
175 /*
176 * With MSVC, for C, __inline is used to make a function an inline.
177 */
178 #ifdef _MSC_VER
179 #define inline __inline
180 #endif
181
182 #ifdef AF_INET6
183 #define HAVE_OS_IPV6_SUPPORT
184 #endif
185
186 #ifndef INET6_ADDRSTRLEN
187 #define INET6_ADDRSTRLEN 46
188 #endif
189
190 /* It is in MSVC's <errno.h>, but not defined in MingW+Watcom.
191 */
192 #ifndef EAFNOSUPPORT
193 #define EAFNOSUPPORT WSAEAFNOSUPPORT
194 #endif
195
196 #ifndef caddr_t
197 typedef char* caddr_t;
198 #endif /* caddr_t */
199
200 #define MAXHOSTNAMELEN 64
201 #define snprintf _snprintf
202 #define vsnprintf _vsnprintf
203 #define RETSIGTYPE void
204
205 #else /* _WIN32 */
206
207 /*
208 * Includes and definitions for various flavors of UN*X.
209 */
210
211 #include <ctype.h>
212 #include <unistd.h>
213 #include <netdb.h>
214 #include <sys/param.h>
215 #include <sys/types.h> /* concession to AIX */
216 #include <sys/time.h>
217 #include <sys/socket.h>
218 #include <netinet/in.h>
219
220 #ifdef TIME_WITH_SYS_TIME
221 #include <time.h>
222 #endif
223
224 #include <arpa/inet.h>
225
226 #endif /* _WIN32 */
227
228 #ifndef HAVE___ATTRIBUTE__
229 #define __attribute__(x)
230 #endif
231
232 /*
233 * Used to declare a structure unaligned, so that the C compiler,
234 * if necessary, generates code that doesn't assume alignment.
235 * This is required because there is no guarantee that the packet
236 * data we get from libpcap/WinPcap is properly aligned.
237 *
238 * This assumes that, for all compilers that support __attribute__:
239 *
240 * 1) they support __attribute__((packed));
241 *
242 * 2) for all instruction set architectures requiring strict
243 * alignment, declaring a structure with that attribute
244 * causes the compiler to generate code that handles
245 * misaligned 2-byte, 4-byte, and 8-byte integral
246 * quantities.
247 *
248 * It does not (yet) handle compilers where you can get the compiler
249 * to generate code of that sort by some other means.
250 *
251 * This is required in order to, for example, keep the compiler from
252 * generating, for
253 *
254 * if (bp->bp_htype == 1 && bp->bp_hlen == 6 && bp->bp_op == BOOTPREQUEST) {
255 *
256 * in print-bootp.c, code that loads the first 4-byte word of a
257 * "struct bootp", masking out the bp_hops field, and comparing the result
258 * against 0x01010600.
259 *
260 * Note: this also requires that padding be put into the structure,
261 * at least for compilers where it's implemented as __attribute__((packed)).
262 */
263 #if !(defined(_MSC_VER) && defined(UNALIGNED))
264 /* MSVC may have its own macro defined with the same name and purpose. */
265 #undef UNALIGNED
266 #define UNALIGNED __attribute__((packed))
267 #endif
268
269 /*
270 * fopen() read and write modes for text files and binary files.
271 */
272 #if defined(_WIN32) || defined(MSDOS)
273 #define FOPEN_READ_TXT "rt"
274 #define FOPEN_READ_BIN "rb"
275 #define FOPEN_WRITE_TXT "wt"
276 #define FOPEN_WRITE_BIN "wb"
277 #else
278 #define FOPEN_READ_TXT "r"
279 #define FOPEN_READ_BIN FOPEN_READ_TXT
280 #define FOPEN_WRITE_TXT "w"
281 #define FOPEN_WRITE_BIN FOPEN_WRITE_TXT
282 #endif
283
284 /*
285 * Inline x86 assembler-language versions of ntoh[ls]() and hton[ls](),
286 * defined if the OS doesn't provide them. These assume no more than
287 * an 80386, so, for example, it avoids the bswap instruction added in
288 * the 80486.
289 *
290 * (We don't use them on OS X; Apple provides their own, which *doesn't*
291 * avoid the bswap instruction, as OS X only supports machines that
292 * have it.)
293 */
294 #if defined(__GNUC__) && defined(__i386__) && !defined(__APPLE__) && !defined(__ntohl)
295 #undef ntohl
296 #undef ntohs
297 #undef htonl
298 #undef htons
299
300 static __inline__ unsigned long __ntohl (unsigned long x);
301 static __inline__ unsigned short __ntohs (unsigned short x);
302
303 #define ntohl(x) __ntohl(x)
304 #define ntohs(x) __ntohs(x)
305 #define htonl(x) __ntohl(x)
306 #define htons(x) __ntohs(x)
307
308 static __inline__ unsigned long __ntohl (unsigned long x)
309 {
310 __asm__ ("xchgb %b0, %h0\n\t" /* swap lower bytes */
311 "rorl $16, %0\n\t" /* swap words */
312 "xchgb %b0, %h0" /* swap higher bytes */
313 : "=q" (x) : "0" (x));
314 return (x);
315 }
316
317 static __inline__ unsigned short __ntohs (unsigned short x)
318 {
319 __asm__ ("xchgb %b0, %h0" /* swap bytes */
320 : "=q" (x) : "0" (x));
321 return (x);
322 }
323 #endif
324
325 /*
326 * If the OS doesn't define AF_INET6 and struct in6_addr:
327 *
328 * define AF_INET6, so we can use it internally as a "this is an
329 * IPv6 address" indication;
330 *
331 * define struct in6_addr so that we can use it for IPv6 addresses.
332 */
333 #ifndef HAVE_OS_IPV6_SUPPORT
334 #ifndef AF_INET6
335 #define AF_INET6 24
336
337 struct in6_addr {
338 union {
339 __uint8_t __u6_addr8[16];
340 __uint16_t __u6_addr16[8];
341 __uint32_t __u6_addr32[4];
342 } __u6_addr; /* 128-bit IP6 address */
343 };
344 #endif
345 #endif
346
347 #ifndef NI_MAXHOST
348 #define NI_MAXHOST 1025
349 #endif
350
351 #ifndef INET_ADDRSTRLEN
352 #define INET_ADDRSTRLEN 16
353 #endif
354
355 #ifndef TRUE
356 #define TRUE 1
357 #endif
358
359 #ifndef FALSE
360 #define FALSE 0
361 #endif
362
363 /*
364 * The Apple deprecation workaround macros below were adopted from the
365 * FreeRADIUS server code under permission of Alan DeKok and Arran Cudbard-Bell.
366 */
367
368 #define XSTRINGIFY(x) #x
369
370 /*
371 * Macros for controlling warnings in GCC >= 4.2 and clang >= 2.8
372 */
373 #define DIAG_JOINSTR(x,y) XSTRINGIFY(x ## y)
374 #define DIAG_DO_PRAGMA(x) _Pragma (#x)
375
376 #if defined(__GNUC__) && ((__GNUC__ * 100) + __GNUC_MINOR__) >= 402
377 # define DIAG_PRAGMA(x) DIAG_DO_PRAGMA(GCC diagnostic x)
378 # if ((__GNUC__ * 100) + __GNUC_MINOR__) >= 406
379 # define DIAG_OFF(x) DIAG_PRAGMA(push) DIAG_PRAGMA(ignored DIAG_JOINSTR(-W,x))
380 # define DIAG_ON(x) DIAG_PRAGMA(pop)
381 # else
382 # define DIAG_OFF(x) DIAG_PRAGMA(ignored DIAG_JOINSTR(-W,x))
383 # define DIAG_ON(x) DIAG_PRAGMA(warning DIAG_JOINSTR(-W,x))
384 # endif
385 #elif defined(__clang__) && ((__clang_major__ * 100) + __clang_minor__ >= 208)
386 # define DIAG_PRAGMA(x) DIAG_DO_PRAGMA(clang diagnostic x)
387 # define DIAG_OFF(x) DIAG_PRAGMA(push) DIAG_PRAGMA(ignored DIAG_JOINSTR(-W,x))
388 # define DIAG_ON(x) DIAG_PRAGMA(pop)
389 #else
390 # define DIAG_OFF(x)
391 # define DIAG_ON(x)
392 #endif
393
394 /*
395 * For dealing with APIs which are only deprecated in OSX (like the OpenSSL API)
396 */
397 #ifdef __APPLE__
398 # define USES_APPLE_DEPRECATED_API DIAG_OFF(deprecated-declarations)
399 # define USES_APPLE_RST DIAG_ON(deprecated-declarations)
400 #else
401 # define USES_APPLE_DEPRECATED_API
402 # define USES_APPLE_RST
403 #endif
404
405 /*
406 * end of Apple deprecation workaround macros
407 */
408
409 /*
410 * Function attributes, for various compilers.
411 */
412 #include "funcattrs.h"
413
414 #ifndef min
415 #define min(a,b) ((a)>(b)?(b):(a))
416 #endif
417 #ifndef max
418 #define max(a,b) ((b)>(a)?(b):(a))
419 #endif
420
421 #ifdef __ATTRIBUTE___FALLTHROUGH_OK
422 # define ND_FALL_THROUGH __attribute__ ((fallthrough))
423 #else
424 # define ND_FALL_THROUGH
425 #endif /* __ATTRIBUTE___FALLTHROUGH_OK */
426
427 #endif /* netdissect_stdinc_h */