X-Git-Url: https://git.tcpdump.org/tcpdump/blobdiff_plain/6ec714988caac3bf9fedc766ae51a2248896ec80..a8c33a5850cd9d2f39e56c06b645c283225d78c4:/addrtoname.h diff --git a/addrtoname.h b/addrtoname.h index 8a37d3d5..201ab431 100644 --- a/addrtoname.h +++ b/addrtoname.h @@ -23,6 +23,9 @@ * Definitions to let us compile most of the IPv6 code even on systems * without IPv6 support. */ + +#include "extract.h" + #ifndef INET6_ADDRSTRLEN #define INET6_ADDRSTRLEN 46 #endif @@ -39,17 +42,16 @@ enum { #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 *etheraddr_string(netdissect_options *, const uint8_t *); +extern const char *le64addr_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 *, 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 +59,35 @@ 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_ipaddr_string(netdissect_options *ndo, const u_char *p) +{ + if (!ND_TTEST_4(p)) + longjmp(ndo->ndo_truncated, 1); + return ipaddr_string(ndo, p); +} + +static inline const char * +get_ip6addr_string(netdissect_options *ndo, const u_char *p) +{ + if (!ND_TTEST_16(p)) + longjmp(ndo->ndo_truncated, 1); + return ip6addr_string(ndo, p); +} + +static inline const char * +get_le64addr_string(netdissect_options *ndo, const u_char *p) +{ + if (!ND_TTEST_8(p)) + longjmp(ndo->ndo_truncated, 1); + return le64addr_string(ndo, p); +} + +#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)) +#define GET_LE64ADDR_STRING(p) get_le64addr_string(ndo, (const u_char *)(p))