X-Git-Url: https://git.tcpdump.org/tcpdump/blobdiff_plain/b8c56aa09228ee6c59af9bd2565bc66b69ac7943..d7b497cac78b6e22a66a6bae9bdec60a8044f67a:/print-otv.c?ds=sidebyside diff --git a/print-otv.c b/print-otv.c index 5a82752c..f4daacfa 100644 --- a/print-otv.c +++ b/print-otv.c @@ -26,6 +26,8 @@ #include "netdissect.h" #include "extract.h" +#define OTV_HDR_LEN 8 + /* * OTV header, draft-hasmit-otv-04 * @@ -44,7 +46,7 @@ otv_print(netdissect_options *ndo, const u_char *bp, u_int len) uint8_t flags; ND_PRINT((ndo, "OTV, ")); - if (len < 8) + if (len < OTV_HDR_LEN) goto trunc; ND_TCHECK(*bp); @@ -52,19 +54,19 @@ otv_print(netdissect_options *ndo, const u_char *bp, u_int len) ND_PRINT((ndo, "flags [%s] (0x%02x), ", flags & 0x08 ? "I" : ".", flags)); bp += 1; - ND_TCHECK2(*bp, 3); - ND_PRINT((ndo, "overlay %u, ", EXTRACT_24BITS(bp))); + ND_TCHECK_3(bp); + ND_PRINT((ndo, "overlay %u, ", EXTRACT_BE_U_3(bp))); bp += 3; - ND_TCHECK2(*bp, 3); - ND_PRINT((ndo, "instance %u\n", EXTRACT_24BITS(bp))); + ND_TCHECK_3(bp); + ND_PRINT((ndo, "instance %u\n", EXTRACT_BE_U_3(bp))); bp += 3; /* Reserved */ ND_TCHECK(*bp); bp += 1; - ether_print(ndo, bp, len - 8, ndo->ndo_snapend - bp, NULL, NULL); + ether_print(ndo, bp, len - OTV_HDR_LEN, ndo->ndo_snapend - bp, NULL, NULL); return; trunc: