X-Git-Url: https://git.tcpdump.org/tcpdump/blobdiff_plain/a7fc606fd549623888db00b7aefacf54fb904f4c..refs/heads/master:/addrtoname.h?ds=inline diff --git a/addrtoname.h b/addrtoname.h index c3019194..e17a1f4b 100644 --- a/addrtoname.h +++ b/addrtoname.h @@ -19,8 +19,15 @@ * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. */ +#include "extract.h" + +#ifdef HAVE_CASPER +#include +extern cap_channel_t *capdns; +#endif + /* - * Definitions to let us compile most of the IPv6 code even on systems + * Definition to let us compile most of the IPv6 code even on systems * without IPv6 support. */ #ifndef INET6_ADDRSTRLEN @@ -30,26 +37,26 @@ /* Name to address translation routines. */ enum { - LINKADDR_ETHER, + LINKADDR_MAC48, LINKADDR_FRELAY, - LINKADDR_IEEE1394, + LINKADDR_EUI64, LINKADDR_ATM, LINKADDR_OTHER }; #define BUFSIZE 128 -extern const char *linkaddr_string(netdissect_options *, const u_char *, const unsigned int, const unsigned int); -extern const char *etheraddr_string(netdissect_options *, const u_char *); -extern const char *le64addr_string(netdissect_options *, const u_char *); -extern const char *etherproto_string(netdissect_options *, u_short); +extern const char *linkaddr_string(netdissect_options *, const uint8_t *, const unsigned int, const unsigned int); +extern const char *mac48_string(netdissect_options *, const uint8_t *); +extern const char *eui64_string(netdissect_options *, const uint8_t *); +extern const char *eui64le_string(netdissect_options *, const uint8_t *); extern const char *tcpport_string(netdissect_options *, u_short); extern const char *udpport_string(netdissect_options *, u_short); -extern const char *isonsap_string(netdissect_options *, const u_char *, register u_int); +extern const char *isonsap_string(netdissect_options *, const uint8_t *, u_int); extern const char *dnaddr_string(netdissect_options *, u_short); extern const char *ipxsap_string(netdissect_options *, u_short); -extern const char *getname(netdissect_options *, const u_char *); -extern const char *getname6(netdissect_options *, const u_char *); +extern const char *ipaddr_string(netdissect_options *, const u_char *); +extern const char *ip6addr_string(netdissect_options *, const u_char *); extern const char *intoa(uint32_t); extern void init_addrtoname(netdissect_options *, uint32_t, uint32_t); @@ -57,5 +64,73 @@ extern struct hnamemem *newhnamemem(netdissect_options *); extern struct h6namemem *newh6namemem(netdissect_options *); extern const char * ieee8021q_tci_string(const uint16_t); -#define ipaddr_string(ndo, p) getname(ndo, (const u_char *)(p)) -#define ip6addr_string(ndo, p) getname6(ndo, (const u_char *)(p)) +/* macro(s) and inline function(s) with setjmp/longjmp logic to call + * the X_string() function(s) after bounds checking. + * The macro(s) must be used on a packet buffer pointer. + */ + +static inline const char * +get_linkaddr_string(netdissect_options *ndo, const uint8_t *p, + const unsigned int type, const unsigned int len) +{ + if (!ND_TTEST_LEN(p, len)) + nd_trunc_longjmp(ndo); + return linkaddr_string(ndo, p, type, len); +} + +static inline const char * +get_mac48_string(netdissect_options *ndo, const uint8_t *p) +{ + if (!ND_TTEST_LEN(p, MAC48_LEN)) + nd_trunc_longjmp(ndo); + return mac48_string(ndo, p); +} + +static inline const char * +get_eui64_string(netdissect_options *ndo, const uint8_t *p) +{ + if (!ND_TTEST_LEN(p, EUI64_LEN)) + nd_trunc_longjmp(ndo); + return eui64_string(ndo, p); +} + +static inline const char * +get_eui64le_string(netdissect_options *ndo, const uint8_t *p) +{ + if (!ND_TTEST_LEN(p, EUI64_LEN)) + nd_trunc_longjmp(ndo); + return eui64le_string(ndo, p); +} + +static inline const char * +get_isonsap_string(netdissect_options *ndo, const uint8_t *nsap, + u_int nsap_length) +{ + if (!ND_TTEST_LEN(nsap, nsap_length)) + nd_trunc_longjmp(ndo); + return isonsap_string(ndo, nsap, nsap_length); +} + +static inline const char * +get_ipaddr_string(netdissect_options *ndo, const u_char *p) +{ + if (!ND_TTEST_4(p)) + nd_trunc_longjmp(ndo); + return ipaddr_string(ndo, p); +} + +static inline const char * +get_ip6addr_string(netdissect_options *ndo, const u_char *p) +{ + if (!ND_TTEST_16(p)) + nd_trunc_longjmp(ndo); + return ip6addr_string(ndo, p); +} + +#define GET_LINKADDR_STRING(p, type, len) get_linkaddr_string(ndo, (const u_char *)(p), type, len) +#define GET_MAC48_STRING(p) get_mac48_string(ndo, (const u_char *)(p)) +#define GET_EUI64_STRING(p) get_eui64_string(ndo, (const u_char *)(p)) +#define GET_EUI64LE_STRING(p) get_eui64le_string(ndo, (const u_char *)(p)) +#define GET_ISONSAP_STRING(nsap, nsap_length) get_isonsap_string(ndo, (const u_char *)(nsap), nsap_length) +#define GET_IPADDR_STRING(p) get_ipaddr_string(ndo, (const u_char *)(p)) +#define GET_IP6ADDR_STRING(p) get_ip6addr_string(ndo, (const u_char *)(p))