X-Git-Url: https://git.tcpdump.org/tcpdump/blobdiff_plain/64677b0d78ff168d98c3035e894c4910c021136e..5ef0bcb5edd748de9d9af13c40da0395dfdd94e8:/print-vrrp.c diff --git a/print-vrrp.c b/print-vrrp.c index 5726bd90..972a8cd7 100644 --- a/print-vrrp.c +++ b/print-vrrp.c @@ -26,10 +26,10 @@ /* \summary: Virtual Router Redundancy Protocol (VRRP) printer */ #ifdef HAVE_CONFIG_H -#include "config.h" +#include #endif -#include +#include "netdissect-stdinc.h" #include "netdissect.h" #include "extract.h" @@ -110,30 +110,28 @@ vrrp_print(netdissect_options *ndo, int version, type, auth_type = VRRP_AUTH_NONE; /* keep compiler happy */ const char *type_s; - ND_TCHECK_1(bp); - version = (EXTRACT_U_1(bp) & 0xf0) >> 4; - type = EXTRACT_U_1(bp) & 0x0f; + ndo->ndo_protocol = "vrrp"; + version = (GET_U_1(bp) & 0xf0) >> 4; + type = GET_U_1(bp) & 0x0f; type_s = tok2str(type2str, "unknown type (%u)", type); ND_PRINT("VRRPv%u, %s", version, type_s); if (ttl != 255) ND_PRINT(", (ttl %u)", ttl); if (version < 2 || version > 3 || type != VRRP_TYPE_ADVERTISEMENT) return; - ND_TCHECK_1(bp + 2); - ND_PRINT(", vrid %u, prio %u", EXTRACT_U_1(bp + 1), EXTRACT_U_1(bp + 2)); - ND_TCHECK_1(bp + 5); + ND_PRINT(", vrid %u, prio %u", GET_U_1(bp + 1), GET_U_1(bp + 2)); if (version == 2) { - auth_type = EXTRACT_U_1(bp + 4); + auth_type = GET_U_1(bp + 4); ND_PRINT(", authtype %s", tok2str(auth2str, NULL, auth_type)); - ND_PRINT(", intvl %us, length %u", EXTRACT_U_1(bp + 5), len); + ND_PRINT(", intvl %us, length %u", GET_U_1(bp + 5), len); } else { /* version == 3 */ - uint16_t intvl = (EXTRACT_U_1(bp + 4) & 0x0f) << 8 | EXTRACT_U_1(bp + 5); + uint16_t intvl = (GET_U_1(bp + 4) & 0x0f) << 8 | GET_U_1(bp + 5); ND_PRINT(", intvl %ucs, length %u", intvl, len); } if (ndo->ndo_vflag) { - u_int naddrs = EXTRACT_U_1(bp + 3); + u_int naddrs = GET_U_1(bp + 3); u_int i; char c; @@ -144,7 +142,7 @@ vrrp_print(netdissect_options *ndo, vec[0].len = len; if (in_cksum(vec, 1)) ND_PRINT(", (bad vrrp cksum %x)", - EXTRACT_BE_U_2(bp + 6)); + GET_BE_U_2(bp + 6)); } if (version == 3 && ND_TTEST_LEN(bp, len)) { @@ -152,7 +150,7 @@ vrrp_print(netdissect_options *ndo, len, len, IPPROTO_VRRP); if (cksum) ND_PRINT(", (bad vrrp cksum %x)", - EXTRACT_BE_U_2(bp + 6)); + GET_BE_U_2(bp + 6)); } ND_PRINT(", addrs"); @@ -162,15 +160,14 @@ vrrp_print(netdissect_options *ndo, c = ' '; bp += 8; for (i = 0; i < naddrs; i++) { - ND_TCHECK_1(bp + 3); - ND_PRINT("%c%s", c, ipaddr_string(ndo, bp)); + ND_PRINT("%c%s", c, GET_IPADDR_STRING(bp)); c = ','; bp += 4; } if (version == 2 && auth_type == VRRP_AUTH_SIMPLE) { /* simple text password */ ND_TCHECK_1(bp + 7); ND_PRINT(" auth \""); - if (fn_printn(ndo, bp, 8, ndo->ndo_snapend)) { + if (nd_printn(ndo, bp, 8, ndo->ndo_snapend)) { ND_PRINT("\""); goto trunc; } @@ -179,5 +176,5 @@ vrrp_print(netdissect_options *ndo, } return; trunc: - ND_PRINT("[|vrrp]"); + nd_print_trunc(ndo); }