X-Git-Url: https://git.tcpdump.org/tcpdump/blobdiff_plain/8dbfd7f299b06e19c4ede893bf35f366386f5cad..refs/pull/1034/head:/print-ipoib.c diff --git a/print-ipoib.c b/print-ipoib.c index 5ebefd6c..3d431235 100644 --- a/print-ipoib.c +++ b/print-ipoib.c @@ -31,8 +31,6 @@ #include "netdissect-stdinc.h" -#include - #include "netdissect.h" #include "extract.h" #include "addrtoname.h" @@ -74,8 +72,15 @@ ipoib_print(netdissect_options *ndo, const u_char *p, u_int length, u_int caplen u_int orig_length; u_short ether_type; - if (caplen < IPOIB_HDRLEN || length < IPOIB_HDRLEN) { + if (caplen < IPOIB_HDRLEN) { + nd_print_trunc(ndo); + ndo->ndo_ll_hdr_len += caplen; + return; + } + + if (length < IPOIB_HDRLEN) { nd_print_trunc(ndo); + ndo->ndo_ll_hdr_len += length; return; } @@ -87,6 +92,7 @@ ipoib_print(netdissect_options *ndo, const u_char *p, u_int length, u_int caplen } orig_length = length; + ndo->ndo_ll_hdr_len += IPOIB_HDRLEN; length -= IPOIB_HDRLEN; caplen -= IPOIB_HDRLEN; ether_type = GET_BE_U_2(p + 40); @@ -111,11 +117,9 @@ ipoib_print(netdissect_options *ndo, const u_char *p, u_int length, u_int caplen * 'h->len' is the length of the packet off the wire, and 'h->caplen' * is the number of bytes actually captured. */ -u_int +void ipoib_if_print(netdissect_options *ndo, const struct pcap_pkthdr *h, const u_char *p) { ndo->ndo_protocol = "ipoib"; ipoib_print(ndo, p, h->len, h->caplen, NULL, NULL); - - return (IPOIB_HDRLEN); }