X-Git-Url: https://git.tcpdump.org/tcpdump/blobdiff_plain/07ac438e08e5ffed3539e10d78f1cfc7d221d591..1a04b92e365f5ed01ca38619b41bcc4fc9cbd63c:/print-babel.c diff --git a/print-babel.c b/print-babel.c index 5c5ab308..3f0166d1 100644 --- a/print-babel.c +++ b/print-babel.c @@ -377,7 +377,7 @@ babel_print_v2(netdissect_options *ndo, ICHECK(i, 2); len = EXTRACT_U_1(message + 1); - ND_TCHECK2(*message, 2 + len); + ND_TCHECK_LEN(message, 2 + len); ICHECK(i, 2 + len); switch(type) { @@ -501,12 +501,12 @@ babel_print_v2(netdissect_options *ndo, u_char prefix[16]; ND_PRINT((ndo, "\n\tUpdate")); if(len < 10) goto invalid; - plen = message[4] + (message[2] == 1 ? 96 : 0); + plen = EXTRACT_U_1(message + 4) + (EXTRACT_U_1(message + 2) == 1 ? 96 : 0); rc = network_prefix(EXTRACT_U_1(message + 2), EXTRACT_U_1(message + 4), EXTRACT_U_1(message + 5), message + 12, - message[2] == 1 ? v4_prefix : v6_prefix, + EXTRACT_U_1(message + 2) == 1 ? v4_prefix : v6_prefix, len - 10, prefix); if(rc < 0) goto invalid; interval = EXTRACT_BE_U_2(message + 6); @@ -519,7 +519,7 @@ babel_print_v2(netdissect_options *ndo, format_prefix(ndo, prefix, plen), metric, seqno, format_interval_update(interval))); if(EXTRACT_U_1(message + 3) & 0x80) { - if(message[2] == 1) + if(EXTRACT_U_1(message + 2) == 1) memcpy(v4_prefix, prefix, 16); else memcpy(v6_prefix, prefix, 16); @@ -539,7 +539,7 @@ babel_print_v2(netdissect_options *ndo, u_char prefix[16], plen; ND_PRINT((ndo, "\n\tRequest ")); if(len < 2) goto invalid; - plen = message[3] + (message[2] == 1 ? 96 : 0); + plen = EXTRACT_U_1(message + 3) + (EXTRACT_U_1(message + 2) == 1 ? 96 : 0); rc = network_prefix(EXTRACT_U_1(message + 2), EXTRACT_U_1(message + 3), 0, message + 4, NULL, len - 2, prefix); @@ -564,7 +564,7 @@ babel_print_v2(netdissect_options *ndo, EXTRACT_U_1(message + 3), 0, message + 16, NULL, len - 14, prefix); if(rc < 0) goto invalid; - plen = message[3] + (message[2] == 1 ? 96 : 0); + plen = EXTRACT_U_1(message + 3) + (EXTRACT_U_1(message + 2) == 1 ? 96 : 0); ND_PRINT((ndo, "(%u hops) for %s seqno %u id %s", EXTRACT_U_1(message + 6), format_prefix(ndo, prefix, plen), seqno, format_id(message + 8)));