]> The Tcpdump Group git mirrors - tcpdump/blobdiff - print-enc.c
On Solaris, for 64-bit builds, use the 64-bit pcap-config.
[tcpdump] / print-enc.c
index aeacd6c6818a752cfdcd4ac5c3ca5dd4a743c17b..9f541c3ccc569b85d7331da319f493bc8ae89bf7 100644 (file)
@@ -29,6 +29,7 @@
 
 #include "netdissect-stdinc.h"
 
+#define ND_LONGJMP_FROM_TCHECK
 #include "netdissect.h"
 #include "extract.h"
 #include "af.h"
@@ -80,9 +81,9 @@ struct enchdr {
        nd_uint32_t flags;
 };
 
-#define ENC_PRINT_TYPE(wh, xf, nam) \
+#define ENC_PRINT_TYPE(wh, xf, name) \
        if ((wh) & (xf)) { \
-               ND_PRINT("%s%s", nam, (wh) == (xf) ? "): " : ","); \
+               ND_PRINT("%s%s", name, (wh) == (xf) ? "): " : ","); \
                (wh) &= ~(xf); \
        }
 
@@ -104,12 +105,8 @@ enc_if_print(netdissect_options *ndo,
        const struct enchdr *hdr;
 
        ndo->ndo_protocol = "enc";
-       if (caplen < ENC_HDRLEN) {
-               ndo->ndo_ll_header_length += caplen;
-               nd_print_trunc(ndo);
-               return;
-       }
-       ndo->ndo_ll_header_length += ENC_HDRLEN;
+       ND_TCHECK_LEN(p, ENC_HDRLEN);
+       ndo->ndo_ll_hdr_len += ENC_HDRLEN;
 
        hdr = (const struct enchdr *)p;
        /*
@@ -160,6 +157,4 @@ enc_if_print(netdissect_options *ndo,
                ip6_print(ndo, p, length);
                break;
        }
-
-       return;
 }