]> The Tcpdump Group git mirrors - tcpdump/blobdiff - print-dvmrp.c
The third argument to linkaddr_string is one of the LINKADDR_ enums.
[tcpdump] / print-dvmrp.c
index 91daec833ecc064b14e6f03f7d28c55f3b1b2ba3..7e57a49bcd605edbf64ed9dd733fede71a97db8c 100644 (file)
 /* \summary: Distance Vector Multicast Routing Protocol printer */
 
 #ifdef HAVE_CONFIG_H
-#include "config.h"
+#include <config.h>
 #endif
 
-#include <netdissect-stdinc.h>
+#include "netdissect-stdinc.h"
 
 #include "netdissect.h"
 #include "extract.h"
@@ -73,12 +73,13 @@ dvmrp_print(netdissect_options *ndo,
        u_char type;
        uint8_t major_version, minor_version;
 
-       ep = (const u_char *)ndo->ndo_snapend;
+       ndo->ndo_protocol = "dvmrp";
+       ep = ndo->ndo_snapend;
        if (bp >= ep)
                return;
 
        ND_TCHECK_1(bp + 1);
-       type = EXTRACT_U_1(bp + 1);
+       type = GET_U_1(bp + 1);
 
        /* Skip IGMP header */
        bp += 8;
@@ -87,7 +88,7 @@ dvmrp_print(netdissect_options *ndo,
        switch (type) {
 
        case DVMRP_PROBE:
-               ND_PRINT((ndo, " Probe"));
+               ND_PRINT(" Probe");
                if (ndo->ndo_vflag) {
                        if (print_probe(ndo, bp, ep, len) < 0)
                                goto trunc;
@@ -95,7 +96,7 @@ dvmrp_print(netdissect_options *ndo,
                break;
 
        case DVMRP_REPORT:
-               ND_PRINT((ndo, " Report"));
+               ND_PRINT(" Report");
                if (ndo->ndo_vflag > 1) {
                        if (print_report(ndo, bp, ep, len) < 0)
                                goto trunc;
@@ -103,28 +104,28 @@ dvmrp_print(netdissect_options *ndo,
                break;
 
        case DVMRP_ASK_NEIGHBORS:
-               ND_PRINT((ndo, " Ask-neighbors(old)"));
+               ND_PRINT(" Ask-neighbors(old)");
                break;
 
        case DVMRP_NEIGHBORS:
-               ND_PRINT((ndo, " Neighbors(old)"));
+               ND_PRINT(" Neighbors(old)");
                if (print_neighbors(ndo, bp, ep, len) < 0)
                        goto trunc;
                break;
 
        case DVMRP_ASK_NEIGHBORS2:
-               ND_PRINT((ndo, " Ask-neighbors2"));
+               ND_PRINT(" Ask-neighbors2");
                break;
 
        case DVMRP_NEIGHBORS2:
-               ND_PRINT((ndo, " Neighbors2"));
+               ND_PRINT(" Neighbors2");
                /*
                 * extract version from IGMP group address field
                 */
                bp -= 4;
                ND_TCHECK_4(bp);
-               major_version = EXTRACT_U_1(bp + 3);
-               minor_version = EXTRACT_U_1(bp + 2);
+               major_version = GET_U_1(bp + 3);
+               minor_version = GET_U_1(bp + 2);
                bp += 4;
                if (print_neighbors2(ndo, bp, ep, len, major_version,
                    minor_version) < 0)
@@ -132,31 +133,31 @@ dvmrp_print(netdissect_options *ndo,
                break;
 
        case DVMRP_PRUNE:
-               ND_PRINT((ndo, " Prune"));
+               ND_PRINT(" Prune");
                if (print_prune(ndo, bp) < 0)
                        goto trunc;
                break;
 
        case DVMRP_GRAFT:
-               ND_PRINT((ndo, " Graft"));
+               ND_PRINT(" Graft");
                if (print_graft(ndo, bp) < 0)
                        goto trunc;
                break;
 
        case DVMRP_GRAFT_ACK:
-               ND_PRINT((ndo, " Graft-ACK"));
+               ND_PRINT(" Graft-ACK");
                if (print_graft_ack(ndo, bp) < 0)
                        goto trunc;
                break;
 
        default:
-               ND_PRINT((ndo, " [type %d]", type));
+               ND_PRINT(" [type %u]", type);
                break;
        }
        return;
 
 trunc:
-       ND_PRINT((ndo, "[|dvmrp]"));
+       nd_print_trunc(ndo);
        return;
 }
 
@@ -166,53 +167,53 @@ print_report(netdissect_options *ndo,
              u_int len)
 {
        uint32_t mask, origin;
-       int metric, done;
+       u_int metric, done;
        u_int i, width;
 
        while (len > 0) {
                if (len < 3) {
-                       ND_PRINT((ndo, " [|]"));
+                       ND_PRINT(" [|]");
                        return (0);
                }
                ND_TCHECK_3(bp);
-               mask = (uint32_t)0xff << 24 | EXTRACT_U_1(bp) << 16 |
-                       EXTRACT_U_1(bp + 1) << 8 | EXTRACT_U_1(bp + 2);
+               mask = (uint32_t)0xff << 24 | GET_U_1(bp) << 16 |
+                       GET_U_1(bp + 1) << 8 | GET_U_1(bp + 2);
                width = 1;
-               if (EXTRACT_U_1(bp))
+               if (GET_U_1(bp))
                        width = 2;
-               if (EXTRACT_U_1(bp + 1))
+               if (GET_U_1(bp + 1))
                        width = 3;
-               if (EXTRACT_U_1(bp + 2))
+               if (GET_U_1(bp + 2))
                        width = 4;
 
-               ND_PRINT((ndo, "\n\tMask %s", intoa(htonl(mask))));
+               ND_PRINT("\n\tMask %s", intoa(htonl(mask)));
                bp += 3;
                len -= 3;
                do {
                        if (bp + width + 1 > ep) {
-                               ND_PRINT((ndo, " [|]"));
+                               ND_PRINT(" [|]");
                                return (0);
                        }
                        if (len < width + 1) {
-                               ND_PRINT((ndo, "\n\t  [Truncated Report]"));
+                               ND_PRINT("\n\t  [Truncated Report]");
                                return (0);
                        }
                        origin = 0;
                        for (i = 0; i < width; ++i) {
                                ND_TCHECK_1(bp);
-                               origin = origin << 8 | EXTRACT_U_1(bp);
+                               origin = origin << 8 | GET_U_1(bp);
                                bp++;
                        }
                        for ( ; i < 4; ++i)
                                origin <<= 8;
 
                        ND_TCHECK_1(bp);
-                       metric = EXTRACT_U_1(bp);
+                       metric = GET_U_1(bp);
                        bp++;
                        done = metric & 0x80;
                        metric &= 0x7f;
-                       ND_PRINT((ndo, "\n\t  %s metric %d", intoa(htonl(origin)),
-                               metric));
+                       ND_PRINT("\n\t  %s metric %u", intoa(htonl(origin)),
+                               metric);
                        len -= width + 1;
                } while (!done);
        }
@@ -231,21 +232,20 @@ print_probe(netdissect_options *ndo,
        ND_TCHECK_4(bp);
        if ((len < 4) || ((bp + 4) > ep)) {
                /* { (ctags) */
-               ND_PRINT((ndo, " [|}"));
+               ND_PRINT(" [|}");
                return (0);
        }
-       genid = (EXTRACT_U_1(bp) << 24) | (EXTRACT_U_1(bp + 1) << 16) |
-                (EXTRACT_U_1(bp + 2) << 8) | EXTRACT_U_1(bp + 3);
+       genid = GET_BE_U_4(bp);
        bp += 4;
        len -= 4;
-       ND_PRINT((ndo, ndo->ndo_vflag > 1 ? "\n\t" : " "));
-       ND_PRINT((ndo, "genid %u", genid));
+       ND_PRINT(ndo->ndo_vflag > 1 ? "\n\t" : " ");
+       ND_PRINT("genid %u", genid);
        if (ndo->ndo_vflag < 2)
                return (0);
 
        while ((len > 0) && (bp < ep)) {
                ND_TCHECK_4(bp);
-               ND_PRINT((ndo, "\n\tneighbor %s", ipaddr_string(ndo, bp)));
+               ND_PRINT("\n\tneighbor %s", ipaddr_string(ndo, bp));
                bp += 4; len -= 4;
        }
        return (0);
@@ -267,18 +267,18 @@ print_neighbors(netdissect_options *ndo,
                ND_TCHECK_7(bp);
                laddr = bp;
                bp += 4;
-               metric = EXTRACT_U_1(bp);
+               metric = GET_U_1(bp);
                bp++;
-               thresh = EXTRACT_U_1(bp);
+               thresh = GET_U_1(bp);
                bp++;
-               ncount = EXTRACT_U_1(bp);
+               ncount = GET_U_1(bp);
                bp++;
                len -= 7;
                while (--ncount >= 0) {
                        ND_TCHECK_4(bp);
-                       ND_PRINT((ndo, " [%s ->", ipaddr_string(ndo, laddr)));
-                       ND_PRINT((ndo, " %s, (%d/%d)]",
-                                  ipaddr_string(ndo, bp), metric, thresh));
+                       ND_PRINT(" [%s ->", ipaddr_string(ndo, laddr));
+                       ND_PRINT(" %s, (%u/%u)]",
+                                  ipaddr_string(ndo, bp), metric, thresh);
                        bp += 4;
                        len -= 4;
                }
@@ -298,41 +298,41 @@ print_neighbors2(netdissect_options *ndo,
        u_char metric, thresh, flags;
        int ncount;
 
-       ND_PRINT((ndo, " (v %u.%u):", major_version, minor_version));
+       ND_PRINT(" (v %u.%u):", major_version, minor_version);
 
        while (len > 0 && bp < ep) {
                ND_TCHECK_8(bp);
                laddr = bp;
                bp += 4;
-               metric = EXTRACT_U_1(bp);
+               metric = GET_U_1(bp);
                bp++;
-               thresh = EXTRACT_U_1(bp);
+               thresh = GET_U_1(bp);
                bp++;
-               flags = EXTRACT_U_1(bp);
+               flags = GET_U_1(bp);
                bp++;
-               ncount = EXTRACT_U_1(bp);
+               ncount = GET_U_1(bp);
                bp++;
                len -= 8;
                while (--ncount >= 0 && (len >= 4) && (bp + 4) <= ep) {
-                       ND_PRINT((ndo, " [%s -> ", ipaddr_string(ndo, laddr)));
-                       ND_PRINT((ndo, "%s (%d/%d", ipaddr_string(ndo, bp),
-                                    metric, thresh));
+                       ND_PRINT(" [%s -> ", ipaddr_string(ndo, laddr));
+                       ND_PRINT("%s (%u/%u", ipaddr_string(ndo, bp),
+                                    metric, thresh);
                        if (flags & DVMRP_NF_TUNNEL)
-                               ND_PRINT((ndo, "/tunnel"));
+                               ND_PRINT("/tunnel");
                        if (flags & DVMRP_NF_SRCRT)
-                               ND_PRINT((ndo, "/srcrt"));
+                               ND_PRINT("/srcrt");
                        if (flags & DVMRP_NF_QUERIER)
-                               ND_PRINT((ndo, "/querier"));
+                               ND_PRINT("/querier");
                        if (flags & DVMRP_NF_DISABLED)
-                               ND_PRINT((ndo, "/disabled"));
+                               ND_PRINT("/disabled");
                        if (flags & DVMRP_NF_DOWN)
-                               ND_PRINT((ndo, "/down"));
-                       ND_PRINT((ndo, ")]"));
+                               ND_PRINT("/down");
+                       ND_PRINT(")]");
                        bp += 4;
                        len -= 4;
                }
                if (ncount != -1) {
-                       ND_PRINT((ndo, " [|]"));
+                       ND_PRINT(" [|]");
                        return (0);
                }
        }
@@ -346,10 +346,10 @@ print_prune(netdissect_options *ndo,
             const u_char *bp)
 {
        ND_TCHECK_LEN(bp, 12);
-       ND_PRINT((ndo, " src %s grp %s", ipaddr_string(ndo, bp), ipaddr_string(ndo, bp + 4)));
+       ND_PRINT(" src %s grp %s", ipaddr_string(ndo, bp), ipaddr_string(ndo, bp + 4));
        bp += 8;
-       ND_PRINT((ndo, " timer "));
-       unsigned_relts_print(ndo, EXTRACT_BE_U_4(bp));
+       ND_PRINT(" timer ");
+       unsigned_relts_print(ndo, GET_BE_U_4(bp));
        return (0);
 trunc:
        return (-1);
@@ -360,7 +360,7 @@ print_graft(netdissect_options *ndo,
             const u_char *bp)
 {
        ND_TCHECK_8(bp);
-       ND_PRINT((ndo, " src %s grp %s", ipaddr_string(ndo, bp), ipaddr_string(ndo, bp + 4)));
+       ND_PRINT(" src %s grp %s", ipaddr_string(ndo, bp), ipaddr_string(ndo, bp + 4));
        return (0);
 trunc:
        return (-1);
@@ -371,7 +371,7 @@ print_graft_ack(netdissect_options *ndo,
                 const u_char *bp)
 {
        ND_TCHECK_8(bp);
-       ND_PRINT((ndo, " src %s grp %s", ipaddr_string(ndo, bp), ipaddr_string(ndo, bp + 4)));
+       ND_PRINT(" src %s grp %s", ipaddr_string(ndo, bp), ipaddr_string(ndo, bp + 4));
        return (0);
 trunc:
        return (-1);