X-Git-Url: https://git.tcpdump.org/tcpdump/blobdiff_plain/4ef024c8e94459e3ab9afae90e1948406e1d04db..refs/heads/mcr-macro-update-1:/print-cip.c diff --git a/print-cip.c b/print-cip.c index a123b69f..8838dc99 100644 --- a/print-cip.c +++ b/print-cip.c @@ -20,15 +20,15 @@ * */ -/* \summary: Classical-IP over ATM printer */ +/* \summary: Linux Classical IP over ATM printer */ #ifdef HAVE_CONFIG_H -#include "config.h" +#include #endif #include -#include +#include "netdissect-stdinc.h" #include "netdissect.h" #include "addrtoname.h" @@ -41,13 +41,13 @@ static const unsigned char rfcllc[] = { 0x00, 0x00 }; -static inline void +static void cip_print(netdissect_options *ndo, u_int length) { /* * There is no MAC-layer header, so just print the length. */ - ND_PRINT((ndo, "%u: ", length)); + ND_PRINT("%u: ", length); } /* @@ -56,7 +56,7 @@ cip_print(netdissect_options *ndo, u_int length) * 'h->len' is the length of the packet off the wire, and 'h->caplen' * is the number of bytes actually captured. */ -u_int +void cip_if_print(netdissect_options *ndo, const struct pcap_pkthdr *h, const u_char *p) { u_int caplen = h->caplen; @@ -64,6 +64,7 @@ cip_if_print(netdissect_options *ndo, const struct pcap_pkthdr *h, const u_char size_t cmplen; int llc_hdrlen; + ndo->ndo_protocol = "cip"; cmplen = sizeof(rfcllc); if (cmplen > caplen) cmplen = caplen; @@ -74,8 +75,8 @@ cip_if_print(netdissect_options *ndo, const struct pcap_pkthdr *h, const u_char cip_print(ndo, length); if (cmplen == 0) { - ND_PRINT((ndo, "[|cip]")); - return 0; + nd_print_trunc(ndo); + return; } if (memcmp(rfcllc, p, cmplen) == 0) { /* @@ -96,13 +97,5 @@ cip_if_print(netdissect_options *ndo, const struct pcap_pkthdr *h, const u_char ip_print(ndo, p, length); } - return (llc_hdrlen); + ndo->ndo_ll_hdr_len += llc_hdrlen; } - - -/* - * Local Variables: - * c-style: whitesmith - * c-basic-offset: 8 - * End: - */