2004-03-25 11:29:53 +08:00
|
|
|
/*
|
|
|
|
* Copyright (c) 1988-1997
|
|
|
|
* The Regents of the University of California. All rights reserved.
|
|
|
|
*
|
2012-04-08 08:31:47 +08:00
|
|
|
* Copyright (c) 1998-2012 Michael Richardson <mcr@tcpdump.org>
|
2004-03-25 11:29:53 +08:00
|
|
|
* The TCPDUMP project
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that: (1) source code distributions
|
|
|
|
* retain the above copyright notice and this paragraph in its entirety, (2)
|
|
|
|
* distributions including binary code include the above copyright notice and
|
|
|
|
* this paragraph in its entirety in the documentation or other materials
|
|
|
|
* provided with the distribution, and (3) all advertising materials mentioning
|
|
|
|
* features or use of this software display the following acknowledgement:
|
|
|
|
* ``This product includes software developed by the University of California,
|
|
|
|
* Lawrence Berkeley Laboratory and its contributors.'' Neither the name of
|
|
|
|
* the University nor the names of its contributors may be used to endorse
|
|
|
|
* or promote products derived from this software without specific prior
|
|
|
|
* written permission.
|
|
|
|
* THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR IMPLIED
|
|
|
|
* WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF
|
|
|
|
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef netdissect_h
|
|
|
|
#define netdissect_h
|
|
|
|
|
|
|
|
#ifdef HAVE_OS_PROTO_H
|
|
|
|
#include "os-proto.h"
|
|
|
|
#endif
|
|
|
|
#include <sys/types.h>
|
2018-05-01 00:02:43 +08:00
|
|
|
#include <setjmp.h>
|
2018-02-25 18:04:39 +08:00
|
|
|
#include "status-exit-codes.h"
|
2004-03-25 11:29:53 +08:00
|
|
|
|
2015-10-07 15:14:20 +08:00
|
|
|
/*
|
|
|
|
* Data types corresponding to multi-byte integral values within data
|
|
|
|
* structures. These are defined as arrays of octets, so that they're
|
|
|
|
* not aligned on their "natural" boundaries, and so that you *must*
|
|
|
|
* use the EXTRACT_ macros to extract them (which you should be doing
|
|
|
|
* *anyway*, so as not to assume a particular byte order or alignment
|
|
|
|
* in your code).
|
2017-12-11 08:23:34 +08:00
|
|
|
*
|
|
|
|
* We even want EXTRACT_U_1 used for 8-bit integral values, so we
|
|
|
|
* define nd_uint8_t and nd_int8_t as arrays as well.
|
2015-10-07 15:14:20 +08:00
|
|
|
*/
|
2017-12-11 08:23:34 +08:00
|
|
|
typedef unsigned char nd_uint8_t[1];
|
2015-10-07 15:14:20 +08:00
|
|
|
typedef unsigned char nd_uint16_t[2];
|
|
|
|
typedef unsigned char nd_uint24_t[3];
|
|
|
|
typedef unsigned char nd_uint32_t[4];
|
|
|
|
typedef unsigned char nd_uint40_t[5];
|
|
|
|
typedef unsigned char nd_uint48_t[6];
|
|
|
|
typedef unsigned char nd_uint56_t[7];
|
|
|
|
typedef unsigned char nd_uint64_t[8];
|
|
|
|
|
2017-12-11 08:23:34 +08:00
|
|
|
typedef signed char nd_int8_t[1];
|
|
|
|
|
2017-12-19 13:41:03 +08:00
|
|
|
/*
|
|
|
|
* "unsigned char" so that sign extension isn't done on the
|
|
|
|
* individual bytes while they're being assembled.
|
|
|
|
*/
|
|
|
|
typedef unsigned char nd_int32_t[4];
|
2018-01-12 03:10:21 +08:00
|
|
|
typedef unsigned char nd_int64_t[8];
|
2017-12-19 13:41:03 +08:00
|
|
|
|
2015-10-07 15:14:20 +08:00
|
|
|
/*
|
2017-12-11 16:08:25 +08:00
|
|
|
* Use this for IPv4 addresses and netmasks.
|
|
|
|
*
|
|
|
|
* It's defined as an array of octets, so that it's not guaranteed to
|
|
|
|
* be aligned on its "natural" boundary (in some packet formats, it
|
2017-12-20 17:07:48 +08:00
|
|
|
* *isn't* so aligned). We have separate EXTRACT_ calls for them;
|
|
|
|
* sometimes you want the host-byte-order value, other times you want
|
|
|
|
* the network-byte-order value.
|
2017-11-20 03:34:23 +08:00
|
|
|
*
|
2017-12-20 17:07:48 +08:00
|
|
|
* Don't use EXTRACT_BE_U_4() on them, use EXTRACT_IPV4_TO_HOST_ORDER()
|
|
|
|
* if you want them in host byte order and EXTRACT_IPV4_TO_NETWORK_ORDER()
|
|
|
|
* if you want them in network byte order (which you want with system APIs
|
|
|
|
* that expect network-order IPv4 addresses, such as inet_ntop()).
|
|
|
|
*
|
|
|
|
* If, on your little-endian machine (e.g., an "IBM-compatible PC", no matter
|
|
|
|
* what the OS, or an Intel Mac, no matter what the OS), you get the wrong
|
|
|
|
* answer, and you've used EXTRACT_BE_U_4(), do *N*O*T* "fix" this by using
|
|
|
|
* EXTRACT_LE_U_4(), fix it by using EXTRACT_IPV4_TO_NETWORK_ORDER(),
|
|
|
|
* otherwise you're breaking the result on big-endian machines (e.g.,
|
|
|
|
* most PowerPC/Power ISA machines, System/390 and z/Architecture, SPARC,
|
|
|
|
* etc.).
|
|
|
|
*
|
|
|
|
* Yes, people do this; that's why Wireshark has tvb_get_ipv4(), to extract
|
|
|
|
* an IPv4 address from a packet data buffer; it was introduced in reaction
|
|
|
|
* to somebody who *had* done that.
|
2015-10-07 15:14:20 +08:00
|
|
|
*/
|
2017-12-20 17:07:48 +08:00
|
|
|
typedef unsigned char nd_ipv4[4];
|
2015-10-07 15:14:20 +08:00
|
|
|
|
2017-12-11 16:08:25 +08:00
|
|
|
/*
|
|
|
|
* Use this for IPv6 addresses and netmasks.
|
|
|
|
*/
|
2017-12-20 17:07:48 +08:00
|
|
|
typedef unsigned char nd_ipv6[16];
|
2017-12-11 16:08:25 +08:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Use this for MAC addresses.
|
|
|
|
*/
|
2017-12-13 02:36:21 +08:00
|
|
|
#define MAC_ADDR_LEN 6 /* length of MAC addresses */
|
|
|
|
typedef unsigned char nd_mac_addr[MAC_ADDR_LEN];
|
2017-12-11 16:08:25 +08:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Use this for blobs of bytes; make them arrays of nd_byte.
|
|
|
|
*/
|
|
|
|
typedef unsigned char nd_byte;
|
|
|
|
|
2018-06-23 02:18:20 +08:00
|
|
|
/*
|
|
|
|
* Round up x to a multiple of y; y must be a power of 2.
|
|
|
|
*/
|
|
|
|
#ifndef roundup2
|
|
|
|
#define roundup2(x, y) (((x)+((y)-1))&(~((y)-1)))
|
|
|
|
#endif
|
|
|
|
|
2018-01-30 07:48:55 +08:00
|
|
|
/* nd_snprintf et al */
|
2004-03-25 11:29:53 +08:00
|
|
|
|
|
|
|
#include <stdarg.h>
|
2015-09-14 21:34:13 +08:00
|
|
|
#include <pcap.h>
|
2004-03-25 11:29:53 +08:00
|
|
|
|
2014-03-26 19:47:29 +08:00
|
|
|
#include "ip.h" /* struct ip for nextproto4_cksum() */
|
2016-02-13 12:26:39 +08:00
|
|
|
#include "ip6.h" /* struct ip6 for nextproto6_cksum() */
|
2014-03-26 19:47:29 +08:00
|
|
|
|
2004-03-25 11:29:53 +08:00
|
|
|
#ifndef HAVE_STRLCAT
|
|
|
|
extern size_t strlcat (char *, const char *, size_t);
|
|
|
|
#endif
|
|
|
|
#ifndef HAVE_STRLCPY
|
|
|
|
extern size_t strlcpy (char *, const char *, size_t);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef HAVE_STRDUP
|
|
|
|
extern char *strdup (const char *str);
|
|
|
|
#endif
|
|
|
|
|
2004-07-22 06:00:10 +08:00
|
|
|
#ifndef HAVE_STRSEP
|
|
|
|
extern char *strsep(char **, const char *);
|
|
|
|
#endif
|
|
|
|
|
2004-03-25 11:29:53 +08:00
|
|
|
struct tok {
|
2014-02-26 18:49:56 +08:00
|
|
|
u_int v; /* value */
|
2004-03-25 11:29:53 +08:00
|
|
|
const char *s; /* string */
|
|
|
|
};
|
|
|
|
|
2018-12-11 14:01:39 +08:00
|
|
|
extern const char *tok2strbuf(const struct tok *, const char *, u_int,
|
|
|
|
char *buf, size_t bufsize);
|
2004-04-29 10:15:41 +08:00
|
|
|
|
|
|
|
/* tok2str is deprecated */
|
2018-12-11 14:01:39 +08:00
|
|
|
extern const char *tok2str(const struct tok *, const char *, u_int);
|
|
|
|
extern char *bittok2str(const struct tok *, const char *, u_int);
|
|
|
|
extern char *bittok2str_nosep(const struct tok *, const char *, u_int);
|
2004-03-25 11:29:53 +08:00
|
|
|
|
2016-08-05 04:19:57 +08:00
|
|
|
/* Initialize netdissect. */
|
|
|
|
extern int nd_init(char *, size_t);
|
|
|
|
/* Clean up netdissect. */
|
|
|
|
extern void nd_cleanup(void);
|
|
|
|
|
2016-08-05 05:35:35 +08:00
|
|
|
/* Do we have libsmi support? */
|
|
|
|
extern int nd_have_smi_support(void);
|
|
|
|
/* Load an SMI module. */
|
|
|
|
extern int nd_load_smi_module(const char *, char *, size_t);
|
|
|
|
/* Flag indicating whether an SMI module has been loaded. */
|
|
|
|
extern int nd_smi_module_loaded;
|
|
|
|
/* Version number of the SMI library, or NULL if we don't have libsmi support. */
|
|
|
|
extern const char *nd_smi_version_string(void);
|
|
|
|
|
2004-03-25 11:29:53 +08:00
|
|
|
typedef struct netdissect_options netdissect_options;
|
|
|
|
|
2015-09-18 21:14:31 +08:00
|
|
|
#define IF_PRINTER_ARGS (netdissect_options *, const struct pcap_pkthdr *, const u_char *)
|
|
|
|
|
|
|
|
typedef u_int (*if_printer) IF_PRINTER_ARGS;
|
2015-09-14 21:34:13 +08:00
|
|
|
|
2019-03-31 10:26:06 +08:00
|
|
|
/*
|
|
|
|
* In case the data in a buffer needs to be processed by being decrypted,
|
|
|
|
* decompressed, etc. before it's dissected, we can't process it in place,
|
|
|
|
* we have to allocate a new buffer for the processed data.
|
|
|
|
*
|
|
|
|
* We keep a stack of those buffers; when we allocate a new buffer, we
|
|
|
|
* push the current one onto a stack, and when we're done with the new
|
|
|
|
* buffer, we free the current buffer and pop the previous one off the
|
|
|
|
* stack.
|
|
|
|
*
|
|
|
|
* A buffer has a beginnning and end pointer, and a link to the previous
|
|
|
|
* buffer on the stack.
|
|
|
|
*/
|
|
|
|
struct netdissect_saved_info {
|
|
|
|
u_char *ndsi_buffer; /* pointer to allocated buffer data */
|
|
|
|
const u_char *ndsi_packetp; /* saved beginning of data */
|
|
|
|
const u_char *ndsi_snapend; /* saved end of data */
|
|
|
|
struct netdissect_saved_info *ndsi_prev; /* previous buffer on the stack */
|
|
|
|
};
|
|
|
|
|
2004-03-25 11:29:53 +08:00
|
|
|
struct netdissect_options {
|
2009-01-21 04:40:22 +08:00
|
|
|
int ndo_bflag; /* print 4 byte ASes in ASDOT notation */
|
2004-03-25 11:29:53 +08:00
|
|
|
int ndo_eflag; /* print ethernet header */
|
|
|
|
int ndo_fflag; /* don't translate "foreign" IP address */
|
2017-09-21 02:45:37 +08:00
|
|
|
int ndo_Kflag; /* don't check IP, TCP or UDP checksums */
|
2004-03-25 11:29:53 +08:00
|
|
|
int ndo_nflag; /* leave addresses as numbers */
|
|
|
|
int ndo_Nflag; /* remove domains from printed host names */
|
|
|
|
int ndo_qflag; /* quick (shorter) output */
|
|
|
|
int ndo_Sflag; /* print raw TCP sequence numbers */
|
|
|
|
int ndo_tflag; /* print packet arrival time */
|
|
|
|
int ndo_uflag; /* Print undecoded NFS handles */
|
2015-09-09 04:37:54 +08:00
|
|
|
int ndo_vflag; /* verbosity level */
|
2004-03-25 11:29:53 +08:00
|
|
|
int ndo_xflag; /* print packet in hex */
|
2017-08-10 16:52:46 +08:00
|
|
|
int ndo_Xflag; /* print packet in hex/ASCII */
|
|
|
|
int ndo_Aflag; /* print packet only in ASCII observing TAB,
|
2004-03-25 11:29:53 +08:00
|
|
|
* LF, CR and SPACE as graphical chars
|
|
|
|
*/
|
2011-06-22 09:15:50 +08:00
|
|
|
int ndo_Hflag; /* dissect 802.11s draft mesh standard */
|
2018-03-14 23:54:17 +08:00
|
|
|
const char *ndo_protocol; /* protocol */
|
2018-05-01 00:02:43 +08:00
|
|
|
jmp_buf ndo_truncated; /* jmp_buf for setjmp()/longjmp() */
|
2018-03-14 20:41:33 +08:00
|
|
|
void *ndo_last_mem_p; /* pointer to the last allocated memory chunk */
|
2014-05-06 18:07:55 +08:00
|
|
|
int ndo_packet_number; /* print a packet number in the beginning of line */
|
2005-07-07 09:22:15 +08:00
|
|
|
int ndo_suppress_default_print; /* don't use default_print() for unknown packet types */
|
2015-09-08 01:04:50 +08:00
|
|
|
int ndo_tstamp_precision; /* requested time stamp precision */
|
|
|
|
const char *program_name; /* Name of the program using the library */
|
2004-03-25 11:29:53 +08:00
|
|
|
|
|
|
|
char *ndo_espsecret;
|
2004-04-05 08:15:50 +08:00
|
|
|
struct sa_list *ndo_sa_list_head; /* used by print-esp.c */
|
|
|
|
struct sa_list *ndo_sa_default;
|
|
|
|
|
2015-09-08 01:04:50 +08:00
|
|
|
char *ndo_sigsecret; /* Signature verification secret key */
|
2004-03-25 11:29:53 +08:00
|
|
|
|
|
|
|
int ndo_packettype; /* as specified by -T */
|
|
|
|
|
|
|
|
int ndo_snaplen;
|
|
|
|
|
|
|
|
/*global pointers to beginning and end of current packet (during printing) */
|
|
|
|
const u_char *ndo_packetp;
|
|
|
|
const u_char *ndo_snapend;
|
|
|
|
|
2019-03-31 10:26:06 +08:00
|
|
|
/* stack of saved buffer information */
|
|
|
|
struct netdissect_saved_info *ndo_buffer_stack;
|
|
|
|
|
2015-09-14 21:34:13 +08:00
|
|
|
/* pointer to the if_printer function */
|
|
|
|
if_printer ndo_if_printer;
|
|
|
|
|
2004-03-25 11:29:53 +08:00
|
|
|
/* pointer to void function to output stuff */
|
|
|
|
void (*ndo_default_print)(netdissect_options *,
|
2017-12-14 02:17:47 +08:00
|
|
|
const u_char *bp, u_int length);
|
2014-07-08 10:05:14 +08:00
|
|
|
|
|
|
|
/* pointer to function to do regular output */
|
2004-03-25 11:29:53 +08:00
|
|
|
int (*ndo_printf)(netdissect_options *,
|
2009-05-25 05:06:10 +08:00
|
|
|
const char *fmt, ...)
|
2017-08-20 02:25:24 +08:00
|
|
|
PRINTFLIKE_FUNCPTR(2, 3);
|
2014-07-08 10:05:14 +08:00
|
|
|
/* pointer to function to output errors */
|
2017-08-20 02:25:24 +08:00
|
|
|
void NORETURN_FUNCPTR (*ndo_error)(netdissect_options *,
|
2018-02-25 18:04:39 +08:00
|
|
|
status_exit_codes_t status,
|
2017-08-20 02:25:24 +08:00
|
|
|
const char *fmt, ...)
|
2018-02-25 18:04:39 +08:00
|
|
|
PRINTFLIKE_FUNCPTR(3, 4);
|
2014-07-08 10:05:14 +08:00
|
|
|
/* pointer to function to output warnings */
|
2004-04-05 08:15:50 +08:00
|
|
|
void (*ndo_warning)(netdissect_options *,
|
2009-05-25 05:06:10 +08:00
|
|
|
const char *fmt, ...)
|
2017-08-20 02:25:24 +08:00
|
|
|
PRINTFLIKE_FUNCPTR(2, 3);
|
2004-03-25 11:29:53 +08:00
|
|
|
};
|
|
|
|
|
2019-03-31 10:26:06 +08:00
|
|
|
extern int nd_push_buffer(netdissect_options *, u_char *, const u_char *,
|
|
|
|
const u_char *);
|
|
|
|
extern void nd_pop_buffer(netdissect_options *);
|
|
|
|
extern void nd_pop_all_buffers(netdissect_options *);
|
|
|
|
|
2004-03-25 11:29:53 +08:00
|
|
|
#define PT_VAT 1 /* Visual Audio Tool */
|
|
|
|
#define PT_WB 2 /* distributed White Board */
|
|
|
|
#define PT_RPC 3 /* Remote Procedure Call */
|
|
|
|
#define PT_RTP 4 /* Real-Time Applications protocol */
|
|
|
|
#define PT_RTCP 5 /* Real-Time Applications control protocol */
|
|
|
|
#define PT_SNMP 6 /* Simple Network Management Protocol */
|
|
|
|
#define PT_CNFP 7 /* Cisco NetFlow protocol */
|
2012-07-01 06:59:18 +08:00
|
|
|
#define PT_TFTP 8 /* trivial file transfer protocol */
|
|
|
|
#define PT_AODV 9 /* Ad-hoc On-demand Distance Vector Protocol */
|
2013-02-09 16:08:34 +08:00
|
|
|
#define PT_CARP 10 /* Common Address Redundancy Protocol */
|
|
|
|
#define PT_RADIUS 11 /* RADIUS authentication Protocol */
|
2013-02-09 21:36:24 +08:00
|
|
|
#define PT_ZMTP1 12 /* ZeroMQ Message Transport Protocol 1.0 */
|
2013-02-26 20:44:11 +08:00
|
|
|
#define PT_VXLAN 13 /* Virtual eXtensible Local Area Network */
|
2013-03-15 01:17:53 +08:00
|
|
|
#define PT_PGM 14 /* [UDP-encapsulated] Pragmatic General Multicast */
|
2013-03-15 01:59:38 +08:00
|
|
|
#define PT_PGM_ZMTP1 15 /* ZMTP/1.0 inside PGM (native or UDP-encapsulated) */
|
2013-09-07 16:22:37 +08:00
|
|
|
#define PT_LMP 16 /* Link Management Protocol */
|
2016-01-13 01:32:55 +08:00
|
|
|
#define PT_RESP 17 /* RESP */
|
2004-03-25 11:29:53 +08:00
|
|
|
|
|
|
|
#ifndef min
|
|
|
|
#define min(a,b) ((a)>(b)?(b):(a))
|
|
|
|
#endif
|
|
|
|
#ifndef max
|
|
|
|
#define max(a,b) ((b)>(a)?(b):(a))
|
|
|
|
#endif
|
|
|
|
|
2015-12-15 03:28:14 +08:00
|
|
|
/* For source or destination ports tests (UDP, TCP, ...) */
|
|
|
|
#define IS_SRC_OR_DST_PORT(p) (sport == (p) || dport == (p))
|
|
|
|
|
2004-03-25 11:29:53 +08:00
|
|
|
/*
|
2009-03-05 17:01:29 +08:00
|
|
|
* Maximum snapshot length. This should be enough to capture the full
|
|
|
|
* packet on most network interfaces.
|
|
|
|
*
|
2014-06-26 04:41:22 +08:00
|
|
|
*
|
|
|
|
* Somewhat arbitrary, but chosen to be:
|
|
|
|
*
|
|
|
|
* 1) big enough for maximum-size Linux loopback packets (65549)
|
|
|
|
* and some USB packets captured with USBPcap:
|
|
|
|
*
|
|
|
|
* http://desowin.org/usbpcap/
|
|
|
|
*
|
|
|
|
* (> 131072, < 262144)
|
|
|
|
*
|
|
|
|
* and
|
|
|
|
*
|
|
|
|
* 2) small enough not to cause attempts to allocate huge amounts of
|
|
|
|
* memory; some applications might use the snapshot length in a
|
|
|
|
* savefile header to control the size of the buffer they allocate,
|
|
|
|
* so a size of, say, 2^31-1 might not work well.
|
2014-06-26 04:18:18 +08:00
|
|
|
*
|
2017-06-03 12:50:45 +08:00
|
|
|
* XXX - does it need to be bigger still? Note that, for versions of
|
|
|
|
* libpcap with pcap_create()/pcap_activate(), if no -s flag is specified
|
|
|
|
* or -s 0 is specified, we won't set the snapshot length at all, and will
|
|
|
|
* let libpcap choose a snapshot length; newer versions may choose a bigger
|
|
|
|
* value than 262144 for D-Bus, for example.
|
2004-03-25 11:29:53 +08:00
|
|
|
*/
|
2014-06-26 04:41:22 +08:00
|
|
|
#define MAXIMUM_SNAPLEN 262144
|
2009-03-05 17:01:29 +08:00
|
|
|
|
2004-07-22 06:00:10 +08:00
|
|
|
/*
|
2018-09-22 21:19:44 +08:00
|
|
|
* True if "l" bytes from "p" were captured.
|
2004-07-22 06:00:10 +08:00
|
|
|
*
|
|
|
|
* The "ndo->ndo_snapend - (l) <= ndo->ndo_snapend" checks to make sure
|
|
|
|
* "l" isn't so large that "ndo->ndo_snapend - (l)" underflows.
|
|
|
|
*
|
|
|
|
* The check is for <= rather than < because "l" might be 0.
|
2015-03-03 05:25:12 +08:00
|
|
|
*
|
|
|
|
* We cast the pointers to uintptr_t to make sure that the compiler
|
|
|
|
* doesn't optimize away any of these tests (which it is allowed to
|
|
|
|
* do, as adding an integer to, or subtracting an integer from, a
|
|
|
|
* pointer assumes that the pointer is a pointer to an element of an
|
|
|
|
* array and that the result of the addition or subtraction yields a
|
|
|
|
* pointer to another member of the array, so that, for example, if
|
|
|
|
* you subtract a positive integer from a pointer, the result is
|
|
|
|
* guaranteed to be less than the original pointer value). See
|
|
|
|
*
|
|
|
|
* http://www.kb.cert.org/vuls/id/162289
|
2004-07-22 06:00:10 +08:00
|
|
|
*/
|
2015-04-28 00:20:59 +08:00
|
|
|
|
2015-04-28 12:17:16 +08:00
|
|
|
/*
|
|
|
|
* Test in two parts to avoid these warnings:
|
|
|
|
* comparison of unsigned expression >= 0 is always true [-Wtype-limits],
|
|
|
|
* comparison is always true due to limited range of data type [-Wtype-limits].
|
|
|
|
*/
|
2015-04-28 00:20:59 +08:00
|
|
|
#define IS_NOT_NEGATIVE(x) (((x) > 0) || ((x) == 0))
|
|
|
|
|
2017-12-11 19:46:51 +08:00
|
|
|
#define ND_TTEST_LEN(p, l) \
|
|
|
|
(IS_NOT_NEGATIVE(l) && \
|
|
|
|
((uintptr_t)ndo->ndo_snapend - (l) <= (uintptr_t)ndo->ndo_snapend && \
|
|
|
|
(uintptr_t)(p) <= (uintptr_t)ndo->ndo_snapend - (l)))
|
|
|
|
|
2018-01-02 22:50:24 +08:00
|
|
|
/* True if "*(p)" was captured */
|
|
|
|
#define ND_TTEST_SIZE(p) ND_TTEST_LEN(p, sizeof(*(p)))
|
|
|
|
|
|
|
|
/* Bail out if "l" bytes from "p" were not captured */
|
2017-12-11 19:46:51 +08:00
|
|
|
#define ND_TCHECK_LEN(p, l) if (!ND_TTEST_LEN(p, l)) goto trunc
|
|
|
|
|
2018-01-02 22:50:24 +08:00
|
|
|
/* Bail out if "*(p)" was not captured */
|
|
|
|
#define ND_TCHECK_SIZE(p) ND_TCHECK_LEN(p, sizeof(*(p)))
|
|
|
|
|
2018-01-07 18:47:30 +08:00
|
|
|
#define ND_PRINT(...) (ndo->ndo_printf)(ndo, __VA_ARGS__)
|
2004-05-01 00:42:14 +08:00
|
|
|
#define ND_DEFAULTPRINT(ap, length) (*ndo->ndo_default_print)(ndo, ap, length)
|
2004-03-25 11:29:53 +08:00
|
|
|
|
2014-04-03 21:40:30 +08:00
|
|
|
extern void ts_print(netdissect_options *, const struct timeval *);
|
2015-08-09 03:53:36 +08:00
|
|
|
extern void signed_relts_print(netdissect_options *, int32_t);
|
|
|
|
extern void unsigned_relts_print(netdissect_options *, uint32_t);
|
2004-03-25 11:29:53 +08:00
|
|
|
|
2015-11-09 22:59:58 +08:00
|
|
|
extern void fn_print_char(netdissect_options *, u_char);
|
2018-05-19 04:18:46 +08:00
|
|
|
extern void fn_print_str(netdissect_options *, const u_char *);
|
2018-04-30 18:52:10 +08:00
|
|
|
extern int nd_print(netdissect_options *, const u_char *, const u_char *);
|
2019-03-31 20:36:49 +08:00
|
|
|
extern u_int nd_printztn(netdissect_options *, const u_char *, u_int, const u_char *);
|
2018-04-30 18:52:10 +08:00
|
|
|
extern int nd_printn(netdissect_options *, const u_char *, u_int, const u_char *);
|
|
|
|
extern int nd_printzp(netdissect_options *, const u_char *, u_int, const u_char *);
|
2004-03-25 11:29:53 +08:00
|
|
|
|
2014-10-20 04:46:22 +08:00
|
|
|
/*
|
|
|
|
* Flags for txtproto_print().
|
|
|
|
*/
|
|
|
|
#define RESP_CODE_SECOND_TOKEN 0x00000001 /* response code is second token in response line */
|
2014-10-20 02:21:44 +08:00
|
|
|
|
|
|
|
extern void txtproto_print(netdissect_options *, const u_char *, u_int,
|
2019-03-08 05:20:34 +08:00
|
|
|
const char **, u_int);
|
2014-10-20 02:21:44 +08:00
|
|
|
|
2014-02-03 07:17:06 +08:00
|
|
|
/*
|
|
|
|
* Locale-independent macros for testing character properties and
|
2018-12-11 15:16:45 +08:00
|
|
|
* stripping the 8th bit from characters.
|
|
|
|
*
|
|
|
|
* Byte values outside the ASCII range are considered unprintable, so
|
|
|
|
* both ND_ISPRINT() and ND_ISGRAPH() return "false" for them.
|
|
|
|
*
|
|
|
|
* Assumed to be handed a value between 0 and 255, i.e. don't hand them
|
|
|
|
* a char, as those might be in the range -128 to 127.
|
2014-02-03 07:17:06 +08:00
|
|
|
*/
|
|
|
|
#define ND_ISASCII(c) (!((c) & 0x80)) /* value is an ASCII code point */
|
|
|
|
#define ND_ISPRINT(c) ((c) >= 0x20 && (c) <= 0x7E)
|
|
|
|
#define ND_ISGRAPH(c) ((c) > 0x20 && (c) <= 0x7E)
|
|
|
|
#define ND_TOASCII(c) ((c) & 0x7F)
|
|
|
|
|
2018-12-11 15:16:45 +08:00
|
|
|
/*
|
|
|
|
* Locale-independent macros for coverting to upper or lower case.
|
|
|
|
*
|
|
|
|
* Byte values outside the ASCII range are not converted. Byte values
|
|
|
|
* *in* the ASCII range are converted to byte values in the ASCII range;
|
|
|
|
* in particular, 'i' is upper-cased to 'I" and 'I' is lower-cased to 'i',
|
|
|
|
* even in Turkish locales.
|
|
|
|
*
|
|
|
|
* Assumed to be handed a value between 0 and 255, i.e. don't hand
|
|
|
|
* them a char, as those might be in the range -128 to 127.
|
|
|
|
*/
|
|
|
|
#define ND_TOLOWER(c) (((c) >= 'A' && (c) <= 'Z') ? (c) - 'A' + 'a' : (c))
|
2018-12-11 15:26:25 +08:00
|
|
|
#define ND_TOUPPER(c) (((c) >= 'a' && (c) <= 'z') ? (c) - 'a' + 'A' : (c))
|
2018-12-11 15:16:45 +08:00
|
|
|
|
2017-10-16 16:39:10 +08:00
|
|
|
#if (defined(__i386__) || defined(_M_IX86) || defined(__X86__) || defined(__x86_64__) || defined(_M_X64)) || \
|
|
|
|
(defined(__arm__) || defined(_M_ARM) || defined(__aarch64__)) || \
|
|
|
|
(defined(__m68k__) && (!defined(__mc68000__) && !defined(__mc68010__))) || \
|
|
|
|
(defined(__ppc__) || defined(__ppc64__) || defined(_M_PPC) || defined(_ARCH_PPC) || defined(_ARCH_PPC64)) || \
|
|
|
|
(defined(__s390__) || defined(__s390x__) || defined(__zarch__)) || \
|
|
|
|
defined(__vax__)
|
|
|
|
/*
|
|
|
|
* The procesor natively handles unaligned loads, so just use memcpy()
|
|
|
|
* and memcmp(), to enable those optimizations.
|
|
|
|
*
|
|
|
|
* XXX - are those all the x86 tests we need?
|
|
|
|
* XXX - do we need to worry about ARMv1 through ARMv5, which didn't
|
|
|
|
* support unaligned loads, and, if so, do we need to worry about all
|
|
|
|
* of them, or just some of them, e.g. ARMv5?
|
|
|
|
* XXX - are those the only 68k tests we need not to generated
|
|
|
|
* unaligned accesses if the target is the 68000 or 68010?
|
|
|
|
* XXX - are there any tests we don't need, because some definitions are for
|
|
|
|
* compilers that also predefine the GCC symbols?
|
|
|
|
* XXX - do we need to test for both 32-bit and 64-bit versions of those
|
|
|
|
* architectures in all cases?
|
|
|
|
*/
|
|
|
|
#define UNALIGNED_MEMCPY(p, q, l) memcpy((p), (q), (l))
|
|
|
|
#define UNALIGNED_MEMCMP(p, q, l) memcmp((p), (q), (l))
|
|
|
|
#else
|
2014-01-18 09:51:04 +08:00
|
|
|
/*
|
|
|
|
* The processor doesn't natively handle unaligned loads,
|
|
|
|
* and the compiler might "helpfully" optimize memcpy()
|
|
|
|
* and memcmp(), when handed pointers that would normally
|
|
|
|
* be properly aligned, into sequences that assume proper
|
|
|
|
* alignment.
|
|
|
|
*
|
|
|
|
* Do copies and compares of possibly-unaligned data by
|
|
|
|
* calling routines that wrap memcpy() and memcmp(), to
|
|
|
|
* prevent that optimization.
|
|
|
|
*/
|
2014-01-16 10:12:06 +08:00
|
|
|
extern void unaligned_memcpy(void *, const void *, size_t);
|
2014-01-16 15:03:31 +08:00
|
|
|
extern int unaligned_memcmp(const void *, const void *, size_t);
|
2014-01-18 09:51:04 +08:00
|
|
|
#define UNALIGNED_MEMCPY(p, q, l) unaligned_memcpy((p), (q), (l))
|
|
|
|
#define UNALIGNED_MEMCMP(p, q, l) unaligned_memcmp((p), (q), (l))
|
|
|
|
#endif
|
2014-01-16 10:12:06 +08:00
|
|
|
|
2011-03-09 01:11:25 +08:00
|
|
|
#define PLURAL_SUFFIX(n) \
|
|
|
|
(((n) != 1) ? "s" : "")
|
|
|
|
|
2015-06-11 03:12:38 +08:00
|
|
|
extern const char *tok2strary_internal(const char **, int, const char *, int);
|
|
|
|
#define tok2strary(a,f,i) tok2strary_internal(a, sizeof(a)/sizeof(a[0]),f,i)
|
|
|
|
|
2011-05-05 17:25:42 +08:00
|
|
|
extern if_printer lookup_printer(int);
|
2004-03-25 11:29:53 +08:00
|
|
|
|
2018-09-05 03:50:33 +08:00
|
|
|
#define ND_DEBUG {printf(" [%s:%d %s] ", __FILE__, __LINE__, __FUNCTION__); fflush(stdout);}
|
|
|
|
|
2015-09-18 21:14:31 +08:00
|
|
|
/* The DLT printer routines */
|
|
|
|
|
|
|
|
extern u_int ap1394_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int arcnet_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int arcnet_linux_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int atm_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int bt_if_print IF_PRINTER_ARGS;
|
2019-01-19 07:24:33 +08:00
|
|
|
extern u_int brcm_tag_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int brcm_tag_prepend_if_print IF_PRINTER_ARGS;
|
2015-09-18 21:14:31 +08:00
|
|
|
extern u_int chdlc_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int cip_if_print IF_PRINTER_ARGS;
|
2019-04-06 23:16:54 +08:00
|
|
|
extern u_int dsa_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int edsa_if_print IF_PRINTER_ARGS;
|
2015-09-18 21:14:31 +08:00
|
|
|
extern u_int enc_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int ether_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int fddi_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int fr_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int ieee802_11_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int ieee802_11_radio_avs_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int ieee802_11_radio_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int ieee802_15_4_if_print IF_PRINTER_ARGS;
|
2019-02-16 04:27:46 +08:00
|
|
|
extern u_int ieee802_15_4_tap_if_print IF_PRINTER_ARGS;
|
2015-09-18 21:14:31 +08:00
|
|
|
extern u_int ipfc_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int ipnet_if_print IF_PRINTER_ARGS;
|
2017-11-16 14:15:35 +08:00
|
|
|
extern u_int juniper_atm1_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int juniper_atm2_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int juniper_chdlc_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int juniper_es_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int juniper_ether_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int juniper_frelay_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int juniper_ggsn_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int juniper_mfr_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int juniper_mlfr_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int juniper_mlppp_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int juniper_monitor_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int juniper_ppp_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int juniper_pppoe_atm_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int juniper_pppoe_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int juniper_services_if_print IF_PRINTER_ARGS;
|
2015-09-18 21:14:31 +08:00
|
|
|
extern u_int lane_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int ltalk_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int mfr_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int netanalyzer_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int netanalyzer_transparent_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int nflog_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int null_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int pflog_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int pktap_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int ppi_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int ppp_bsdos_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int ppp_hdlc_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int ppp_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int pppoe_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int prism_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int raw_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int sl_bsdos_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int sl_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int sll_if_print IF_PRINTER_ARGS;
|
2018-07-13 02:49:28 +08:00
|
|
|
extern u_int sll2_if_print IF_PRINTER_ARGS;
|
2015-09-18 21:14:31 +08:00
|
|
|
extern u_int sunatm_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int symantec_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int token_if_print IF_PRINTER_ARGS;
|
2017-11-16 14:15:35 +08:00
|
|
|
extern u_int usb_linux_48_byte_if_print IF_PRINTER_ARGS;
|
|
|
|
extern u_int usb_linux_64_byte_if_print IF_PRINTER_ARGS;
|
2016-06-14 22:45:44 +08:00
|
|
|
extern u_int vsock_if_print IF_PRINTER_ARGS;
|
2010-10-08 02:36:49 +08:00
|
|
|
|
2015-07-04 06:54:14 +08:00
|
|
|
/*
|
|
|
|
* Structure passed to some printers to allow them to print
|
|
|
|
* link-layer address information if ndo_eflag isn't set
|
|
|
|
* (because they are for protocols that don't have their
|
|
|
|
* own addresses, so that we'd want to report link-layer
|
|
|
|
* address information).
|
|
|
|
*
|
|
|
|
* This contains a pointer to an address and a pointer to a routine
|
|
|
|
* to which we pass that pointer in order to get a string.
|
|
|
|
*/
|
|
|
|
struct lladdr_info {
|
|
|
|
const char *(*addr_string)(netdissect_options *, const u_char *);
|
|
|
|
const u_char *addr;
|
|
|
|
};
|
|
|
|
|
2015-09-18 21:14:31 +08:00
|
|
|
/* The printer routines. */
|
2014-03-13 15:06:15 +08:00
|
|
|
|
2015-09-18 21:14:31 +08:00
|
|
|
extern void aarp_print(netdissect_options *, const u_char *, u_int);
|
2017-12-14 02:17:47 +08:00
|
|
|
extern int ah_print(netdissect_options *, const u_char *);
|
2014-03-08 19:28:13 +08:00
|
|
|
extern void ahcp_print(netdissect_options *, const u_char *, const u_int);
|
2015-09-18 21:14:31 +08:00
|
|
|
extern void aodv_print(netdissect_options *, const u_char *, u_int, int);
|
|
|
|
extern void aoe_print(netdissect_options *, const u_char *, const u_int);
|
|
|
|
extern void arp_print(netdissect_options *, const u_char *, u_int, u_int);
|
|
|
|
extern void ascii_print(netdissect_options *, const u_char *, u_int);
|
|
|
|
extern void atalk_print(netdissect_options *, const u_char *, u_int);
|
|
|
|
extern void atm_print(netdissect_options *, u_int, u_int, u_int, const u_char *, u_int, u_int);
|
|
|
|
extern void babel_print(netdissect_options *, const u_char *, u_int);
|
|
|
|
extern void beep_print(netdissect_options *, const u_char *, u_int);
|
2014-03-11 20:08:24 +08:00
|
|
|
extern void bfd_print(netdissect_options *, const u_char *, u_int, u_int);
|
2017-12-17 02:50:00 +08:00
|
|
|
extern void bgp_print(netdissect_options *, const u_char *, u_int);
|
2018-03-16 17:39:25 +08:00
|
|
|
extern const char *bgp_vpn_rd_print(netdissect_options *, const u_char *);
|
2015-09-18 21:14:31 +08:00
|
|
|
extern void bootp_print(netdissect_options *, const u_char *, u_int);
|
2015-07-04 06:54:14 +08:00
|
|
|
extern void calm_fast_print(netdissect_options *, const u_char *, u_int, const struct lladdr_info *);
|
2018-01-12 03:52:30 +08:00
|
|
|
extern void carp_print(netdissect_options *, const u_char *, u_int, u_int);
|
2015-09-18 21:14:31 +08:00
|
|
|
extern void cdp_print(netdissect_options *, const u_char *, u_int, u_int);
|
|
|
|
extern void cfm_print(netdissect_options *, const u_char *, u_int);
|
2017-12-14 02:17:47 +08:00
|
|
|
extern u_int chdlc_print(netdissect_options *, const u_char *, u_int);
|
2015-09-18 21:14:31 +08:00
|
|
|
extern void cisco_autorp_print(netdissect_options *, const u_char *, u_int);
|
2014-11-10 15:24:53 +08:00
|
|
|
extern void cnfp_print(netdissect_options *, const u_char *);
|
2015-09-18 21:14:31 +08:00
|
|
|
extern void dccp_print(netdissect_options *, const u_char *, const u_char *, u_int);
|
|
|
|
extern void decnet_print(netdissect_options *, const u_char *, u_int, u_int);
|
|
|
|
extern void dhcp6_print(netdissect_options *, const u_char *, u_int);
|
|
|
|
extern int dstopt_print(netdissect_options *, const u_char *);
|
|
|
|
extern void dtp_print(netdissect_options *, const u_char *, u_int);
|
2014-03-21 20:48:24 +08:00
|
|
|
extern void dvmrp_print(netdissect_options *, const u_char *, u_int);
|
2015-09-18 21:14:31 +08:00
|
|
|
extern void eap_print(netdissect_options *, const u_char *, u_int);
|
2014-03-21 20:48:24 +08:00
|
|
|
extern void egp_print(netdissect_options *, const u_char *, u_int);
|
2015-09-18 21:14:31 +08:00
|
|
|
extern void eigrp_print(netdissect_options *, const u_char *, u_int);
|
2019-03-29 02:45:43 +08:00
|
|
|
extern void esp_print(netdissect_options *, const u_char *, u_int, const u_char *, u_int, int, u_int);
|
2015-09-18 21:14:31 +08:00
|
|
|
extern u_int ether_print(netdissect_options *, const u_char *, u_int, u_int, void (*)(netdissect_options *, const u_char *), const u_char *);
|
2019-04-04 02:59:41 +08:00
|
|
|
extern u_int ether_hdr_len_print(netdissect_options *, const u_char *, u_int, u_int, void (*)(netdissect_options *, const u_char *), const u_char *, u_int);
|
2015-07-04 06:54:14 +08:00
|
|
|
extern int ethertype_print(netdissect_options *, u_short, const u_char *, u_int, u_int, const struct lladdr_info *, const struct lladdr_info *);
|
2015-09-18 21:14:31 +08:00
|
|
|
extern u_int fddi_print(netdissect_options *, const u_char *, u_int, u_int);
|
2014-03-27 18:58:23 +08:00
|
|
|
extern void forces_print(netdissect_options *, const u_char *, u_int);
|
2017-12-14 02:17:47 +08:00
|
|
|
extern u_int fr_print(netdissect_options *, const u_char *, u_int);
|
2015-09-18 21:14:31 +08:00
|
|
|
extern int frag6_print(netdissect_options *, const u_char *, const u_char *);
|
|
|
|
extern void ftp_print(netdissect_options *, const u_char *, u_int);
|
|
|
|
extern void geneve_print(netdissect_options *, const u_char *, u_int);
|
2015-07-04 06:54:14 +08:00
|
|
|
extern void geonet_print(netdissect_options *, const u_char *, u_int, const struct lladdr_info *);
|
2015-09-18 21:14:31 +08:00
|
|
|
extern void gre_print(netdissect_options *, const u_char *, u_int);
|
|
|
|
extern int hbhopt_print(netdissect_options *, const u_char *);
|
|
|
|
extern void hex_and_ascii_print(netdissect_options *, const char *, const u_char *, u_int);
|
|
|
|
extern void hex_print(netdissect_options *, const char *ident, const u_char *cp, u_int);
|
|
|
|
extern void hex_print_with_offset(netdissect_options *, const char *ident, const u_char *cp, u_int, u_int);
|
2016-07-29 03:09:41 +08:00
|
|
|
extern void hncp_print(netdissect_options *, const u_char *, u_int);
|
2015-09-18 21:14:31 +08:00
|
|
|
extern void hsrp_print(netdissect_options *, const u_char *, u_int);
|
|
|
|
extern void http_print(netdissect_options *, const u_char *, u_int);
|
|
|
|
extern void icmp6_print(netdissect_options *, const u_char *, u_int, const u_char *, int);
|
|
|
|
extern void icmp_print(netdissect_options *, const u_char *, u_int, const u_char *, int);
|
2019-03-31 20:36:49 +08:00
|
|
|
extern u_int ieee802_15_4_print(netdissect_options *, const u_char *, u_int);
|
2018-11-13 14:03:49 +08:00
|
|
|
extern u_int ieee802_11_radio_print(netdissect_options *, const u_char *, u_int, u_int);
|
2015-09-18 21:14:31 +08:00
|
|
|
extern void igmp_print(netdissect_options *, const u_char *, u_int);
|
|
|
|
extern void igrp_print(netdissect_options *, const u_char *, u_int);
|
|
|
|
extern void ip6_print(netdissect_options *, const u_char *, u_int);
|
|
|
|
extern void ipN_print(netdissect_options *, const u_char *, u_int);
|
|
|
|
extern void ip_print(netdissect_options *, const u_char *, u_int);
|
2017-12-14 02:17:47 +08:00
|
|
|
extern void ipcomp_print(netdissect_options *, const u_char *);
|
2015-09-18 21:14:31 +08:00
|
|
|
extern void ipx_netbios_print(netdissect_options *, const u_char *, u_int);
|
|
|
|
extern void ipx_print(netdissect_options *, const u_char *, u_int);
|
|
|
|
extern void isakmp_print(netdissect_options *, const u_char *, u_int, const u_char *);
|
2019-03-28 10:58:26 +08:00
|
|
|
extern void isakmp_rfc3948_print(netdissect_options *, const u_char *, u_int, const u_char *, int, int, u_int);
|
2017-02-04 04:24:14 +08:00
|
|
|
extern void isoclns_print(netdissect_options *, const u_char *, u_int);
|
2014-03-28 18:43:43 +08:00
|
|
|
extern void krb_print(netdissect_options *, const u_char *);
|
2015-09-18 21:14:31 +08:00
|
|
|
extern void l2tp_print(netdissect_options *, const u_char *, u_int);
|
|
|
|
extern void lane_print(netdissect_options *, const u_char *, u_int, u_int);
|
|
|
|
extern void ldp_print(netdissect_options *, const u_char *, u_int);
|
2015-08-15 00:06:52 +08:00
|
|
|
extern void lisp_print(netdissect_options *, const u_char *, u_int);
|
2014-03-28 18:43:43 +08:00
|
|
|
extern u_int llap_print(netdissect_options *, const u_char *, u_int);
|
2015-07-04 06:54:14 +08:00
|
|
|
extern int llc_print(netdissect_options *, const u_char *, u_int, u_int, const struct lladdr_info *, const struct lladdr_info *);
|
2015-09-18 21:14:31 +08:00
|
|
|
extern void lldp_print(netdissect_options *, const u_char *, u_int);
|
|
|
|
extern void lmp_print(netdissect_options *, const u_char *, u_int);
|
|
|
|
extern void loopback_print(netdissect_options *, const u_char *, const u_int);
|
|
|
|
extern void lspping_print(netdissect_options *, const u_char *, u_int);
|
|
|
|
extern void lwapp_control_print(netdissect_options *, const u_char *, u_int, int);
|
|
|
|
extern void lwapp_data_print(netdissect_options *, const u_char *, u_int);
|
2014-04-01 23:42:33 +08:00
|
|
|
extern void lwres_print(netdissect_options *, const u_char *, u_int);
|
2015-09-18 21:14:31 +08:00
|
|
|
extern void m3ua_print(netdissect_options *, const u_char *, const u_int);
|
2017-12-14 02:17:47 +08:00
|
|
|
extern u_int mfr_print(netdissect_options *, const u_char *, u_int);
|
2015-09-18 21:14:31 +08:00
|
|
|
extern void mobile_print(netdissect_options *, const u_char *, u_int);
|
|
|
|
extern int mobility_print(netdissect_options *, const u_char *, const u_char *);
|
|
|
|
extern void mpcp_print(netdissect_options *, const u_char *, u_int);
|
|
|
|
extern void mpls_print(netdissect_options *, const u_char *, u_int);
|
|
|
|
extern int mptcp_print(netdissect_options *, const u_char *, u_int, u_char);
|
|
|
|
extern void msdp_print(netdissect_options *, const u_char *, u_int);
|
|
|
|
extern void msnlb_print(netdissect_options *, const u_char *);
|
2018-01-07 14:18:00 +08:00
|
|
|
extern void nbt_tcp_print(netdissect_options *, const u_char *, u_int);
|
|
|
|
extern void nbt_udp137_print(netdissect_options *, const u_char *, u_int);
|
|
|
|
extern void nbt_udp138_print(netdissect_options *, const u_char *, u_int);
|
|
|
|
extern void netbeui_print(netdissect_options *, u_short, const u_char *, u_int);
|
2015-09-18 21:14:31 +08:00
|
|
|
extern void nfsreply_print(netdissect_options *, const u_char *, u_int, const u_char *);
|
2017-11-16 20:49:06 +08:00
|
|
|
extern void nfsreply_noaddr_print(netdissect_options *, const u_char *, u_int, const u_char *);
|
|
|
|
extern void nfsreq_noaddr_print(netdissect_options *, const u_char *, u_int, const u_char *);
|
2019-04-03 20:38:03 +08:00
|
|
|
extern const u_char *fqdn_print(netdissect_options *, const u_char *, const u_char *);
|
2017-11-16 16:40:19 +08:00
|
|
|
extern void domain_print(netdissect_options *, const u_char *, u_int, int);
|
2019-03-31 20:36:49 +08:00
|
|
|
extern void nsh_print(netdissect_options *, const u_char *, u_int);
|
2015-09-18 21:14:31 +08:00
|
|
|
extern void ntp_print(netdissect_options *, const u_char *, u_int);
|
2015-07-04 07:39:25 +08:00
|
|
|
extern void oam_print(netdissect_options *, const u_char *, u_int, u_int);
|
2015-09-18 21:14:31 +08:00
|
|
|
extern void olsr_print(netdissect_options *, const u_char *, u_int, int);
|
|
|
|
extern void openflow_print(netdissect_options *, const u_char *, const u_int);
|
|
|
|
extern void ospf6_print(netdissect_options *, const u_char *, u_int);
|
2014-04-02 16:59:56 +08:00
|
|
|
extern void ospf_print(netdissect_options *, const u_char *, u_int, const u_char *);
|
2018-02-22 21:19:42 +08:00
|
|
|
extern int ospf_grace_lsa_print(netdissect_options *, const u_char *, u_int);
|
|
|
|
extern int ospf_te_lsa_print(netdissect_options *, const u_char *, u_int);
|
2015-09-18 21:14:31 +08:00
|
|
|
extern void otv_print(netdissect_options *, const u_char *, u_int);
|
|
|
|
extern void pgm_print(netdissect_options *, const u_char *, u_int, const u_char *);
|
|
|
|
extern void pim_print(netdissect_options *, const u_char *, u_int, const u_char *);
|
|
|
|
extern void pimv1_print(netdissect_options *, const u_char *, u_int);
|
2017-12-14 02:17:47 +08:00
|
|
|
extern u_int ppp_print(netdissect_options *, const u_char *, u_int);
|
2015-09-18 21:14:31 +08:00
|
|
|
extern u_int pppoe_print(netdissect_options *, const u_char *, u_int);
|
|
|
|
extern void pptp_print(netdissect_options *, const u_char *);
|
|
|
|
extern int print_unknown_data(netdissect_options *, const u_char *, const char *, int);
|
2018-03-16 17:39:25 +08:00
|
|
|
extern const char *q922_string(netdissect_options *, const u_char *, u_int);
|
2015-09-18 21:14:31 +08:00
|
|
|
extern void q933_print(netdissect_options *, const u_char *, u_int);
|
|
|
|
extern void radius_print(netdissect_options *, const u_char *, u_int);
|
2016-01-13 01:32:55 +08:00
|
|
|
extern void resp_print(netdissect_options *, const u_char *, u_int);
|
2015-09-18 21:14:31 +08:00
|
|
|
extern void rip_print(netdissect_options *, const u_char *, u_int);
|
|
|
|
extern void ripng_print(netdissect_options *, const u_char *, unsigned int);
|
|
|
|
extern void rpki_rtr_print(netdissect_options *, const u_char *, u_int);
|
2015-07-04 06:54:14 +08:00
|
|
|
extern void rrcp_print(netdissect_options *, const u_char *, u_int, const struct lladdr_info *, const struct lladdr_info *);
|
2014-04-02 20:39:18 +08:00
|
|
|
extern void rsvp_print(netdissect_options *, const u_char *, u_int);
|
2015-09-18 21:14:31 +08:00
|
|
|
extern int rt6_print(netdissect_options *, const u_char *, const u_char *);
|
2014-10-20 02:21:44 +08:00
|
|
|
extern void rtsp_print(netdissect_options *, const u_char *, u_int);
|
2017-12-14 02:17:47 +08:00
|
|
|
extern void rx_print(netdissect_options *, const u_char *, u_int, u_int, u_int, const u_char *);
|
2015-09-18 21:14:31 +08:00
|
|
|
extern void sctp_print(netdissect_options *, const u_char *, const u_char *, u_int);
|
|
|
|
extern void sflow_print(netdissect_options *, const u_char *, u_int);
|
|
|
|
extern void sip_print(netdissect_options *, const u_char *, u_int);
|
|
|
|
extern void slow_print(netdissect_options *, const u_char *, u_int);
|
2018-02-22 21:19:42 +08:00
|
|
|
extern void smb_data_print(netdissect_options *, const u_char *, u_int);
|
2018-01-07 14:18:00 +08:00
|
|
|
extern void smb_tcp_print(netdissect_options *, const u_char *, u_int);
|
2014-10-20 02:21:44 +08:00
|
|
|
extern void smtp_print(netdissect_options *, const u_char *, u_int);
|
2015-07-04 06:54:14 +08:00
|
|
|
extern int snap_print(netdissect_options *, const u_char *, u_int, u_int, const struct lladdr_info *, const struct lladdr_info *, u_int);
|
2015-09-18 21:14:31 +08:00
|
|
|
extern void snmp_print(netdissect_options *, const u_char *, u_int);
|
|
|
|
extern void stp_print(netdissect_options *, const u_char *, u_int);
|
2017-11-16 17:18:43 +08:00
|
|
|
extern void sunrpc_print(netdissect_options *, const u_char *, u_int, const u_char *);
|
2015-09-18 21:14:31 +08:00
|
|
|
extern void syslog_print(netdissect_options *, const u_char *, u_int);
|
|
|
|
extern void tcp_print(netdissect_options *, const u_char *, u_int, const u_char *, int);
|
|
|
|
extern void telnet_print(netdissect_options *, const u_char *, u_int);
|
|
|
|
extern void tftp_print(netdissect_options *, const u_char *, u_int);
|
|
|
|
extern void timed_print(netdissect_options *, const u_char *);
|
|
|
|
extern void tipc_print(netdissect_options *, const u_char *, u_int, u_int);
|
|
|
|
extern u_int token_print(netdissect_options *, const u_char *, u_int, u_int);
|
|
|
|
extern void udld_print(netdissect_options *, const u_char *, u_int);
|
2019-03-28 10:58:26 +08:00
|
|
|
extern void udp_print(netdissect_options *, const u_char *, u_int, const u_char *, int, u_int);
|
2017-12-14 02:17:47 +08:00
|
|
|
extern int vjc_print(netdissect_options *, const u_char *, u_short);
|
|
|
|
extern void vqp_print(netdissect_options *, const u_char *, u_int);
|
2015-09-18 21:14:31 +08:00
|
|
|
extern void vrrp_print(netdissect_options *, const u_char *, u_int, const u_char *, int);
|
|
|
|
extern void vtp_print(netdissect_options *, const u_char *, u_int);
|
2019-03-31 20:36:49 +08:00
|
|
|
extern void vxlan_gpe_print(netdissect_options *, const u_char *, u_int);
|
2016-03-23 00:23:40 +08:00
|
|
|
extern void vxlan_print(netdissect_options *, const u_char *, u_int);
|
2018-01-03 02:08:01 +08:00
|
|
|
extern void wb_print(netdissect_options *, const u_char *, u_int);
|
2017-03-26 09:48:28 +08:00
|
|
|
extern void zep_print(netdissect_options *, const u_char *, u_int);
|
2015-09-18 21:14:31 +08:00
|
|
|
extern void zephyr_print(netdissect_options *, const u_char *, int);
|
|
|
|
extern void zmtp1_print(netdissect_options *, const u_char *, u_int);
|
2017-11-16 21:17:26 +08:00
|
|
|
extern void zmtp1_datagram_print(netdissect_options *, const u_char *, const u_int);
|
2010-11-08 04:50:16 +08:00
|
|
|
|
2015-06-10 22:17:27 +08:00
|
|
|
/* checksum routines */
|
|
|
|
extern void init_checksum(void);
|
|
|
|
extern uint16_t verify_crc10_cksum(uint16_t, const u_char *, int);
|
|
|
|
extern uint16_t create_osi_cksum(const uint8_t *, int, int);
|
|
|
|
|
2011-06-14 05:08:51 +08:00
|
|
|
struct cksum_vec {
|
2014-04-23 15:45:13 +08:00
|
|
|
const uint8_t *ptr;
|
2011-06-14 05:08:51 +08:00
|
|
|
int len;
|
|
|
|
};
|
2014-04-23 15:45:13 +08:00
|
|
|
extern uint16_t in_cksum(const struct cksum_vec *, int);
|
|
|
|
extern uint16_t in_cksum_shouldbe(uint16_t, uint16_t);
|
2015-06-10 21:47:54 +08:00
|
|
|
|
2019-03-28 10:58:26 +08:00
|
|
|
/* IP protocol demuxing routines */
|
|
|
|
extern void ip_print_demux(netdissect_options *, const u_char *, u_int, u_int, int, u_int, u_int, const u_char *);
|
|
|
|
|
2018-12-11 16:50:15 +08:00
|
|
|
extern uint16_t nextproto4_cksum(netdissect_options *, const struct ip *, const uint8_t *, u_int, u_int, u_int);
|
2004-03-25 11:29:53 +08:00
|
|
|
|
2016-02-13 12:26:39 +08:00
|
|
|
/* in print-ip6.c */
|
2018-12-11 16:50:15 +08:00
|
|
|
extern uint16_t nextproto6_cksum(netdissect_options *, const struct ip6_hdr *, const uint8_t *, u_int, u_int, u_int);
|
2016-02-13 12:26:39 +08:00
|
|
|
|
2015-09-18 21:14:31 +08:00
|
|
|
/* Utilities */
|
2018-05-02 23:12:50 +08:00
|
|
|
extern void nd_print_trunc(netdissect_options *);
|
2019-03-19 21:49:34 +08:00
|
|
|
extern void nd_print_protocol(netdissect_options *);
|
2018-09-11 18:27:55 +08:00
|
|
|
extern void nd_print_invalid(netdissect_options *);
|
2018-05-02 23:12:50 +08:00
|
|
|
|
2015-09-18 21:14:31 +08:00
|
|
|
extern int mask2plen(uint32_t);
|
|
|
|
extern int mask62plen(const u_char *);
|
2007-11-25 02:13:33 +08:00
|
|
|
|
2015-09-18 21:14:31 +08:00
|
|
|
extern const char *dnname_string(netdissect_options *, u_short);
|
|
|
|
extern const char *dnnum_string(netdissect_options *, u_short);
|
2007-11-25 02:13:33 +08:00
|
|
|
|
2015-09-18 21:14:31 +08:00
|
|
|
extern int decode_prefix4(netdissect_options *, const u_char *, u_int, char *, u_int);
|
|
|
|
extern int decode_prefix6(netdissect_options *, const u_char *, u_int, char *, u_int);
|
|
|
|
|
|
|
|
extern void esp_print_decodesecret(netdissect_options *);
|
|
|
|
extern int esp_print_decrypt_buffer_by_ikev2(netdissect_options *, int,
|
2017-12-18 13:49:46 +08:00
|
|
|
const u_char spii[8],
|
|
|
|
const u_char spir[8],
|
2015-09-18 21:14:31 +08:00
|
|
|
const u_char *, const u_char *);
|
2013-06-26 05:43:19 +08:00
|
|
|
|
2004-03-25 11:29:53 +08:00
|
|
|
#endif /* netdissect_h */
|