Moreover:
Use uint32_t type for family (32-bit integer).
Add and use tstr[].
#include <string.h>
#include "netdissect.h"
+#include "extract.h"
#include "af.h"
+static const char tstr[] = " [|null]";
+
/*
* The DLT_NULL packet header is 4 bytes long. It contains a host-byte-order
* 32-bit integer that specifies the family, e.g. AF_INET.
{
u_int length = h->len;
u_int caplen = h->caplen;
- u_int family;
+ uint32_t family;
- if (caplen < NULL_HDRLEN) {
- ND_PRINT("[|null]");
- return (NULL_HDRLEN);
- }
+ if (caplen < NULL_HDRLEN)
+ goto trunc;
+ ND_TCHECK_4(p);
memcpy((char *)&family, (const char *)p, sizeof(family));
/*
ND_DEFAULTPRINT(p, caplen);
}
+ return (NULL_HDRLEN);
+trunc:
+ ND_PRINT("%s", tstr);
return (NULL_HDRLEN);
}