]>
The Tcpdump Group git mirrors - tcpdump/blob - interface.h
2 * Copyright (c) 1988-2002
3 * The Regents of the University of California. All rights reserved.
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that: (1) source code distributions
7 * retain the above copyright notice and this paragraph in its entirety, (2)
8 * distributions including binary code include the above copyright notice and
9 * this paragraph in its entirety in the documentation or other materials
10 * provided with the distribution, and (3) all advertising materials mentioning
11 * features or use of this software display the following acknowledgement:
12 * ``This product includes software developed by the University of California,
13 * Lawrence Berkeley Laboratory and its contributors.'' Neither the name of
14 * the University nor the names of its contributors may be used to endorse
15 * or promote products derived from this software without specific prior
17 * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR IMPLIED
18 * WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF
19 * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
22 #ifndef tcpdump_interface_h
23 #define tcpdump_interface_h
25 #ifdef HAVE_OS_PROTO_H
37 #if !defined(HAVE_SNPRINTF)
38 int snprintf(char *, size_t, const char *, ...)
39 #ifdef __ATTRIBUTE___FORMAT_OK
40 __attribute__((format(printf
, 3, 4)))
41 #endif /* __ATTRIBUTE___FORMAT_OK */
43 #endif /* !defined(HAVE_SNPRINTF) */
45 #if !defined(HAVE_VSNPRINTF)
46 int vsnprintf(char *, size_t, const char *, va_list)
47 #ifdef __ATTRIBUTE___FORMAT_OK
48 __attribute__((format(printf
, 3, 0)))
49 #endif /* __ATTRIBUTE___FORMAT_OK */
51 #endif /* !defined(HAVE_VSNPRINTF) */
54 extern size_t strlcat(char *, const char *, size_t);
57 extern size_t strlcpy(char *, const char *, size_t);
61 extern char *strdup(const char *);
65 extern char *strsep(char **, const char *);
68 #define ESRC(ep) ((ep)->ether_shost)
69 #define EDST(ep) ((ep)->ether_dhost)
72 #define NTOHL(x) (x) = ntohl(x)
73 #define NTOHS(x) (x) = ntohs(x)
74 #define HTONL(x) (x) = htonl(x)
75 #define HTONS(x) (x) = htons(x)
79 extern char *program_name
; /* used to generate self-identifying messages */
81 extern int32_t thiszone
; /* seconds offset from gmt to local time */
83 extern int mask2plen(uint32_t);
84 extern const char *tok2strary_internal(const char **, int, const char *, int);
85 #define tok2strary(a,f,i) tok2strary_internal(a, sizeof(a)/sizeof(a[0]),f,i)
87 extern void error(const char *, ...)
88 __attribute__((noreturn
))
89 #ifdef __ATTRIBUTE___FORMAT_OK
90 __attribute__((format (printf
, 1, 2)))
91 #endif /* __ATTRIBUTE___FORMAT_OK */
93 extern void warning(const char *, ...)
94 #ifdef __ATTRIBUTE___FORMAT_OK
95 __attribute__((format (printf
, 1, 2)))
96 #endif /* __ATTRIBUTE___FORMAT_OK */
99 extern char *read_infile(char *);
100 extern char *copy_argv(char **);
102 /* The printer routines. */
107 extern int mask62plen(const u_char
*);
110 #ifndef HAVE_BPF_DUMP
113 extern void bpf_dump(const struct bpf_program
*, int);
117 #include "netdissect.h"