X-Git-Url: https://git.tcpdump.org/tcpdump/blobdiff_plain/2897a032d0944cf5e36e47ce16e1b2ddab0916f4..refs/heads/master:/print-bt.c diff --git a/print-bt.c b/print-bt.c index 411642b4..290434b9 100644 --- a/print-bt.c +++ b/print-bt.c @@ -19,12 +19,11 @@ /* \summary: Bluetooth printer */ -#ifdef HAVE_CONFIG_H #include -#endif #include "netdissect-stdinc.h" +#define ND_LONGJMP_FROM_TCHECK #include "netdissect.h" #include "extract.h" @@ -46,30 +45,25 @@ typedef struct _bluetooth_h4_header { * 'h->len' is the length of the packet off the wire, and 'h->caplen' * is the number of bytes actually captured. */ -u_int +void bt_if_print(netdissect_options *ndo, const struct pcap_pkthdr *h, const u_char *p) { u_int length = h->len; u_int caplen = h->caplen; - const bluetooth_h4_header* hdr = (const bluetooth_h4_header*)p; + const bluetooth_h4_header *hdr = (const bluetooth_h4_header *)p; - ndo->ndo_protocol = "bt_if"; - if (caplen < BT_HDRLEN || length < BT_HDRLEN) - goto trunc; + ndo->ndo_protocol = "bluetooth"; + nd_print_protocol(ndo); + ND_TCHECK_LEN(p, BT_HDRLEN); + ndo->ndo_ll_hdr_len += BT_HDRLEN; caplen -= BT_HDRLEN; length -= BT_HDRLEN; p += BT_HDRLEN; - ND_TCHECK_4(&hdr->direction); if (ndo->ndo_eflag) - ND_PRINT("hci length %u, direction %s, ", length, - (EXTRACT_BE_U_4(hdr->direction)&0x1) ? "in" : "out"); + ND_PRINT(", hci length %u, direction %s", length, + (GET_BE_U_4(hdr->direction)&0x1) ? "in" : "out"); if (!ndo->ndo_suppress_default_print) ND_DEFAULTPRINT(p, caplen); - return (BT_HDRLEN); - -trunc: - nd_print_trunc(ndo); - return (BT_HDRLEN); } #endif