#include "netdissect.h"
#include "extract.h"
+#define OTV_HDR_LEN 8
+
/*
* OTV header, draft-hasmit-otv-04
*
otv_print(netdissect_options *ndo, const u_char *bp, u_int len)
{
uint8_t flags;
- uint32_t overlay_id;
- uint32_t instance_id;
- if (len < 8) {
- ND_PRINT((ndo, "[|OTV]"));
- return;
- }
+ ND_PRINT((ndo, "OTV, "));
+ if (len < OTV_HDR_LEN)
+ goto trunc;
+ ND_TCHECK(*bp);
flags = *bp;
+ ND_PRINT((ndo, "flags [%s] (0x%02x), ", flags & 0x08 ? "I" : ".", flags));
bp += 1;
- overlay_id = EXTRACT_24BITS(bp);
+ ND_TCHECK2(*bp, 3);
+ ND_PRINT((ndo, "overlay %u, ", EXTRACT_24BITS(bp)));
+ bp += 3;
+
+ ND_TCHECK2(*bp, 3);
+ ND_PRINT((ndo, "instance %u\n", EXTRACT_24BITS(bp)));
bp += 3;
- instance_id = EXTRACT_24BITS(bp);
- bp += 4;
+ /* Reserved */
+ ND_TCHECK(*bp);
+ bp += 1;
- ND_PRINT((ndo, "OTV, "));
- ND_PRINT((ndo, "flags [%s] (0x%02x), ", flags & 0x08 ? "I" : ".", flags));
- ND_PRINT((ndo, "overlay %u, ", overlay_id));
- ND_PRINT((ndo, "instance %u\n", instance_id));
+ ether_print(ndo, bp, len - OTV_HDR_LEN, ndo->ndo_snapend - bp, NULL, NULL);
+ return;
- ether_print(ndo, bp, len - 8, len - 8, NULL, NULL);
+trunc:
+ ND_PRINT((ndo, " [|OTV]"));
}