X-Git-Url: https://git.tcpdump.org/tcpdump/blobdiff_plain/99c91c3aec40b691641374f58e798bd8d6b657bd..d7b497cac78b6e22a66a6bae9bdec60a8044f67a:/print-rip.c diff --git a/print-rip.c b/print-rip.c index f9272d48..aae66f55 100644 --- a/print-rip.c +++ b/print-rip.c @@ -19,6 +19,8 @@ * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. */ +/* \summary: Routing Information Protocol (RIP) printer */ + #ifdef HAVE_CONFIG_H #include "config.h" #endif @@ -98,15 +100,15 @@ rip_entry_print_v1(netdissect_options *ndo, register u_short family; /* RFC 1058 */ - family = EXTRACT_16BITS(&ni->rip_family); + family = EXTRACT_BE_U_2(&ni->rip_family); if (family != BSD_AFNUM_INET && family != 0) { ND_PRINT((ndo, "\n\t AFI %s, ", tok2str(bsd_af_values, "Unknown (%u)", family))); print_unknown_data(ndo, (const uint8_t *)&ni->rip_family, "\n\t ", RIP_ROUTELEN); return; } - if (EXTRACT_16BITS(&ni->rip_tag) || - EXTRACT_32BITS(&ni->rip_dest_mask) || - EXTRACT_32BITS(&ni->rip_router)) { + if (EXTRACT_BE_U_2(&ni->rip_tag) || + EXTRACT_BE_U_4(&ni->rip_dest_mask) || + EXTRACT_BE_U_4(&ni->rip_router)) { /* MBZ fields not zero */ print_unknown_data(ndo, (const uint8_t *)&ni->rip_family, "\n\t ", RIP_ROUTELEN); return; @@ -114,12 +116,12 @@ rip_entry_print_v1(netdissect_options *ndo, if (family == 0) { ND_PRINT((ndo, "\n\t AFI 0, %s, metric: %u", ipaddr_string(ndo, &ni->rip_dest), - EXTRACT_32BITS(&ni->rip_metric))); + EXTRACT_BE_U_4(&ni->rip_metric))); return; } /* BSD_AFNUM_INET */ ND_PRINT((ndo, "\n\t %s, metric: %u", ipaddr_string(ndo, &ni->rip_dest), - EXTRACT_32BITS(&ni->rip_metric))); + EXTRACT_BE_U_4(&ni->rip_metric))); } static unsigned @@ -128,30 +130,31 @@ rip_entry_print_v2(netdissect_options *ndo, { register u_short family; - family = EXTRACT_16BITS(&ni->rip_family); + family = EXTRACT_BE_U_2(&ni->rip_family); if (family == 0xFFFF) { /* variable-sized authentication structures */ - uint16_t auth_type = EXTRACT_16BITS(&ni->rip_tag); + uint16_t auth_type = EXTRACT_BE_U_2(&ni->rip_tag); if (auth_type == 2) { register const u_char *p = (const u_char *)&ni->rip_dest; u_int i = 0; ND_PRINT((ndo, "\n\t Simple Text Authentication data: ")); for (; i < RIP_AUTHLEN; p++, i++) - ND_PRINT((ndo, "%c", ND_ISPRINT(*p) ? *p : '.')); + ND_PRINT((ndo, "%c", + ND_ISPRINT(EXTRACT_U_1(p)) ? EXTRACT_U_1(p) : '.')); } else if (auth_type == 3) { ND_PRINT((ndo, "\n\t Auth header:")); - ND_PRINT((ndo, " Packet Len %u,", EXTRACT_16BITS((const uint8_t *)ni + 4))); + ND_PRINT((ndo, " Packet Len %u,", EXTRACT_BE_U_2((const uint8_t *)ni + 4))); ND_PRINT((ndo, " Key-ID %u,", *((const uint8_t *)ni + 6))); ND_PRINT((ndo, " Auth Data Len %u,", *((const uint8_t *)ni + 7))); - ND_PRINT((ndo, " SeqNo %u,", EXTRACT_32BITS(&ni->rip_dest_mask))); - ND_PRINT((ndo, " MBZ %u,", EXTRACT_32BITS(&ni->rip_router))); - ND_PRINT((ndo, " MBZ %u", EXTRACT_32BITS(&ni->rip_metric))); + ND_PRINT((ndo, " SeqNo %u,", EXTRACT_BE_U_4(&ni->rip_dest_mask))); + ND_PRINT((ndo, " MBZ %u,", EXTRACT_BE_U_4(&ni->rip_router))); + ND_PRINT((ndo, " MBZ %u", EXTRACT_BE_U_4(&ni->rip_metric))); } else if (auth_type == 1) { ND_PRINT((ndo, "\n\t Auth trailer:")); print_unknown_data(ndo, (const uint8_t *)&ni->rip_dest, "\n\t ", remaining); return remaining; /* AT spans till the packet end */ } else { ND_PRINT((ndo, "\n\t Unknown (%u) Authentication data:", - EXTRACT_16BITS(&ni->rip_tag))); + EXTRACT_BE_U_2(&ni->rip_tag))); print_unknown_data(ndo, (const uint8_t *)&ni->rip_dest, "\n\t ", remaining); } } else if (family != BSD_AFNUM_INET && family != 0) { @@ -161,10 +164,10 @@ rip_entry_print_v2(netdissect_options *ndo, ND_PRINT((ndo, "\n\t AFI %s, %15s/%-2d, tag 0x%04x, metric: %u, next-hop: ", tok2str(bsd_af_values, "%u", family), ipaddr_string(ndo, &ni->rip_dest), - mask2plen(EXTRACT_32BITS(&ni->rip_dest_mask)), - EXTRACT_16BITS(&ni->rip_tag), - EXTRACT_32BITS(&ni->rip_metric))); - if (EXTRACT_32BITS(&ni->rip_router)) + mask2plen(EXTRACT_BE_U_4(&ni->rip_dest_mask)), + EXTRACT_BE_U_2(&ni->rip_tag), + EXTRACT_BE_U_4(&ni->rip_metric))); + if (EXTRACT_BE_U_4(&ni->rip_router)) ND_PRINT((ndo, "%s", ipaddr_string(ndo, &ni->rip_router))); else ND_PRINT((ndo, "self"));