summaryrefslogtreecommitdiff
path: root/addrtoname.h
diff options
context:
space:
mode:
Diffstat (limited to 'addrtoname.h')
-rw-r--r--addrtoname.h50
1 files changed, 39 insertions, 11 deletions
diff --git a/addrtoname.h b/addrtoname.h
index 201ab431..8a262aa7 100644
--- a/addrtoname.h
+++ b/addrtoname.h
@@ -19,13 +19,12 @@
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
*/
+#include "extract.h"
+
/*
- * 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.
*/
-
-#include "extract.h"
-
#ifndef INET6_ADDRSTRLEN
#define INET6_ADDRSTRLEN 46
#endif
@@ -65,19 +64,20 @@ extern const char * ieee8021q_tci_string(const uint16_t);
*/
static inline const char *
-get_ipaddr_string(netdissect_options *ndo, const u_char *p)
+get_linkaddr_string(netdissect_options *ndo, const uint8_t *p,
+ const unsigned int type, const unsigned int len)
{
- if (!ND_TTEST_4(p))
+ if (!ND_TTEST_LEN(p, len))
longjmp(ndo->ndo_truncated, 1);
- return ipaddr_string(ndo, p);
+ return linkaddr_string(ndo, p, type, len);
}
static inline const char *
-get_ip6addr_string(netdissect_options *ndo, const u_char *p)
+get_etheraddr_string(netdissect_options *ndo, const uint8_t *p)
{
- if (!ND_TTEST_16(p))
+ if (!ND_TTEST_LEN(p, MAC_ADDR_LEN))
longjmp(ndo->ndo_truncated, 1);
- return ip6addr_string(ndo, p);
+ return etheraddr_string(ndo, p);
}
static inline const char *
@@ -88,6 +88,34 @@ get_le64addr_string(netdissect_options *ndo, const u_char *p)
return le64addr_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))
+ longjmp(ndo->ndo_truncated, 1);
+ 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))
+ 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);
+}
+
+#define GET_LINKADDR_STRING(p, type, len) get_linkaddr_string(ndo, (const u_char *)(p), type, len)
+#define GET_ETHERADDR_STRING(p) get_etheraddr_string(ndo, (const u_char *)(p))
+#define GET_LE64ADDR_STRING(p) get_le64addr_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))
-#define GET_LE64ADDR_STRING(p) get_le64addr_string(ndo, (const u_char *)(p))