X-Git-Url: https://git.tcpdump.org/tcpdump/blobdiff_plain/6ec714988caac3bf9fedc766ae51a2248896ec80..HEAD:/print-calm-fast.c diff --git a/print-calm-fast.c b/print-calm-fast.c index 6fa91a8f..5b79337a 100644 --- a/print-calm-fast.c +++ b/print-calm-fast.c @@ -17,12 +17,11 @@ /* \summary: Communication access for land mobiles (CALM) printer */ -#ifdef HAVE_CONFIG_H -#include "config.h" -#endif +#include -#include +#include "netdissect-stdinc.h" +#define ND_LONGJMP_FROM_TCHECK #include "netdissect.h" #include "extract.h" #include "addrtoname.h" @@ -40,37 +39,31 @@ void calm_fast_print(netdissect_options *ndo, const u_char *bp, u_int length, const struct lladdr_info *src) { - int srcNwref; - int dstNwref; + ndo->ndo_protocol = "calm_fast"; - ND_TCHECK_2(bp); - if (length < 2) - goto trunc; - srcNwref = EXTRACT_U_1(bp); - dstNwref = EXTRACT_U_1(bp + 1); - length -= 2; - bp += 2; - - ND_PRINT((ndo, "CALM FAST")); + ND_PRINT("CALM FAST"); if (src != NULL) - ND_PRINT((ndo, " src:%s", (src->addr_string)(ndo, src->addr))); - ND_PRINT((ndo, "; ")); - ND_PRINT((ndo, "SrcNwref:%d; ", srcNwref)); - ND_PRINT((ndo, "DstNwref:%d; ", dstNwref)); + ND_PRINT(" src:%s", (src->addr_string)(ndo, src->addr)); + ND_PRINT("; "); + + if (length < 2) { + ND_PRINT(" (length %u < 2)", length); + goto invalid; + } + + ND_PRINT("SrcNwref:%u; ", GET_U_1(bp)); + length -= 1; + bp += 1; + + ND_PRINT("DstNwref:%u; ", GET_U_1(bp)); + length -= 1; + bp += 1; if (ndo->ndo_vflag) ND_DEFAULTPRINT(bp, length); return; -trunc: - ND_PRINT((ndo, "[|calm fast]")); - return; +invalid: + nd_print_invalid(ndo); + ND_TCHECK_LEN(bp, length); } - - -/* - * Local Variables: - * c-style: whitesmith - * c-basic-offset: 8 - * End: - */