X-Git-Url: https://git.tcpdump.org/tcpdump/blobdiff_plain/d08b4abef4de825b3aecbb7c7e7601ac010806fc..1a04b92e365f5ed01ca38619b41bcc4fc9cbd63c:/print-calm-fast.c diff --git a/print-calm-fast.c b/print-calm-fast.c index 3d58fe0d..6fa91a8f 100644 --- a/print-calm-fast.c +++ b/print-calm-fast.c @@ -15,13 +15,16 @@ * Original code by Ola Martin Lykkja (ola.lykkja@q-free.com) */ +/* \summary: Communication access for land mobiles (CALM) printer */ + #ifdef HAVE_CONFIG_H #include "config.h" #endif -#include +#include #include "netdissect.h" +#include "extract.h" #include "addrtoname.h" /* @@ -35,19 +38,33 @@ * to the calm header of the packet. */ void -calm_fast_print(netdissect_options *ndo, const u_char *eth, const u_char *bp, u_int length) +calm_fast_print(netdissect_options *ndo, const u_char *bp, u_int length, const struct lladdr_info *src) { - int srcNwref = bp[0]; - int dstNwref = bp[1]; + int srcNwref; + int dstNwref; + + 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 src:%s; ", etheraddr_string(eth+6))); + ND_PRINT((ndo, "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)); if (ndo->ndo_vflag) - ndo->ndo_default_print(ndo, bp, length); + ND_DEFAULTPRINT(bp, length); + return; + +trunc: + ND_PRINT((ndo, "[|calm fast]")); + return; }