X-Git-Url: https://git.tcpdump.org/tcpdump/blobdiff_plain/49b23c5a9b0198bb382dcf43c458d46fcf2fa809..d7b497cac78b6e22a66a6bae9bdec60a8044f67a:/print-vxlan-gpe.c diff --git a/print-vxlan-gpe.c b/print-vxlan-gpe.c index a3c214d3..71c517ba 100644 --- a/print-vxlan-gpe.c +++ b/print-vxlan-gpe.c @@ -75,7 +75,7 @@ vxlan_gpe_print(netdissect_options *ndo, const u_char *bp, u_int len) next_protocol = *bp; bp += 1; - vni = EXTRACT_24BITS(bp); + vni = EXTRACT_BE_U_3(bp); bp += 4; ND_PRINT((ndo, "VXLAN-GPE, ")); @@ -86,19 +86,19 @@ vxlan_gpe_print(netdissect_options *ndo, const u_char *bp, u_int len) switch (next_protocol) { case 0x1: - ip_print(ndo, bp, len - 8); + ip_print(ndo, bp, len - VXLAN_GPE_HDR_LEN); break; case 0x2: - ip6_print(ndo, bp, len - 8); + ip6_print(ndo, bp, len - VXLAN_GPE_HDR_LEN); break; case 0x3: - ether_print(ndo, bp, len - 8, len - 8, NULL, NULL); + ether_print(ndo, bp, len - VXLAN_GPE_HDR_LEN, ndo->ndo_snapend - bp, NULL, NULL); break; case 0x4: - nsh_print(ndo, bp, len - 8); + nsh_print(ndo, bp, len - VXLAN_GPE_HDR_LEN); break; case 0x5: - mpls_print(ndo, bp, len - 8); + mpls_print(ndo, bp, len - VXLAN_GPE_HDR_LEN); break; default: ND_PRINT((ndo, "ERROR: unknown-next-protocol"));