X-Git-Url: https://git.tcpdump.org/tcpdump/blobdiff_plain/fc3fcdee62a5820e60a28a6ed75910b207272d03..refs/pull/433/head:/print-vxlan.c?ds=inline diff --git a/print-vxlan.c b/print-vxlan.c index da610e59..c4de68d5 100644 --- a/print-vxlan.c +++ b/print-vxlan.c @@ -13,21 +13,20 @@ * Original code by Francesco Fondelli (francesco dot fondelli, gmail dot com) */ +#define NETDISSECT_REWORKED #ifdef HAVE_CONFIG_H #include "config.h" #endif #include -#include -#include - #include "interface.h" #include "extract.h" -#include "addrtoname.h" /* - * VXLAN header, draft-mahalingam-dutt-dcops-vxlan-03 + * VXLAN header, RFC7348 + * Virtual eXtensible Local Area Network (VXLAN): A Framework + * for Overlaying Virtualized Layer 2 Networks over Layer 3 Networks * * 0 1 2 3 * 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 @@ -39,13 +38,13 @@ */ void -vxlan_print(const u_char *bp, u_int len) +vxlan_print(netdissect_options *ndo, const u_char *bp, u_int len) { - u_int8_t flags; - u_int32_t vni; + uint8_t flags; + uint32_t vni; if (len < 8) { - printf("[|VXLAN]"); + ND_PRINT((ndo, "[|VXLAN]")); return; } @@ -55,18 +54,9 @@ vxlan_print(const u_char *bp, u_int len) vni = EXTRACT_24BITS(bp); bp += 4; - printf("VXLAN, "); - - fputs("flags [", stdout); - if (flags & 0x08) - fputs("I", stdout); - else - fputs(".", stdout); - fputs("] ", stdout); - - printf("(0x%02x), ", flags); - printf("vni %u\n", vni); + ND_PRINT((ndo, "VXLAN, ")); + ND_PRINT((ndo, "flags [%s] (0x%02x), ", flags & 0x08 ? "I" : ".", flags)); + ND_PRINT((ndo, "vni %u\n", vni)); - ether_print(gndo, bp, len - 8, len - 8, NULL, NULL); - return; + ether_print(ndo, bp, len - 8, len - 8, NULL, NULL); }