X-Git-Url: https://git.tcpdump.org/tcpdump/blobdiff_plain/4b0d808e20676e17a65cec4363a4f29ed1e5d80f..refs/heads/master:/netdissect.h diff --git a/netdissect.h b/netdissect.h index a6e298ba..ca2b5665 100644 --- a/netdissect.h +++ b/netdissect.h @@ -33,7 +33,6 @@ #include #include "status-exit-codes.h" #include "funcattrs.h" /* for PRINTFLIKE_FUNCPTR() */ -#include "diag-control.h" /* for ND_UNREACHABLE */ /* * Data types corresponding to multi-byte integral values within data @@ -73,6 +72,14 @@ typedef unsigned char nd_int64_t[8]; #define FMAXINT (4294967296.0) /* floating point rep. of MAXINT */ +/* + * Data types corresponding to multi-byte floating_point values within + * data structures. These are defined as arrays of octets, for the + * same reason that we do so for integral values. + */ +typedef unsigned char nd_float[4]; +typedef unsigned char nd_double[8]; + /* * Use this for IPv4 addresses and netmasks. * @@ -153,9 +160,9 @@ struct tok { }; /* tok2str is deprecated */ -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); +extern const char *tok2str(const struct tok *, const char *, const u_int); +extern char *bittok2str(const struct tok *, const char *, const u_int); +extern char *bittok2str_nosep(const struct tok *, const char *, const u_int); /* Initialize netdissect. */ extern int nd_init(char *, size_t); @@ -228,6 +235,7 @@ struct netdissect_options { jmp_buf ndo_early_end; /* jmp_buf for setjmp()/longjmp() */ void *ndo_last_mem_p; /* pointer to the last allocated memory chunk */ int ndo_packet_number; /* print a packet number in the beginning of line */ + int ndo_lengths; /* print packet header caplen and len */ int ndo_print_sampling; /* print every Nth packet */ int ndo_suppress_default_print; /* don't use default_print() for unknown packet types */ int ndo_tstamp_precision; /* requested time stamp precision */ @@ -378,9 +386,15 @@ NORETURN void nd_trunc_longjmp(netdissect_options *ndo); /* Bail out if "l" bytes from "p" were not captured */ #ifdef ND_LONGJMP_FROM_TCHECK -#define ND_TCHECK_LEN(p, l) if (!ND_TTEST_LEN(p, l)) nd_trunc_longjmp(ndo) +#define ND_TCHECK_LEN(p, l) \ +do { \ +if (!ND_TTEST_LEN(p, l)) nd_trunc_longjmp(ndo); \ +} while (0) #else -#define ND_TCHECK_LEN(p, l) if (!ND_TTEST_LEN(p, l)) goto trunc +#define ND_TCHECK_LEN(p, l) \ +do { \ +if (!ND_TTEST_LEN(p, l)) goto trunc; \ +} while (0) #endif /* Bail out if "*(p)" was not captured */ @@ -402,10 +416,12 @@ NORETURN void nd_trunc_longjmp(netdissect_options *ndo); * a custom message, format %u */ #define ND_ICHECKMSG_U(message, expression_1, operator, expression_2) \ +do { \ if ((expression_1) operator (expression_2)) { \ ND_PRINT(" [%s %u %s %u]", (message), (expression_1), (#operator), (expression_2)); \ goto invalid; \ -} +} \ +} while (0) /* * Check (expression_1 operator expression_2) for invalid packet with @@ -419,10 +435,12 @@ ND_ICHECKMSG_U((#expression_1), (expression_1), operator, (expression_2)) * a custom message, format %zu */ #define ND_ICHECKMSG_ZU(message, expression_1, operator, expression_2) \ +do { \ if ((expression_1) operator (expression_2)) { \ ND_PRINT(" [%s %u %s %zu]", (message), (expression_1), (#operator), (expression_2)); \ goto invalid; \ -} +} \ +} while (0) /* * Check (expression_1 operator expression_2) for invalid packet with @@ -447,6 +465,7 @@ extern u_int nd_printztn(netdissect_options *, const u_char *, u_int, const u_ch extern int nd_printn(netdissect_options *, const u_char *, u_int, const u_char *); extern void nd_printjn(netdissect_options *, const u_char *, u_int); extern void nd_printjnp(netdissect_options *, const u_char *, u_int); +extern void nd_print_bytes_hex(netdissect_options *, const u_char *, u_int); /* * Flags for txtproto_print(). @@ -500,7 +519,7 @@ extern int unaligned_memcmp(const void *, const void *, size_t); #define PLURAL_SUFFIX(n) \ (((n) != 1) ? "s" : "") -extern const char *tok2strary_internal(const char **, int, const char *, int); +extern const char *tok2strary_internal(const char **, int, const char *, const int); #define tok2strary(a,f,i) tok2strary_internal(a, sizeof(a)/sizeof(a[0]),f,i) struct uint_tokary @@ -565,7 +584,6 @@ extern void null_if_print IF_PRINTER_ARGS; extern void pflog_if_print IF_PRINTER_ARGS; extern void pktap_if_print IF_PRINTER_ARGS; extern void ppi_if_print IF_PRINTER_ARGS; -extern void ppp_bsdos_if_print IF_PRINTER_ARGS; extern void ppp_hdlc_if_print IF_PRINTER_ARGS; extern void ppp_if_print IF_PRINTER_ARGS; extern void pppoe_if_print IF_PRINTER_ARGS; @@ -635,7 +653,8 @@ extern void eap_print(netdissect_options *, const u_char *, const u_int); extern void eapol_print(netdissect_options *, const u_char *); extern void egp_print(netdissect_options *, const u_char *, u_int); extern void eigrp_print(netdissect_options *, const u_char *, u_int); -extern void erspan_print(netdissect_options *, uint16_t, const u_char *, u_int); +extern void erspan_i_ii_print(netdissect_options *, uint16_t, const u_char *, u_int); +extern void erspan_iii_print(netdissect_options *, const u_char *, u_int); extern void esp_print(netdissect_options *, const u_char *, u_int, const u_char *, u_int, int, u_int); extern u_int ether_print(netdissect_options *, const u_char *, u_int, u_int, void (*)(netdissect_options *, const u_char *), const u_char *); extern u_int ether_switch_tag_print(netdissect_options *, const u_char *, u_int, u_int, void (*)(netdissect_options *, const u_char *), u_int); @@ -657,14 +676,14 @@ extern void hncp_print(netdissect_options *, const u_char *, u_int); 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); +extern void icmp_print(netdissect_options *, const u_char *, u_int, int); extern u_int ieee802_11_radio_print(netdissect_options *, const u_char *, u_int, u_int); extern u_int ieee802_15_4_print(netdissect_options *, const u_char *, u_int); 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); +extern void ip_print(netdissect_options *, const u_char *, const u_int); extern void ipcomp_print(netdissect_options *, const u_char *); extern void ipx_netbios_print(netdissect_options *, const u_char *, u_int); extern void ipx_print(netdissect_options *, const u_char *, u_int); @@ -725,7 +744,7 @@ extern const char *q922_string(netdissect_options *, const u_char *, u_int); extern void q933_print(netdissect_options *, const u_char *, u_int); extern int quic_detect(netdissect_options *, const u_char *, const u_int); extern void quic_print(netdissect_options *, const u_char *); -extern void radius_print(netdissect_options *, const u_char *, u_int); +extern void radius_print(netdissect_options *, const u_char *, const u_int); extern void resp_print(netdissect_options *, const u_char *, u_int); extern void rip_print(netdissect_options *, const u_char *, u_int); extern void ripng_print(netdissect_options *, const u_char *, unsigned int); @@ -794,7 +813,7 @@ extern void nd_print_protocol(netdissect_options *); extern void nd_print_protocol_caps(netdissect_options *); extern void nd_print_invalid(netdissect_options *); -extern int mask2plen(uint32_t); +extern int mask2plen(const uint32_t); extern int mask62plen(const u_char *); extern const char *dnnum_string(netdissect_options *, u_short);