3 * BlueZ - Bluetooth protocol stack for Linux
5 * Copyright (C) 2011-2014 Intel Corporation
6 * Copyright (C) 2002-2010 Marcel Holtmann <marcel@holtmann.org>
9 * This library is free software; you can redistribute it and/or
10 * modify it under the terms of the GNU Lesser General Public
11 * License as published by the Free Software Foundation; either
12 * version 2.1 of the License, or (at your option) any later version.
14 * This library is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
17 * Lesser General Public License for more details.
19 * You should have received a copy of the GNU Lesser General Public
20 * License along with this library; if not, write to the Free Software
21 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
39 #include <sys/socket.h>
41 #include "lib/bluetooth.h"
43 #include "lib/hci_lib.h"
45 #include "src/shared/util.h"
46 #include "src/shared/btsnoop.h"
60 #define COLOR_INDEX_LABEL COLOR_WHITE
61 #define COLOR_TIMESTAMP COLOR_YELLOW
63 #define COLOR_NEW_INDEX COLOR_GREEN
64 #define COLOR_DEL_INDEX COLOR_RED
65 #define COLOR_OPEN_INDEX COLOR_GREEN
66 #define COLOR_CLOSE_INDEX COLOR_RED
67 #define COLOR_INDEX_INFO COLOR_GREEN
68 #define COLOR_VENDOR_DIAG COLOR_YELLOW
70 #define COLOR_HCI_COMMAND COLOR_BLUE
71 #define COLOR_HCI_COMMAND_UNKNOWN COLOR_WHITE_BG
73 #define COLOR_HCI_EVENT COLOR_MAGENTA
74 #define COLOR_HCI_EVENT_UNKNOWN COLOR_WHITE_BG
76 #define COLOR_HCI_ACLDATA COLOR_CYAN
77 #define COLOR_HCI_SCODATA COLOR_YELLOW
79 #define COLOR_UNKNOWN_ERROR COLOR_WHITE_BG
80 #define COLOR_UNKNOWN_FEATURE_BIT COLOR_WHITE_BG
81 #define COLOR_UNKNOWN_COMMAND_BIT COLOR_WHITE_BG
82 #define COLOR_UNKNOWN_EVENT_MASK COLOR_WHITE_BG
83 #define COLOR_UNKNOWN_LE_STATES COLOR_WHITE_BG
84 #define COLOR_UNKNOWN_SERVICE_CLASS COLOR_WHITE_BG
85 #define COLOR_UNKNOWN_PKT_TYPE_BIT COLOR_WHITE_BG
87 #define COLOR_PHY_PACKET COLOR_BLUE
89 static time_t time_offset = ((time_t) -1);
90 static int priority_level = BTSNOOP_PRIORITY_INFO;
91 static unsigned long filter_mask = 0;
92 static bool index_filter = false;
93 static uint16_t index_number = 0;
94 static uint16_t index_current = 0;
96 #define UNKNOWN_MANUFACTURER 0xffff
105 static struct conn_data conn_list[MAX_CONN];
107 static void assign_handle(uint16_t handle, uint8_t type)
111 for (i = 0; i < MAX_CONN; i++) {
112 if (conn_list[i].handle == 0x0000) {
113 conn_list[i].handle = handle;
114 conn_list[i].type = type;
120 static void release_handle(uint16_t handle)
124 for (i = 0; i < MAX_CONN; i++) {
125 if (conn_list[i].handle == handle) {
126 conn_list[i].handle = 0x0000;
127 conn_list[i].type = 0x00;
133 static uint8_t get_type(uint16_t handle)
137 for (i = 0; i < MAX_CONN; i++) {
138 if (conn_list[i].handle == handle)
139 return conn_list[i].type;
145 void packet_set_filter(unsigned long filter)
147 filter_mask = filter;
150 void packet_add_filter(unsigned long filter)
153 filter &= ~PACKET_FILTER_SHOW_INDEX;
155 filter_mask |= filter;
158 void packet_del_filter(unsigned long filter)
160 filter_mask &= ~filter;
163 void packet_set_priority(const char *priority)
168 if (!strcasecmp(priority, "debug"))
169 priority_level = BTSNOOP_PRIORITY_DEBUG;
171 priority_level = atoi(priority);
174 void packet_select_index(uint16_t index)
176 filter_mask &= ~PACKET_FILTER_SHOW_INDEX;
179 index_number = index;
182 #define print_space(x) printf("%*c", (x), ' ');
184 static void print_packet(struct timeval *tv, struct ucred *cred,
185 uint16_t index, char ident,
186 const char *color, const char *label,
187 const char *text, const char *extra)
189 int col = num_columns();
190 char line[256], ts_str[64];
191 int n, ts_len = 0, ts_pos = 0, len = 0, pos = 0;
193 if ((filter_mask & PACKET_FILTER_SHOW_INDEX) &&
194 index != HCI_DEV_NONE) {
196 n = sprintf(ts_str + ts_pos, "%s", COLOR_INDEX_LABEL);
201 n = sprintf(ts_str + ts_pos, " [hci%d]", index);
209 time_t t = tv->tv_sec;
212 localtime_r(&t, &tm);
215 n = sprintf(ts_str + ts_pos, "%s", COLOR_TIMESTAMP);
220 if (filter_mask & PACKET_FILTER_SHOW_DATE) {
221 n = sprintf(ts_str + ts_pos, " %04d-%02d-%02d",
222 tm.tm_year + 1900, tm.tm_mon + 1, tm.tm_mday);
229 if (filter_mask & PACKET_FILTER_SHOW_TIME) {
230 n = sprintf(ts_str + ts_pos, " %02d:%02d:%02d.%06lu",
231 tm.tm_hour, tm.tm_min, tm.tm_sec, tv->tv_usec);
238 if (filter_mask & PACKET_FILTER_SHOW_TIME_OFFSET) {
239 n = sprintf(ts_str + ts_pos, " %lu.%06lu",
240 tv->tv_sec - time_offset, tv->tv_usec);
249 n = sprintf(ts_str + ts_pos, "%s", COLOR_OFF);
255 n = sprintf(line + pos, "%s", color);
260 n = sprintf(line + pos, "%c %s", ident, label ? label : "");
267 int extra_len = extra ? strlen(extra) : 0;
268 int max_len = col - len - extra_len - ts_len - 3;
270 n = snprintf(line + pos, max_len + 1, "%s%s",
271 label ? ": " : "", text);
273 line[pos + max_len - 1] = '.';
274 line[pos + max_len - 2] = '.';
275 if (line[pos + max_len - 3] == ' ')
276 line[pos + max_len - 3] = '.';
288 n = sprintf(line + pos, "%s", COLOR_OFF);
294 n = sprintf(line + pos, " %s", extra);
304 print_space(col - len - ts_len - 1);
305 printf("%s%s\n", use_color() ? COLOR_TIMESTAMP : "", ts_str);
307 printf("%s\n", line);
310 static const struct {
313 } error2str_table[] = {
315 { 0x01, "Unknown HCI Command" },
316 { 0x02, "Unknown Connection Identifier" },
317 { 0x03, "Hardware Failure" },
318 { 0x04, "Page Timeout" },
319 { 0x05, "Authentication Failure" },
320 { 0x06, "PIN or Key Missing" },
321 { 0x07, "Memory Capacity Exceeded" },
322 { 0x08, "Connection Timeout" },
323 { 0x09, "Connection Limit Exceeded" },
324 { 0x0a, "Synchronous Connection Limit to a Device Exceeded" },
325 { 0x0b, "ACL Connection Already Exists" },
326 { 0x0c, "Command Disallowed" },
327 { 0x0d, "Connection Rejected due to Limited Resources" },
328 { 0x0e, "Connection Rejected due to Security Reasons" },
329 { 0x0f, "Connection Rejected due to Unacceptable BD_ADDR" },
330 { 0x10, "Connection Accept Timeout Exceeded" },
331 { 0x11, "Unsupported Feature or Parameter Value" },
332 { 0x12, "Invalid HCI Command Parameters" },
333 { 0x13, "Remote User Terminated Connection" },
334 { 0x14, "Remote Device Terminated due to Low Resources" },
335 { 0x15, "Remote Device Terminated due to Power Off" },
336 { 0x16, "Connection Terminated By Local Host" },
337 { 0x17, "Repeated Attempts" },
338 { 0x18, "Pairing Not Allowed" },
339 { 0x19, "Unknown LMP PDU" },
340 { 0x1a, "Unsupported Remote Feature / Unsupported LMP Feature" },
341 { 0x1b, "SCO Offset Rejected" },
342 { 0x1c, "SCO Interval Rejected" },
343 { 0x1d, "SCO Air Mode Rejected" },
344 { 0x1e, "Invalid LMP Parameters / Invalid LL Parameters" },
345 { 0x1f, "Unspecified Error" },
346 { 0x20, "Unsupported LMP Parameter Value / "
347 "Unsupported LL Parameter Value" },
348 { 0x21, "Role Change Not Allowed" },
349 { 0x22, "LMP Response Timeout / LL Response Timeout" },
350 { 0x23, "LMP Error Transaction Collision" },
351 { 0x24, "LMP PDU Not Allowed" },
352 { 0x25, "Encryption Mode Not Acceptable" },
353 { 0x26, "Link Key cannot be Changed" },
354 { 0x27, "Requested QoS Not Supported" },
355 { 0x28, "Instant Passed" },
356 { 0x29, "Pairing With Unit Key Not Supported" },
357 { 0x2a, "Different Transaction Collision" },
358 { 0x2b, "Reserved" },
359 { 0x2c, "QoS Unacceptable Parameter" },
360 { 0x2d, "QoS Rejected" },
361 { 0x2e, "Channel Classification Not Supported" },
362 { 0x2f, "Insufficient Security" },
363 { 0x30, "Parameter Out Of Manadatory Range" },
364 { 0x31, "Reserved" },
365 { 0x32, "Role Switch Pending" },
366 { 0x33, "Reserved" },
367 { 0x34, "Reserved Slot Violation" },
368 { 0x35, "Role Switch Failed" },
369 { 0x36, "Extended Inquiry Response Too Large" },
370 { 0x37, "Secure Simple Pairing Not Supported By Host" },
371 { 0x38, "Host Busy - Pairing" },
372 { 0x39, "Connection Rejected due to No Suitable Channel Found" },
373 { 0x3a, "Controller Busy" },
374 { 0x3b, "Unacceptable Connection Parameters" },
375 { 0x3c, "Directed Advertising Timeout" },
376 { 0x3d, "Connection Terminated due to MIC Failure" },
377 { 0x3e, "Connection Failed to be Established" },
378 { 0x3f, "MAC Connection Failed" },
379 { 0x40, "Coarse Clock Adjustment Rejected "
380 "but Will Try to Adjust Using Clock Dragging" },
384 static void print_error(const char *label, uint8_t error)
386 const char *str = "Unknown";
387 const char *color_on, *color_off;
391 for (i = 0; error2str_table[i].str; i++) {
392 if (error2str_table[i].error == error) {
393 str = error2str_table[i].str;
402 color_on = COLOR_UNKNOWN_ERROR;
404 color_on = COLOR_RED;
406 color_on = COLOR_GREEN;
407 color_off = COLOR_OFF;
413 print_field("%s: %s%s%s (0x%2.2x)", label,
414 color_on, str, color_off, error);
417 static void print_status(uint8_t status)
419 print_error("Status", status);
422 static void print_reason(uint8_t reason)
424 print_error("Reason", reason);
427 void packet_print_error(const char *label, uint8_t error)
429 print_error(label, error);
432 static void print_addr_type(const char *label, uint8_t addr_type)
448 print_field("%s: %s (0x%2.2x)", label, str, addr_type);
451 static void print_own_addr_type(uint8_t addr_type)
469 print_field("Own address type: %s (0x%2.2x)", str, addr_type);
472 static void print_peer_addr_type(const char *label, uint8_t addr_type)
484 str = "Resolved Public";
487 str = "Resolved Random";
494 print_field("%s: %s (0x%2.2x)", label, str, addr_type);
497 static void print_addr_resolve(const char *label, const uint8_t *addr,
498 uint8_t addr_type, bool resolve)
506 if (!hwdb_get_company(addr, &company))
510 print_field("%s: %2.2X:%2.2X:%2.2X:%2.2X:%2.2X:%2.2X"
511 " (%s)", label, addr[5], addr[4],
517 print_field("%s: %2.2X:%2.2X:%2.2X:%2.2X:%2.2X:%2.2X"
518 " (OUI %2.2X-%2.2X-%2.2X)", label,
519 addr[5], addr[4], addr[3],
520 addr[2], addr[1], addr[0],
521 addr[5], addr[4], addr[3]);
526 switch ((addr[5] & 0xc0) >> 6) {
528 str = "Non-Resolvable";
541 print_field("%s: %2.2X:%2.2X:%2.2X:%2.2X:%2.2X:%2.2X (%s)",
542 label, addr[5], addr[4], addr[3],
543 addr[2], addr[1], addr[0], str);
545 if (resolve && (addr[5] & 0xc0) == 0x40) {
546 uint8_t ident[6], ident_type;
548 if (keys_resolve_identity(addr, ident, &ident_type)) {
549 print_addr_type(" Identity type", ident_type);
550 print_addr_resolve(" Identity", ident,
556 print_field("%s: %2.2X-%2.2X-%2.2X-%2.2X-%2.2X-%2.2X",
557 label, addr[5], addr[4], addr[3],
558 addr[2], addr[1], addr[0]);
563 static void print_addr(const char *label, const uint8_t *addr,
566 print_addr_resolve(label, addr, addr_type, true);
569 static void print_bdaddr(const uint8_t *bdaddr)
571 print_addr("Address", bdaddr, 0x00);
574 static void print_lt_addr(uint8_t lt_addr)
576 print_field("LT address: %d", lt_addr);
579 static void print_handle(uint16_t handle)
581 print_field("Handle: %d", le16_to_cpu(handle));
584 static void print_phy_handle(uint8_t phy_handle)
586 print_field("Physical handle: %d", phy_handle);
589 static const struct {
592 } pkt_type_table[] = {
593 { 1, "2-DH1 may not be used" },
594 { 2, "3-DH1 may not be used" },
595 { 3, "DM1 may be used" },
596 { 4, "DH1 may be used" },
597 { 8, "2-DH3 may not be used" },
598 { 9, "3-DH3 may not be used" },
599 { 10, "DM3 may be used" },
600 { 11, "DH3 may be used" },
601 { 12, "3-DH5 may not be used" },
602 { 13, "3-DH5 may not be used" },
603 { 14, "DM5 may be used" },
604 { 15, "DH5 may be used" },
608 static void print_pkt_type(uint16_t pkt_type)
613 print_field("Packet type: 0x%4.4x", le16_to_cpu(pkt_type));
615 mask = le16_to_cpu(pkt_type);
617 for (i = 0; pkt_type_table[i].str; i++) {
618 if (le16_to_cpu(pkt_type) & (1 << pkt_type_table[i].bit)) {
619 print_field(" %s", pkt_type_table[i].str);
620 mask &= ~(1 << pkt_type_table[i].bit);
625 print_text(COLOR_UNKNOWN_PKT_TYPE_BIT,
626 " Unknown packet types (0x%4.4x)", mask);
629 static const struct {
632 } pkt_type_sco_table[] = {
633 { 0, "HV1 may be used" },
634 { 1, "HV2 may be used" },
635 { 2, "HV3 may be used" },
636 { 3, "EV3 may be used" },
637 { 4, "EV4 may be used" },
638 { 5, "EV5 may be used" },
639 { 6, "2-EV3 may not be used" },
640 { 7, "3-EV3 may not be used" },
641 { 8, "2-EV5 may not be used" },
642 { 9, "3-EV5 may not be used" },
646 static void print_pkt_type_sco(uint16_t pkt_type)
651 print_field("Packet type: 0x%4.4x", le16_to_cpu(pkt_type));
653 mask = le16_to_cpu(pkt_type);
655 for (i = 0; pkt_type_sco_table[i].str; i++) {
656 if (le16_to_cpu(pkt_type) & (1 << pkt_type_sco_table[i].bit)) {
657 print_field(" %s", pkt_type_sco_table[i].str);
658 mask &= ~(1 << pkt_type_sco_table[i].bit);
663 print_text(COLOR_UNKNOWN_PKT_TYPE_BIT,
664 " Unknown packet types (0x%4.4x)", mask);
667 static void print_iac(const uint8_t *lap)
669 const char *str = "";
671 if (lap[2] == 0x9e && lap[1] == 0x8b) {
674 str = " (General Inquiry)";
677 str = " (Limited Inquiry)";
682 print_field("Access code: 0x%2.2x%2.2x%2.2x%s",
683 lap[2], lap[1], lap[0], str);
686 static void print_auth_enable(uint8_t enable)
692 str = "Authentication not required";
695 str = "Authentication required for all connections";
702 print_field("Enable: %s (0x%2.2x)", str, enable);
705 static void print_encrypt_mode(uint8_t mode)
711 str = "Encryption not required";
714 str = "Encryption required for all connections";
721 print_field("Mode: %s (0x%2.2x)", str, mode);
724 static const struct {
727 } svc_class_table[] = {
728 { 0, "Positioning (Location identification)" },
729 { 1, "Networking (LAN, Ad hoc)" },
730 { 2, "Rendering (Printing, Speaker)" },
731 { 3, "Capturing (Scanner, Microphone)" },
732 { 4, "Object Transfer (v-Inbox, v-Folder)" },
733 { 5, "Audio (Speaker, Microphone, Headset)" },
734 { 6, "Telephony (Cordless telephony, Modem, Headset)" },
735 { 7, "Information (WEB-server, WAP-server)" },
739 static const struct {
742 } major_class_computer_table[] = {
743 { 0x00, "Uncategorized, code for device not assigned" },
744 { 0x01, "Desktop workstation" },
745 { 0x02, "Server-class computer" },
747 { 0x04, "Handheld PC/PDA (clam shell)" },
748 { 0x05, "Palm sized PC/PDA" },
749 { 0x06, "Wearable computer (Watch sized)" },
754 static const char *major_class_computer(uint8_t minor)
758 for (i = 0; major_class_computer_table[i].str; i++) {
759 if (major_class_computer_table[i].val == minor)
760 return major_class_computer_table[i].str;
766 static const struct {
769 } major_class_phone_table[] = {
770 { 0x00, "Uncategorized, code for device not assigned" },
771 { 0x01, "Cellular" },
772 { 0x02, "Cordless" },
773 { 0x03, "Smart phone" },
774 { 0x04, "Wired modem or voice gateway" },
775 { 0x05, "Common ISDN Access" },
779 static const char *major_class_phone(uint8_t minor)
783 for (i = 0; major_class_phone_table[i].str; i++) {
784 if (major_class_phone_table[i].val == minor)
785 return major_class_phone_table[i].str;
791 static const struct {
794 } major_class_av_table[] = {
795 { 0x00, "Uncategorized, code for device not assigned" },
796 { 0x01, "Wearable Headset Device" },
797 { 0x02, "Hands-free Device" },
798 { 0x04, "Microphone" },
799 { 0x05, "Loudspeaker" },
800 { 0x06, "Headphones" },
801 { 0x07, "Portable Audio" },
802 { 0x08, "Car audio" },
803 { 0x09, "Set-top box" },
804 { 0x0a, "HiFi Audio Device" },
806 { 0x0c, "Video Camera" },
807 { 0x0d, "Camcorder" },
808 { 0x0e, "Video Monitor" },
809 { 0x0f, "Video Display and Loudspeaker" },
810 { 0x10, "Video Conferencing" },
811 { 0x12, "Gaming/Toy" },
815 static const char *major_class_av(uint8_t minor)
819 for (i = 0; major_class_av_table[i].str; i++) {
820 if (major_class_av_table[i].val == minor)
821 return major_class_av_table[i].str;
827 static const struct {
830 } major_class_wearable_table[] = {
831 { 0x01, "Wrist Watch" },
839 static const char *major_class_wearable(uint8_t minor)
843 for (i = 0; major_class_wearable_table[i].str; i++) {
844 if (major_class_wearable_table[i].val == minor)
845 return major_class_wearable_table[i].str;
851 static const struct {
854 const char *(*func)(uint8_t minor);
855 } major_class_table[] = {
856 { 0x00, "Miscellaneous" },
857 { 0x01, "Computer (desktop, notebook, PDA, organizers)",
858 major_class_computer },
859 { 0x02, "Phone (cellular, cordless, payphone, modem)",
861 { 0x03, "LAN /Network Access point" },
862 { 0x04, "Audio/Video (headset, speaker, stereo, video, vcr)",
864 { 0x05, "Peripheral (mouse, joystick, keyboards)" },
865 { 0x06, "Imaging (printing, scanner, camera, display)" },
866 { 0x07, "Wearable", major_class_wearable },
869 { 0x1f, "Uncategorized, specific device code not specified" },
873 static void print_dev_class(const uint8_t *dev_class)
875 uint8_t mask, major_cls, minor_cls;
876 const char *major_str = NULL;
877 const char *minor_str = NULL;
880 print_field("Class: 0x%2.2x%2.2x%2.2x",
881 dev_class[2], dev_class[1], dev_class[0]);
883 if ((dev_class[0] & 0x03) != 0x00) {
884 print_field(" Format type: 0x%2.2x", dev_class[0] & 0x03);
885 print_text(COLOR_ERROR, " invalid format type");
889 major_cls = dev_class[1] & 0x1f;
890 minor_cls = (dev_class[0] & 0xfc) >> 2;
892 for (i = 0; major_class_table[i].str; i++) {
893 if (major_class_table[i].val == major_cls) {
894 major_str = major_class_table[i].str;
896 if (!major_class_table[i].func)
899 minor_str = major_class_table[i].func(minor_cls);
905 print_field(" Major class: %s", major_str);
907 print_field(" Minor class: %s", minor_str);
909 print_field(" Minor class: 0x%2.2x", minor_cls);
911 print_field(" Major class: 0x%2.2x", major_cls);
912 print_field(" Minor class: 0x%2.2x", minor_cls);
915 if (dev_class[1] & 0x20)
916 print_field(" Limited Discoverable Mode");
918 if ((dev_class[1] & 0xc0) != 0x00) {
919 print_text(COLOR_ERROR, " invalid service class");
925 for (i = 0; svc_class_table[i].str; i++) {
926 if (dev_class[2] & (1 << svc_class_table[i].bit)) {
927 print_field(" %s", svc_class_table[i].str);
928 mask &= ~(1 << svc_class_table[i].bit);
933 print_text(COLOR_UNKNOWN_SERVICE_CLASS,
934 " Unknown service class (0x%2.2x)", mask);
937 static const struct {
941 } appearance_table[] = {
942 { 0, true, "Unknown" },
943 { 64, true, "Phone" },
944 { 128, true, "Computer" },
945 { 192, true, "Watch" },
946 { 193, false, "Sports Watch" },
947 { 256, true, "Clock" },
948 { 320, true, "Display" },
949 { 384, true, "Remote Control" },
950 { 448, true, "Eye-glasses" },
951 { 512, true, "Tag" },
952 { 576, true, "Keyring" },
953 { 640, true, "Media Player" },
954 { 704, true, "Barcode Scanner" },
955 { 768, true, "Thermometer" },
956 { 769, false, "Thermometer: Ear" },
957 { 832, true, "Heart Rate Sensor" },
958 { 833, false, "Heart Rate Belt" },
959 { 896, true, "Blood Pressure" },
960 { 897, false, "Blood Pressure: Arm" },
961 { 898, false, "Blood Pressure: Wrist" },
962 { 960, true, "Human Interface Device" },
963 { 961, false, "Keyboard" },
964 { 962, false, "Mouse" },
965 { 963, false, "Joystick" },
966 { 964, false, "Gamepad" },
967 { 965, false, "Digitizer Tablet" },
968 { 966, false, "Card Reader" },
969 { 967, false, "Digital Pen" },
970 { 968, false, "Barcode Scanner" },
971 { 1024, true, "Glucose Meter" },
972 { 1088, true, "Running Walking Sensor" },
973 { 1089, false, "Running Walking Sensor: In-Shoe" },
974 { 1090, false, "Running Walking Sensor: On-Shoe" },
975 { 1091, false, "Running Walking Sensor: On-Hip" },
976 { 1152, true, "Cycling" },
977 { 1153, false, "Cycling: Cycling Computer" },
978 { 1154, false, "Cycling: Speed Sensor" },
979 { 1155, false, "Cycling: Cadence Sensor" },
980 { 1156, false, "Cycling: Power Sensor" },
981 { 1157, false, "Cycling: Speed and Cadence Sensor" },
982 { 1216, true, "Undefined" },
984 { 3136, true, "Pulse Oximeter" },
985 { 3137, false, "Pulse Oximeter: Fingertip" },
986 { 3138, false, "Pulse Oximeter: Wrist Worn" },
987 { 3200, true, "Weight Scale" },
988 { 3264, true, "Undefined" },
990 { 5184, true, "Outdoor Sports Activity" },
991 { 5185, false, "Location Display Device" },
992 { 5186, false, "Location and Navigation Display Device" },
993 { 5187, false, "Location Pod" },
994 { 5188, false, "Location and Navigation Pod" },
995 { 5248, true, "Undefined" },
999 static void print_appearance(uint16_t appearance)
1001 const char *str = NULL;
1004 for (i = 0; appearance_table[i].str; i++) {
1005 if (appearance_table[i].generic) {
1006 if (appearance < appearance_table[i].val)
1011 if (appearance_table[i].val == appearance) {
1012 str = appearance_table[i].str;
1018 str = appearance_table[type].str;
1020 print_field("Appearance: %s (0x%4.4x)", str, appearance);
1023 static void print_num_broadcast_retrans(uint8_t num_retrans)
1025 print_field("Number of broadcast retransmissions: %u", num_retrans);
1028 static void print_hold_mode_activity(uint8_t activity)
1030 print_field("Activity: 0x%2.2x", activity);
1032 if (activity == 0x00) {
1033 print_field(" Maintain current Power State");
1037 if (activity & 0x01)
1038 print_field(" Suspend Page Scan");
1039 if (activity & 0x02)
1040 print_field(" Suspend Inquiry Scan");
1041 if (activity & 0x04)
1042 print_field(" Suspend Periodic Inquiries");
1045 static void print_power_type(uint8_t type)
1051 str = "Current Transmit Power Level";
1054 str = "Maximum Transmit Power Level";
1061 print_field("Type: %s (0x%2.2x)", str, type);
1064 static void print_power_level(int8_t level, const char *type)
1066 print_field("TX power%s%s%s: %d dBm",
1067 type ? " (" : "", type ? type : "", type ? ")" : "", level);
1070 static void print_sync_flow_control(uint8_t enable)
1086 print_field("Flow control: %s (0x%2.2x)", str, enable);
1089 static void print_host_flow_control(uint8_t enable)
1098 str = "ACL Data Packets";
1101 str = "Synchronous Data Packets";
1104 str = "ACL and Synchronous Data Packets";
1111 print_field("Flow control: %s (0x%2.2x)", str, enable);
1114 static void print_voice_setting(uint16_t setting)
1116 uint8_t input_coding = (le16_to_cpu(setting) & 0x0300) >> 8;
1117 uint8_t input_data_format = (le16_to_cpu(setting) & 0xc0) >> 6;
1118 uint8_t air_coding_format = le16_to_cpu(setting) & 0x0003;
1121 print_field("Setting: 0x%4.4x", le16_to_cpu(setting));
1123 switch (input_coding) {
1138 print_field(" Input Coding: %s", str);
1140 switch (input_data_format) {
1142 str = "1's complement";
1145 str = "2's complement";
1148 str = "Sign-Magnitude";
1158 print_field(" Input Data Format: %s", str);
1160 if (input_coding == 0x00) {
1161 print_field(" Input Sample Size: %s",
1162 le16_to_cpu(setting) & 0x20 ? "16-bit" : "8-bit");
1163 print_field(" # of bits padding at MSB: %d",
1164 (le16_to_cpu(setting) & 0x1c) >> 2);
1167 switch (air_coding_format) {
1178 str = "Transparent Data";
1185 print_field(" Air Coding Format: %s", str);
1188 static void print_retransmission_effort(uint8_t effort)
1194 str = "No retransmissions";
1197 str = "Optimize for power consumption";
1200 str = "Optimize for link quality";
1210 print_field("Retransmission effort: %s (0x%2.2x)", str, effort);
1213 static void print_scan_enable(uint8_t scan_enable)
1217 switch (scan_enable) {
1222 str = "Inquiry Scan";
1228 str = "Inquiry Scan + Page Scan";
1235 print_field("Scan enable: %s (0x%2.2x)", str, scan_enable);
1238 static void print_link_policy(uint16_t link_policy)
1240 uint16_t policy = le16_to_cpu(link_policy);
1242 print_field("Link policy: 0x%4.4x", policy);
1244 if (policy == 0x0000) {
1245 print_field(" Disable All Modes");
1249 if (policy & 0x0001)
1250 print_field(" Enable Role Switch");
1251 if (policy & 0x0002)
1252 print_field(" Enable Hold Mode");
1253 if (policy & 0x0004)
1254 print_field(" Enable Sniff Mode");
1255 if (policy & 0x0008)
1256 print_field(" Enable Park State");
1259 static void print_air_mode(uint8_t mode)
1274 str = "Transparent";
1281 print_field("Air mode: %s (0x%2.2x)", str, mode);
1284 static void print_codec(const char *label, uint8_t codec)
1299 str = "Transparent";
1308 str = "Vendor specific";
1315 print_field("%s: %s (0x%2.2x)", label, str, codec);
1318 static void print_inquiry_mode(uint8_t mode)
1324 str = "Standard Inquiry Result";
1327 str = "Inquiry Result with RSSI";
1330 str = "Inquiry Result with RSSI or Extended Inquiry Result";
1337 print_field("Mode: %s (0x%2.2x)", str, mode);
1340 static void print_inquiry_scan_type(uint8_t type)
1346 str = "Standard Scan";
1349 str = "Interlaced Scan";
1356 print_field("Type: %s (0x%2.2x)", str, type);
1359 static void print_pscan_type(uint8_t type)
1365 str = "Standard Scan";
1368 str = "Interlaced Scan";
1375 print_field("Type: %s (0x%2.2x)", str, type);
1378 static void print_afh_mode(uint8_t mode)
1394 print_field("Mode: %s (0x%2.2x)", str, mode);
1397 static void print_erroneous_reporting(uint8_t mode)
1413 print_field("Mode: %s (0x%2.2x)", str, mode);
1416 static void print_loopback_mode(uint8_t mode)
1422 str = "No Loopback";
1425 str = "Local Loopback";
1428 str = "Remote Loopback";
1435 print_field("Mode: %s (0x%2.2x)", str, mode);
1438 static void print_simple_pairing_mode(uint8_t mode)
1454 print_field("Mode: %s (0x%2.2x)", str, mode);
1457 static void print_ssp_debug_mode(uint8_t mode)
1473 print_field("Debug mode: %s (0x%2.2x)", str, mode);
1476 static void print_secure_conn_support(uint8_t support)
1492 print_field("Support: %s (0x%2.2x)", str, support);
1495 static void print_auth_payload_timeout(uint16_t timeout)
1497 print_field("Timeout: %d msec (0x%4.4x)",
1498 le16_to_cpu(timeout) * 10, le16_to_cpu(timeout));
1501 static void print_pscan_rep_mode(uint8_t pscan_rep_mode)
1505 switch (pscan_rep_mode) {
1520 print_field("Page scan repetition mode: %s (0x%2.2x)",
1521 str, pscan_rep_mode);
1524 static void print_pscan_period_mode(uint8_t pscan_period_mode)
1528 switch (pscan_period_mode) {
1543 print_field("Page period mode: %s (0x%2.2x)", str, pscan_period_mode);
1546 static void print_pscan_mode(uint8_t pscan_mode)
1550 switch (pscan_mode) {
1558 str = "Optional II";
1561 str = "Optional III";
1568 print_field("Page scan mode: %s (0x%2.2x)", str, pscan_mode);
1571 static void print_clock_offset(uint16_t clock_offset)
1573 print_field("Clock offset: 0x%4.4x", le16_to_cpu(clock_offset));
1576 static void print_clock(uint32_t clock)
1578 print_field("Clock: 0x%8.8x", le32_to_cpu(clock));
1581 static void print_clock_type(uint8_t type)
1587 str = "Local clock";
1590 str = "Piconet clock";
1597 print_field("Type: %s (0x%2.2x)", str, type);
1600 static void print_clock_accuracy(uint16_t accuracy)
1602 if (le16_to_cpu(accuracy) == 0xffff)
1603 print_field("Accuracy: Unknown (0x%4.4x)",
1604 le16_to_cpu(accuracy));
1606 print_field("Accuracy: %.4f msec (0x%4.4x)",
1607 le16_to_cpu(accuracy) * 0.3125,
1608 le16_to_cpu(accuracy));
1611 static void print_lpo_allowed(uint8_t lpo_allowed)
1613 print_field("LPO allowed: 0x%2.2x", lpo_allowed);
1616 static void print_broadcast_fragment(uint8_t fragment)
1622 str = "Continuation fragment";
1625 str = "Starting fragment";
1628 str = "Ending fragment";
1631 str = "No fragmentation";
1638 print_field("Fragment: %s (0x%2.2x)", str, fragment);
1641 static void print_link_type(uint8_t link_type)
1645 switch (link_type) {
1660 print_field("Link type: %s (0x%2.2x)", str, link_type);
1663 static void print_encr_mode(uint8_t encr_mode)
1667 switch (encr_mode) {
1679 print_field("Encryption: %s (0x%2.2x)", str, encr_mode);
1682 static void print_encr_mode_change(uint8_t encr_mode, uint16_t handle)
1687 conn_type = get_type(le16_to_cpu(handle));
1689 switch (encr_mode) {
1694 switch (conn_type) {
1696 str = "Enabled with E0";
1699 str = "Enabled with AES-CCM";
1707 str = "Enabled with AES-CCM";
1714 print_field("Encryption: %s (0x%2.2x)", str, encr_mode);
1717 static void print_pin_type(uint8_t pin_type)
1733 print_field("PIN type: %s (0x%2.2x)", str, pin_type);
1736 static void print_key_flag(uint8_t key_flag)
1742 str = "Semi-permanent";
1752 print_field("Key flag: %s (0x%2.2x)", str, key_flag);
1755 static void print_key_len(uint8_t key_len)
1768 print_field("Key length: %s (%d)", str, key_len);
1771 static void print_key_type(uint8_t key_type)
1777 str = "Combination key";
1780 str = "Local Unit key";
1783 str = "Remote Unit key";
1786 str = "Debug Combination key";
1789 str = "Unauthenticated Combination key from P-192";
1792 str = "Authenticated Combination key from P-192";
1795 str = "Changed Combination key";
1798 str = "Unauthenticated Combination key from P-256";
1801 str = "Authenticated Combination key from P-256";
1808 print_field("Key type: %s (0x%2.2x)", str, key_type);
1811 static void print_key_size(uint8_t key_size)
1813 print_field("Key size: %d", key_size);
1816 static void print_hex_field(const char *label, const uint8_t *data,
1819 char str[len * 2 + 1];
1824 for (i = 0; i < len; i++)
1825 sprintf(str + (i * 2), "%2.2x", data[i]);
1827 print_field("%s: %s", label, str);
1830 static void print_key(const char *label, const uint8_t *link_key)
1832 print_hex_field(label, link_key, 16);
1835 static void print_link_key(const uint8_t *link_key)
1837 print_key("Link key", link_key);
1840 static void print_pin_code(const uint8_t *pin_code, uint8_t pin_len)
1842 char str[pin_len + 1];
1845 for (i = 0; i < pin_len; i++)
1846 sprintf(str + i, "%c", (const char) pin_code[i]);
1848 print_field("PIN code: %s", str);
1851 static void print_hash_p192(const uint8_t *hash)
1853 print_key("Hash C from P-192", hash);
1856 static void print_hash_p256(const uint8_t *hash)
1858 print_key("Hash C from P-256", hash);
1861 static void print_randomizer_p192(const uint8_t *randomizer)
1863 print_key("Randomizer R with P-192", randomizer);
1866 static void print_randomizer_p256(const uint8_t *randomizer)
1868 print_key("Randomizer R with P-256", randomizer);
1871 static void print_pk256(const char *label, const uint8_t *key)
1873 print_hex_field(label, key, 64);
1876 static void print_dhkey(const uint8_t *dhkey)
1878 print_hex_field("Diffie-Hellman key", dhkey, 32);
1881 static void print_passkey(uint32_t passkey)
1883 print_field("Passkey: %06d", le32_to_cpu(passkey));
1886 static void print_io_capability(uint8_t capability)
1890 switch (capability) {
1892 str = "DisplayOnly";
1895 str = "DisplayYesNo";
1898 str = "KeyboardOnly";
1901 str = "NoInputNoOutput";
1908 print_field("IO capability: %s (0x%2.2x)", str, capability);
1911 static void print_oob_data(uint8_t oob_data)
1917 str = "Authentication data not present";
1920 str = "P-192 authentication data present";
1923 str = "P-256 authentication data present";
1926 str = "P-192 and P-256 authentication data present";
1933 print_field("OOB data: %s (0x%2.2x)", str, oob_data);
1936 static void print_oob_data_response(uint8_t oob_data)
1942 str = "Authentication data not present";
1945 str = "Authentication data present";
1952 print_field("OOB data: %s (0x%2.2x)", str, oob_data);
1955 static void print_authentication(uint8_t authentication)
1959 switch (authentication) {
1961 str = "No Bonding - MITM not required";
1964 str = "No Bonding - MITM required";
1967 str = "Dedicated Bonding - MITM not required";
1970 str = "Dedicated Bonding - MITM required";
1973 str = "General Bonding - MITM not required";
1976 str = "General Bonding - MITM required";
1983 print_field("Authentication: %s (0x%2.2x)", str, authentication);
1986 void packet_print_io_capability(uint8_t capability)
1988 print_io_capability(capability);
1991 void packet_print_io_authentication(uint8_t authentication)
1993 print_authentication(authentication);
1996 static void print_location_domain_aware(uint8_t aware)
2002 str = "Regulatory domain unknown";
2005 str = "Regulatory domain known";
2012 print_field("Domain aware: %s (0x%2.2x)", str, aware);
2015 static void print_location_domain(const uint8_t *domain)
2017 print_field("Domain: %c%c (0x%2.2x%2.2x)",
2018 (char) domain[0], (char) domain[1], domain[0], domain[1]);
2021 static void print_location_domain_options(uint8_t options)
2023 print_field("Domain options: %c (0x%2.2x)", (char) options, options);
2026 static void print_location_options(uint8_t options)
2028 print_field("Options: 0x%2.2x", options);
2031 static void print_flow_control_mode(uint8_t mode)
2037 str = "Packet based";
2040 str = "Data block based";
2047 print_field("Flow control mode: %s (0x%2.2x)", str, mode);
2050 static void print_flow_direction(uint8_t direction)
2054 switch (direction) {
2066 print_field("Flow direction: %s (0x%2.2x)", str, direction);
2069 static void print_service_type(uint8_t service_type)
2073 switch (service_type) {
2078 str = "Best Effort";
2088 print_field("Service type: %s (0x%2.2x)", str, service_type);
2091 static void print_flow_spec(const char *label, const uint8_t *data)
2100 str = "Best effort";
2110 print_field("%s flow spec: 0x%2.2x", label, data[0]);
2111 print_field(" Service type: %s (0x%2.2x)", str, data[1]);
2112 print_field(" Maximum SDU size: 0x%4.4x", get_le16(data + 2));
2113 print_field(" SDU inter-arrival time: 0x%8.8x", get_le32(data + 4));
2114 print_field(" Access latency: 0x%8.8x", get_le32(data + 8));
2115 print_field(" Flush timeout: 0x%8.8x", get_le32(data + 12));
2118 static void print_short_range_mode(uint8_t mode)
2134 print_field("Short range mode: %s (0x%2.2x)", str, mode);
2137 static void print_amp_status(uint8_t amp_status)
2141 switch (amp_status) {
2146 str = "Bluetooth only";
2149 str = "No capacity";
2152 str = "Low capacity";
2155 str = "Medium capacity";
2158 str = "High capacity";
2161 str = "Full capacity";
2168 print_field("AMP status: %s (0x%2.2x)", str, amp_status);
2171 static void print_num_resp(uint8_t num_resp)
2173 print_field("Num responses: %d", num_resp);
2176 static void print_num_reports(uint8_t num_reports)
2178 print_field("Num reports: %d", num_reports);
2181 static void print_adv_event_type(uint8_t type)
2187 str = "Connectable undirected - ADV_IND";
2190 str = "Connectable directed - ADV_DIRECT_IND";
2193 str = "Scannable undirected - ADV_SCAN_IND";
2196 str = "Non connectable undirected - ADV_NONCONN_IND";
2199 str = "Scan response - SCAN_RSP";
2206 print_field("Event type: %s (0x%2.2x)", str, type);
2209 static void print_rssi(int8_t rssi)
2211 if ((uint8_t) rssi == 0x99 || rssi == 127)
2212 print_field("RSSI: invalid (0x%2.2x)", (uint8_t) rssi);
2214 print_field("RSSI: %d dBm (0x%2.2x)", rssi, (uint8_t) rssi);
2217 static void print_slot_625(const char *label, uint16_t value)
2219 print_field("%s: %.3f msec (0x%4.4x)", label,
2220 le16_to_cpu(value) * 0.625, le16_to_cpu(value));
2223 static void print_slot_125(const char *label, uint16_t value)
2225 print_field("%s: %.2f msec (0x%4.4x)", label,
2226 le16_to_cpu(value) * 1.25, le16_to_cpu(value));
2229 static void print_timeout(uint16_t timeout)
2231 print_slot_625("Timeout", timeout);
2234 static void print_interval(uint16_t interval)
2236 print_slot_625("Interval", interval);
2239 static void print_window(uint16_t window)
2241 print_slot_625("Window", window);
2244 static void print_role(uint8_t role)
2260 print_field("Role: %s (0x%2.2x)", str, role);
2263 static void print_mode(uint8_t mode)
2285 print_field("Mode: %s (0x%2.2x)", str, mode);
2288 static void print_name(const uint8_t *name)
2292 memcpy(str, name, 248);
2295 print_field("Name: %s", str);
2298 static void print_channel_map(const uint8_t *map)
2300 unsigned int count = 0, start = 0;
2304 for (i = 0; i < 10; i++)
2305 sprintf(str + (i * 2), "%2.2x", map[i]);
2307 print_field("Channel map: 0x%s", str);
2309 for (i = 0; i < 10; i++) {
2310 for (n = 0; n < 8; n++) {
2311 if (map[i] & (1 << n)) {
2313 start = (i * 8) + n;
2319 print_field(" Channel %u-%u",
2320 start, start + count - 1);
2322 } else if (count > 0) {
2323 print_field(" Channel %u", start);
2330 void packet_print_channel_map_lmp(const uint8_t *map)
2332 print_channel_map(map);
2335 static void print_flush_timeout(uint16_t timeout)
2338 print_timeout(timeout);
2340 print_field("Timeout: No Automatic Flush");
2343 void packet_print_version(const char *label, uint8_t version,
2344 const char *sublabel, uint16_t subversion)
2350 str = "Bluetooth 1.0b";
2353 str = "Bluetooth 1.1";
2356 str = "Bluetooth 1.2";
2359 str = "Bluetooth 2.0";
2362 str = "Bluetooth 2.1";
2365 str = "Bluetooth 3.0";
2368 str = "Bluetooth 4.0";
2371 str = "Bluetooth 4.1";
2374 str = "Bluetooth 4.2";
2381 print_field("%s: %s (0x%2.2x) - %s %d (0x%4.4x)", label, str, version,
2382 sublabel, subversion, subversion);
2385 static void print_hci_version(uint8_t version, uint16_t revision)
2387 packet_print_version("HCI version", version,
2388 "Revision", le16_to_cpu(revision));
2391 static void print_lmp_version(uint8_t version, uint16_t subversion)
2393 packet_print_version("LMP version", version,
2394 "Subversion", le16_to_cpu(subversion));
2397 static void print_pal_version(uint8_t version, uint16_t subversion)
2403 str = "Bluetooth 3.0";
2410 print_field("PAL version: %s (0x%2.2x) - Subversion %d (0x%4.4x)",
2412 le16_to_cpu(subversion),
2413 le16_to_cpu(subversion));
2416 void packet_print_company(const char *label, uint16_t company)
2418 print_field("%s: %s (%d)", label, bt_compidtostr(company), company);
2421 static void print_manufacturer(uint16_t manufacturer)
2423 packet_print_company("Manufacturer", le16_to_cpu(manufacturer));
2426 static const struct {
2429 } broadcom_uart_subversion_table[] = {
2430 { 0x210b, "BCM43142A0" }, /* 001.001.011 */
2431 { 0x410e, "BCM43341B0" }, /* 002.001.014 */
2432 { 0x4406, "BCM4324B3" }, /* 002.004.006 */
2436 static const struct {
2439 } broadcom_usb_subversion_table[] = {
2440 { 0x210b, "BCM43142A0" }, /* 001.001.011 */
2441 { 0x2112, "BCM4314A0" }, /* 001.001.018 */
2442 { 0x2118, "BCM20702A0" }, /* 001.001.024 */
2443 { 0x2126, "BCM4335A0" }, /* 001.001.038 */
2444 { 0x220e, "BCM20702A1" }, /* 001.002.014 */
2445 { 0x230f, "BCM4354A2" }, /* 001.003.015 */
2446 { 0x4106, "BCM4335B0" }, /* 002.001.006 */
2447 { 0x410e, "BCM20702B0" }, /* 002.001.014 */
2448 { 0x6109, "BCM4335C0" }, /* 003.001.009 */
2449 { 0x610c, "BCM4354" }, /* 003.001.012 */
2453 static void print_manufacturer_broadcom(uint16_t subversion, uint16_t revision)
2455 uint16_t ver = le16_to_cpu(subversion);
2456 uint16_t rev = le16_to_cpu(revision);
2457 const char *str = NULL;
2460 switch ((rev & 0xf000) >> 12) {
2463 for (i = 0; broadcom_uart_subversion_table[i].str; i++) {
2464 if (broadcom_uart_subversion_table[i].ver == ver) {
2465 str = broadcom_uart_subversion_table[i].str;
2472 for (i = 0; broadcom_usb_subversion_table[i].str; i++) {
2473 if (broadcom_usb_subversion_table[i].ver == ver) {
2474 str = broadcom_usb_subversion_table[i].str;
2482 print_field(" Firmware: %3.3u.%3.3u.%3.3u (%s)",
2483 (ver & 0xe000) >> 13,
2484 (ver & 0x1f00) >> 8, ver & 0x00ff, str);
2486 print_field(" Firmware: %3.3u.%3.3u.%3.3u",
2487 (ver & 0xe000) >> 13,
2488 (ver & 0x1f00) >> 8, ver & 0x00ff);
2491 print_field(" Build: %4.4u", rev & 0x0fff);
2494 static const char *get_supported_command(int bit);
2496 static void print_commands(const uint8_t *commands)
2498 unsigned int count = 0;
2501 for (i = 0; i < 64; i++) {
2502 for (n = 0; n < 8; n++) {
2503 if (commands[i] & (1 << n))
2508 print_field("Commands: %u entr%s", count, count == 1 ? "y" : "ies");
2510 for (i = 0; i < 64; i++) {
2511 for (n = 0; n < 8; n++) {
2514 if (!(commands[i] & (1 << n)))
2517 cmd = get_supported_command((i * 8) + n);
2519 print_field(" %s (Octet %d - Bit %d)",
2522 print_text(COLOR_UNKNOWN_COMMAND_BIT,
2523 " Octet %d - Bit %d ", i, n);
2528 struct features_data {
2533 static const struct features_data features_page0[] = {
2534 { 0, "3 slot packets" },
2535 { 1, "5 slot packets" },
2536 { 2, "Encryption" },
2537 { 3, "Slot offset" },
2538 { 4, "Timing accuracy" },
2539 { 5, "Role switch" },
2541 { 7, "Sniff mode" },
2542 { 8, "Park state" },
2543 { 9, "Power control requests" },
2544 { 10, "Channel quality driven data rate (CQDDR)"},
2546 { 12, "HV2 packets" },
2547 { 13, "HV3 packets" },
2548 { 14, "u-law log synchronous data" },
2549 { 15, "A-law log synchronous data" },
2550 { 16, "CVSD synchronous data" },
2551 { 17, "Paging parameter negotiation" },
2552 { 18, "Power control" },
2553 { 19, "Transparent synchronous data" },
2554 { 20, "Flow control lag (least significant bit)"},
2555 { 21, "Flow control lag (middle bit)" },
2556 { 22, "Flow control lag (most significant bit)" },
2557 { 23, "Broadcast Encryption" },
2558 { 25, "Enhanced Data Rate ACL 2 Mbps mode" },
2559 { 26, "Enhanced Data Rate ACL 3 Mbps mode" },
2560 { 27, "Enhanced inquiry scan" },
2561 { 28, "Interlaced inquiry scan" },
2562 { 29, "Interlaced page scan" },
2563 { 30, "RSSI with inquiry results" },
2564 { 31, "Extended SCO link (EV3 packets)" },
2565 { 32, "EV4 packets" },
2566 { 33, "EV5 packets" },
2567 { 35, "AFH capable slave" },
2568 { 36, "AFH classification slave" },
2569 { 37, "BR/EDR Not Supported" },
2570 { 38, "LE Supported (Controller)" },
2571 { 39, "3-slot Enhanced Data Rate ACL packets" },
2572 { 40, "5-slot Enhanced Data Rate ACL packets" },
2573 { 41, "Sniff subrating" },
2574 { 42, "Pause encryption" },
2575 { 43, "AFH capable master" },
2576 { 44, "AFH classification master" },
2577 { 45, "Enhanced Data Rate eSCO 2 Mbps mode" },
2578 { 46, "Enhanced Data Rate eSCO 3 Mbps mode" },
2579 { 47, "3-slot Enhanced Data Rate eSCO packets" },
2580 { 48, "Extended Inquiry Response" },
2581 { 49, "Simultaneous LE and BR/EDR (Controller)" },
2582 { 51, "Secure Simple Pairing" },
2583 { 52, "Encapsulated PDU" },
2584 { 53, "Erroneous Data Reporting" },
2585 { 54, "Non-flushable Packet Boundary Flag" },
2586 { 56, "Link Supervision Timeout Changed Event" },
2587 { 57, "Inquiry TX Power Level" },
2588 { 58, "Enhanced Power Control" },
2589 { 63, "Extended features" },
2593 static const struct features_data features_page1[] = {
2594 { 0, "Secure Simple Pairing (Host Support)" },
2595 { 1, "LE Supported (Host)" },
2596 { 2, "Simultaneous LE and BR/EDR (Host)" },
2597 { 3, "Secure Connections (Host Support)" },
2601 static const struct features_data features_page2[] = {
2602 { 0, "Connectionless Slave Broadcast - Master" },
2603 { 1, "Connectionless Slave Broadcast - Slave" },
2604 { 2, "Synchronization Train" },
2605 { 3, "Synchronization Scan" },
2606 { 4, "Inquiry Response Notification Event" },
2607 { 5, "Generalized interlaced scan" },
2608 { 6, "Coarse Clock Adjustment" },
2609 { 8, "Secure Connections (Controller Support)" },
2611 { 11, "Train nudging" },
2615 static const struct features_data features_le[] = {
2616 { 0, "LE Encryption" },
2617 { 1, "Connection Parameter Request Procedure" },
2618 { 2, "Extended Reject Indication" },
2619 { 3, "Slave-initiated Features Exchange" },
2621 { 5, "LE Data Packet Length Extension" },
2622 { 6, "LL Privacy" },
2623 { 7, "Extended Scanner Filter Policies" },
2627 static void print_features(uint8_t page, const uint8_t *features_array,
2630 const struct features_data *features_table = NULL;
2631 uint64_t mask, features = 0;
2635 for (i = 0; i < 8; i++) {
2636 sprintf(str + (i * 5), " 0x%2.2x", features_array[i]);
2637 features |= ((uint64_t) features_array[i]) << (i * 8);
2640 print_field("Features:%s", str);
2646 features_table = features_page0;
2649 features_table = features_page1;
2652 features_table = features_page2;
2659 features_table = features_le;
2665 if (!features_table)
2670 for (i = 0; features_table[i].str; i++) {
2671 if (features & (((uint64_t) 1) << features_table[i].bit)) {
2672 print_field(" %s", features_table[i].str);
2673 mask &= ~(((uint64_t) 1) << features_table[i].bit);
2678 print_text(COLOR_UNKNOWN_FEATURE_BIT, " Unknown features "
2679 "(0x%16.16" PRIx64 ")", mask);
2682 void packet_print_features_lmp(const uint8_t *features, uint8_t page)
2684 print_features(page, features, 0x00);
2687 void packet_print_features_ll(const uint8_t *features)
2689 print_features(0, features, 0x01);
2692 #define LE_STATE_SCAN_ADV 0x0001
2693 #define LE_STATE_CONN_ADV 0x0002
2694 #define LE_STATE_NONCONN_ADV 0x0004
2695 #define LE_STATE_HIGH_DIRECT_ADV 0x0008
2696 #define LE_STATE_LOW_DIRECT_ADV 0x0010
2697 #define LE_STATE_ACTIVE_SCAN 0x0020
2698 #define LE_STATE_PASSIVE_SCAN 0x0040
2699 #define LE_STATE_INITIATING 0x0080
2700 #define LE_STATE_CONN_MASTER 0x0100
2701 #define LE_STATE_CONN_SLAVE 0x0200
2702 #define LE_STATE_MASTER_MASTER 0x0400
2703 #define LE_STATE_SLAVE_SLAVE 0x0800
2704 #define LE_STATE_MASTER_SLAVE 0x1000
2706 static const struct {
2709 } le_states_desc_table[] = {
2710 { 0, "Scannable Advertising State" },
2711 { 1, "Connectable Advertising State" },
2712 { 2, "Non-connectable Advertising State" },
2713 { 3, "High Duty Cycle Directed Advertising State" },
2714 { 4, "Low Duty Cycle Directed Advertising State" },
2715 { 5, "Active Scanning State" },
2716 { 6, "Passive Scanning State" },
2717 { 7, "Initiating State" },
2718 { 8, "Connection State (Master Role)" },
2719 { 9, "Connection State (Slave Role)" },
2720 { 10, "Master Role & Master Role" },
2721 { 11, "Slave Role & Slave Role" },
2722 { 12, "Master Role & Slave Role" },
2726 static const struct {
2729 } le_states_comb_table[] = {
2730 { 0, LE_STATE_NONCONN_ADV },
2731 { 1, LE_STATE_SCAN_ADV },
2732 { 2, LE_STATE_CONN_ADV },
2733 { 3, LE_STATE_HIGH_DIRECT_ADV },
2734 { 4, LE_STATE_PASSIVE_SCAN },
2735 { 5, LE_STATE_ACTIVE_SCAN },
2736 { 6, LE_STATE_INITIATING | LE_STATE_CONN_MASTER },
2737 { 7, LE_STATE_CONN_SLAVE },
2738 { 8, LE_STATE_PASSIVE_SCAN | LE_STATE_NONCONN_ADV },
2739 { 9, LE_STATE_PASSIVE_SCAN | LE_STATE_SCAN_ADV },
2740 { 10, LE_STATE_PASSIVE_SCAN | LE_STATE_CONN_ADV },
2741 { 11, LE_STATE_PASSIVE_SCAN | LE_STATE_HIGH_DIRECT_ADV },
2742 { 12, LE_STATE_ACTIVE_SCAN | LE_STATE_NONCONN_ADV },
2743 { 13, LE_STATE_ACTIVE_SCAN | LE_STATE_SCAN_ADV },
2744 { 14, LE_STATE_ACTIVE_SCAN | LE_STATE_CONN_ADV },
2745 { 15, LE_STATE_ACTIVE_SCAN | LE_STATE_HIGH_DIRECT_ADV },
2746 { 16, LE_STATE_INITIATING | LE_STATE_NONCONN_ADV },
2747 { 17, LE_STATE_INITIATING | LE_STATE_SCAN_ADV },
2748 { 18, LE_STATE_CONN_MASTER | LE_STATE_NONCONN_ADV },
2749 { 19, LE_STATE_CONN_MASTER | LE_STATE_SCAN_ADV },
2750 { 20, LE_STATE_CONN_SLAVE | LE_STATE_NONCONN_ADV },
2751 { 21, LE_STATE_CONN_SLAVE | LE_STATE_SCAN_ADV },
2752 { 22, LE_STATE_INITIATING | LE_STATE_PASSIVE_SCAN },
2753 { 23, LE_STATE_INITIATING | LE_STATE_ACTIVE_SCAN },
2754 { 24, LE_STATE_CONN_MASTER | LE_STATE_PASSIVE_SCAN },
2755 { 25, LE_STATE_CONN_MASTER | LE_STATE_ACTIVE_SCAN },
2756 { 26, LE_STATE_CONN_SLAVE | LE_STATE_PASSIVE_SCAN },
2757 { 27, LE_STATE_CONN_SLAVE | LE_STATE_ACTIVE_SCAN },
2758 { 28, LE_STATE_INITIATING | LE_STATE_CONN_MASTER |
2759 LE_STATE_MASTER_MASTER },
2760 { 29, LE_STATE_LOW_DIRECT_ADV },
2761 { 30, LE_STATE_LOW_DIRECT_ADV | LE_STATE_PASSIVE_SCAN },
2762 { 31, LE_STATE_LOW_DIRECT_ADV | LE_STATE_ACTIVE_SCAN },
2763 { 32, LE_STATE_INITIATING | LE_STATE_CONN_ADV |
2764 LE_STATE_MASTER_SLAVE },
2765 { 33, LE_STATE_INITIATING | LE_STATE_HIGH_DIRECT_ADV |
2766 LE_STATE_MASTER_SLAVE },
2767 { 34, LE_STATE_INITIATING | LE_STATE_LOW_DIRECT_ADV |
2768 LE_STATE_MASTER_SLAVE },
2769 { 35, LE_STATE_CONN_MASTER | LE_STATE_CONN_ADV |
2770 LE_STATE_MASTER_SLAVE },
2771 { 36, LE_STATE_CONN_MASTER | LE_STATE_HIGH_DIRECT_ADV |
2772 LE_STATE_MASTER_SLAVE },
2773 { 37, LE_STATE_CONN_MASTER | LE_STATE_LOW_DIRECT_ADV |
2774 LE_STATE_MASTER_SLAVE },
2775 { 38, LE_STATE_CONN_SLAVE | LE_STATE_CONN_ADV |
2776 LE_STATE_MASTER_SLAVE },
2777 { 39, LE_STATE_CONN_SLAVE | LE_STATE_HIGH_DIRECT_ADV |
2778 LE_STATE_SLAVE_SLAVE },
2779 { 40, LE_STATE_CONN_SLAVE | LE_STATE_LOW_DIRECT_ADV |
2780 LE_STATE_SLAVE_SLAVE },
2781 { 41, LE_STATE_INITIATING | LE_STATE_CONN_SLAVE |
2782 LE_STATE_MASTER_SLAVE },
2786 static void print_le_states(const uint8_t *states_array)
2788 uint64_t mask, states = 0;
2791 for (i = 0; i < 8; i++)
2792 states |= ((uint64_t) states_array[i]) << (i * 8);
2794 print_field("States: 0x%16.16" PRIx64, states);
2798 for (i = 0; le_states_comb_table[i].states; i++) {
2799 uint64_t val = (((uint64_t) 1) << le_states_comb_table[i].bit);
2800 const char *str[3] = { NULL, };
2803 if (!(states & val))
2806 for (n = 0; n < 16; n++) {
2807 if (le_states_comb_table[i].states & (1 << n))
2808 str[num++] = le_states_desc_table[n].str;
2812 print_field(" %s", str[0]);
2813 for (n = 1; n < num; n++)
2814 print_field(" and %s", str[n]);
2821 print_text(COLOR_UNKNOWN_LE_STATES, " Unknown states "
2822 "(0x%16.16" PRIx64 ")", mask);
2825 static void print_le_channel_map(const uint8_t *map)
2827 unsigned int count = 0, start = 0;
2831 for (i = 0; i < 5; i++)
2832 sprintf(str + (i * 2), "%2.2x", map[i]);
2834 print_field("Channel map: 0x%s", str);
2836 for (i = 0; i < 5; i++) {
2837 for (n = 0; n < 8; n++) {
2838 if (map[i] & (1 << n)) {
2840 start = (i * 8) + n;
2846 print_field(" Channel %u-%u",
2847 start, start + count - 1);
2849 } else if (count > 0) {
2850 print_field(" Channel %u", start);
2857 void packet_print_channel_map_ll(const uint8_t *map)
2859 print_le_channel_map(map);
2862 static void print_random_number(uint64_t rand)
2864 print_field("Random number: 0x%16.16" PRIx64, le64_to_cpu(rand));
2867 static void print_encrypted_diversifier(uint16_t ediv)
2869 print_field("Encrypted diversifier: 0x%4.4x", le16_to_cpu(ediv));
2872 static const struct {
2875 } events_table[] = {
2876 { 0, "Inquiry Complete" },
2877 { 1, "Inquiry Result" },
2878 { 2, "Connection Complete" },
2879 { 3, "Connection Request" },
2880 { 4, "Disconnection Complete" },
2881 { 5, "Authentication Complete" },
2882 { 6, "Remote Name Request Complete" },
2883 { 7, "Encryption Change" },
2884 { 8, "Change Connection Link Key Complete" },
2885 { 9, "Master Link Key Complete" },
2886 { 10, "Read Remote Supported Features Complete" },
2887 { 11, "Read Remote Version Information Complete" },
2888 { 12, "QoS Setup Complete" },
2889 { 13, "Command Complete" },
2890 { 14, "Command Status" },
2891 { 15, "Hardware Error" },
2892 { 16, "Flush Occurred" },
2893 { 17, "Role Change" },
2894 { 18, "Number of Completed Packets" },
2895 { 19, "Mode Change" },
2896 { 20, "Return Link Keys" },
2897 { 21, "PIN Code Request" },
2898 { 22, "Link Key Request" },
2899 { 23, "Link Key Notification" },
2900 { 24, "Loopback Command" },
2901 { 25, "Data Buffer Overflow" },
2902 { 26, "Max Slots Change" },
2903 { 27, "Read Clock Offset Complete" },
2904 { 28, "Connection Packet Type Changed" },
2905 { 29, "QoS Violation" },
2906 { 30, "Page Scan Mode Change" },
2907 { 31, "Page Scan Repetition Mode Change" },
2908 { 32, "Flow Specification Complete" },
2909 { 33, "Inquiry Result with RSSI" },
2910 { 34, "Read Remote Extended Features Complete" },
2911 { 43, "Synchronous Connection Complete" },
2912 { 44, "Synchronous Connection Changed" },
2913 { 45, "Sniff Subrating" },
2914 { 46, "Extended Inquiry Result" },
2915 { 47, "Encryption Key Refresh Complete" },
2916 { 48, "IO Capability Request" },
2917 { 49, "IO Capability Request Reply" },
2918 { 50, "User Confirmation Request" },
2919 { 51, "User Passkey Request" },
2920 { 52, "Remote OOB Data Request" },
2921 { 53, "Simple Pairing Complete" },
2922 { 55, "Link Supervision Timeout Changed" },
2923 { 56, "Enhanced Flush Complete" },
2924 { 58, "User Passkey Notification" },
2925 { 59, "Keypress Notification" },
2926 { 60, "Remote Host Supported Features Notification" },
2931 static void print_event_mask(const uint8_t *events_array)
2933 uint64_t mask, events = 0;
2936 for (i = 0; i < 8; i++)
2937 events |= ((uint64_t) events_array[i]) << (i * 8);
2939 print_field("Mask: 0x%16.16" PRIx64, events);
2943 for (i = 0; events_table[i].str; i++) {
2944 if (events & (((uint64_t) 1) << events_table[i].bit)) {
2945 print_field(" %s", events_table[i].str);
2946 mask &= ~(((uint64_t) 1) << events_table[i].bit);
2951 print_text(COLOR_UNKNOWN_EVENT_MASK, " Unknown mask "
2952 "(0x%16.16" PRIx64 ")", mask);
2955 static const struct {
2958 } events_page2_table[] = {
2959 { 0, "Physical Link Complete" },
2960 { 1, "Channel Selected" },
2961 { 2, "Disconnection Physical Link Complete" },
2962 { 3, "Physical Link Loss Early Warning" },
2963 { 4, "Physical Link Recovery" },
2964 { 5, "Logical Link Complete" },
2965 { 6, "Disconnection Logical Link Complete" },
2966 { 7, "Flow Specification Modify Complete" },
2967 { 8, "Number of Completed Data Blocks" },
2968 { 9, "AMP Start Test" },
2969 { 10, "AMP Test End" },
2970 { 11, "AMP Receiver Report" },
2971 { 12, "Short Range Mode Change Complete" },
2972 { 13, "AMP Status Change" },
2973 { 14, "Triggered Clock Capture" },
2974 { 15, "Synchronization Train Complete" },
2975 { 16, "Synchronization Train Received" },
2976 { 17, "Connectionless Slave Broadcast Receive" },
2977 { 18, "Connectionless Slave Broadcast Timeout" },
2978 { 19, "Truncated Page Complete" },
2979 { 20, "Slave Page Response Timeout" },
2980 { 21, "Connectionless Slave Broadcast Channel Map Change" },
2981 { 22, "Inquiry Response Notification" },
2982 { 23, "Authenticated Payload Timeout Expired" },
2986 static void print_event_mask_page2(const uint8_t *events_array)
2988 uint64_t mask, events = 0;
2991 for (i = 0; i < 8; i++)
2992 events |= ((uint64_t) events_array[i]) << (i * 8);
2994 print_field("Mask: 0x%16.16" PRIx64, events);
2998 for (i = 0; events_page2_table[i].str; i++) {
2999 if (events & (((uint64_t) 1) << events_page2_table[i].bit)) {
3000 print_field(" %s", events_page2_table[i].str);
3001 mask &= ~(((uint64_t) 1) << events_page2_table[i].bit);
3006 print_text(COLOR_UNKNOWN_EVENT_MASK, " Unknown mask "
3007 "(0x%16.16" PRIx64 ")", mask);
3010 static const struct {
3013 } events_le_table[] = {
3014 { 0, "LE Connection Complete" },
3015 { 1, "LE Advertising Report" },
3016 { 2, "LE Connection Update Complete" },
3017 { 3, "LE Read Remote Used Features Complete" },
3018 { 4, "LE Long Term Key Request" },
3019 { 5, "LE Remote Connection Parameter Request" },
3020 { 6, "LE Data Length Change" },
3021 { 7, "LE Read Local P-256 Public Key Complete" },
3022 { 8, "LE Generate DHKey Complete" },
3023 { 9, "LE Enhanced Connection Complete" },
3024 { 10, "LE Direct Advertising Report" },
3028 static void print_event_mask_le(const uint8_t *events_array)
3030 uint64_t mask, events = 0;
3033 for (i = 0; i < 8; i++)
3034 events |= ((uint64_t) events_array[i]) << (i * 8);
3036 print_field("Mask: 0x%16.16" PRIx64, events);
3040 for (i = 0; events_le_table[i].str; i++) {
3041 if (events & (((uint64_t) 1) << events_le_table[i].bit)) {
3042 print_field(" %s", events_le_table[i].str);
3043 mask &= ~(((uint64_t) 1) << events_le_table[i].bit);
3048 print_text(COLOR_UNKNOWN_EVENT_MASK, " Unknown mask "
3049 "(0x%16.16" PRIx64 ")", mask);
3052 static void print_fec(uint8_t fec)
3058 str = "Not required";
3068 print_field("FEC: %s (0x%02x)", str, fec);
3071 #define BT_EIR_FLAGS 0x01
3072 #define BT_EIR_UUID16_SOME 0x02
3073 #define BT_EIR_UUID16_ALL 0x03
3074 #define BT_EIR_UUID32_SOME 0x04
3075 #define BT_EIR_UUID32_ALL 0x05
3076 #define BT_EIR_UUID128_SOME 0x06
3077 #define BT_EIR_UUID128_ALL 0x07
3078 #define BT_EIR_NAME_SHORT 0x08
3079 #define BT_EIR_NAME_COMPLETE 0x09
3080 #define BT_EIR_TX_POWER 0x0a
3081 #define BT_EIR_CLASS_OF_DEV 0x0d
3082 #define BT_EIR_SSP_HASH_P192 0x0e
3083 #define BT_EIR_SSP_RANDOMIZER_P192 0x0f
3084 #define BT_EIR_DEVICE_ID 0x10
3085 #define BT_EIR_SMP_TK 0x10
3086 #define BT_EIR_SMP_OOB_FLAGS 0x11
3087 #define BT_EIR_SLAVE_CONN_INTERVAL 0x12
3088 #define BT_EIR_SERVICE_UUID16 0x14
3089 #define BT_EIR_SERVICE_UUID128 0x15
3090 #define BT_EIR_SERVICE_DATA 0x16
3091 #define BT_EIR_PUBLIC_ADDRESS 0x17
3092 #define BT_EIR_RANDOM_ADDRESS 0x18
3093 #define BT_EIR_GAP_APPEARANCE 0x19
3094 #define BT_EIR_ADVERTISING_INTERVAL 0x1a
3095 #define BT_EIR_LE_DEVICE_ADDRESS 0x1b
3096 #define BT_EIR_LE_ROLE 0x1c
3097 #define BT_EIR_SSP_HASH_P256 0x1d
3098 #define BT_EIR_SSP_RANDOMIZER_P256 0x1e
3099 #define BT_EIR_3D_INFO_DATA 0x3d
3100 #define BT_EIR_MANUFACTURER_DATA 0xff
3102 static void print_manufacturer_apple(const void *data, uint8_t data_len)
3104 uint8_t type = *((uint8_t *) data);
3110 char identifier[100];
3112 snprintf(identifier, sizeof(identifier) - 1, "%s",
3113 (const char *) (data + 1));
3115 print_field(" Identifier: %s", identifier);
3119 while (data_len > 0) {
3123 type = *((uint8_t *) data);
3148 print_field(" Type: %s (%u)", str, type);
3150 len = *((uint8_t *) data);
3160 if (type == 0x02 && len == 0x15) {
3161 const uint8_t *uuid;
3162 uint16_t minor, major;
3166 print_field(" UUID: %8.8x-%4.4x-%4.4x-%4.4x-%8.8x%4.4x",
3167 get_le32(&uuid[12]), get_le16(&uuid[10]),
3168 get_le16(&uuid[8]), get_le16(&uuid[6]),
3169 get_le32(&uuid[2]), get_le16(&uuid[0]));
3171 major = get_le16(data + 16);
3172 minor = get_le16(data + 18);
3173 print_field(" Version: %u.%u", major, minor);
3175 tx_power = *(int8_t *) (data + 20);
3176 print_field(" TX power: %d dB", tx_power);
3178 print_hex_field(" Data", data, len);
3184 packet_hexdump(data, data_len);
3187 static void print_manufacturer_data(const void *data, uint8_t data_len)
3189 uint16_t company = get_le16(data);
3191 packet_print_company("Company", company);
3196 print_manufacturer_apple(data + 2, data_len - 2);
3199 print_hex_field(" Data", data + 2, data_len - 2);
3204 static void print_device_id(const void *data, uint8_t data_len)
3206 uint16_t source, vendor, product, version;
3207 char modalias[26], *vendor_str, *product_str;
3213 source = get_le16(data);
3214 vendor = get_le16(data + 2);
3215 product = get_le16(data + 4);
3216 version = get_le16(data + 6);
3220 str = "Bluetooth SIG assigned";
3221 sprintf(modalias, "bluetooth:v%04Xp%04Xd%04X",
3222 vendor, product, version);
3225 str = "USB Implementer's Forum assigned";
3226 sprintf(modalias, "usb:v%04Xp%04Xd%04X",
3227 vendor, product, version);
3235 print_field("Device ID: %s (0x%4.4x)", str, source);
3237 if (!hwdb_get_vendor_model(modalias, &vendor_str, &product_str)) {
3242 if (source != 0x0001) {
3244 print_field(" Vendor: %s (0x%4.4x)",
3245 vendor_str, vendor);
3247 print_field(" Vendor: 0x%4.4x", vendor);
3249 packet_print_company(" Vendor", vendor);
3252 print_field(" Product: %s (0x%4.4x)", product_str, product);
3254 print_field(" Product: 0x%4.4x", product);
3256 print_field(" Version: %u.%u.%u (0x%4.4x)",
3257 (version & 0xff00) >> 8,
3258 (version & 0x00f0) >> 4,
3259 (version & 0x000f), version);
3265 static void print_uuid16_list(const char *label, const void *data,
3268 uint8_t count = data_len / sizeof(uint16_t);
3271 print_field("%s: %u entr%s", label, count, count == 1 ? "y" : "ies");
3273 for (i = 0; i < count; i++) {
3274 uint16_t uuid = get_le16(data + (i * 2));
3275 print_field(" %s (0x%4.4x)", uuid16_to_str(uuid), uuid);
3279 static void print_uuid32_list(const char *label, const void *data,
3282 uint8_t count = data_len / sizeof(uint32_t);
3285 print_field("%s: %u entr%s", label, count, count == 1 ? "y" : "ies");
3287 for (i = 0; i < count; i++) {
3288 uint32_t uuid = get_le32(data + (i * 4));
3289 print_field(" %s (0x%8.8x)", uuid32_to_str(uuid), uuid);
3293 static void print_uuid128_list(const char *label, const void *data,
3296 uint8_t count = data_len / 16;
3299 print_field("%s: %u entr%s", label, count, count == 1 ? "y" : "ies");
3301 for (i = 0; i < count; i++) {
3302 const uint8_t *uuid = data + (i * 16);
3304 print_field(" %8.8x-%4.4x-%4.4x-%4.4x-%8.8x%4.4x",
3305 get_le32(&uuid[12]), get_le16(&uuid[10]),
3306 get_le16(&uuid[8]), get_le16(&uuid[6]),
3307 get_le32(&uuid[2]), get_le16(&uuid[0]));
3311 static const struct {
3314 } eir_flags_table[] = {
3315 { 0, "LE Limited Discoverable Mode" },
3316 { 1, "LE General Discoverable Mode" },
3317 { 2, "BR/EDR Not Supported" },
3318 { 3, "Simultaneous LE and BR/EDR (Controller)" },
3319 { 4, "Simultaneous LE and BR/EDR (Host)" },
3323 static const struct {
3326 } eir_3d_table[] = {
3327 { 0, "Association Notification" },
3328 { 1, "Battery Level Reporting" },
3329 { 2, "Send Battery Level Report on Start-up Synchronization" },
3330 { 7, "Factory Test Mode" },
3334 static void print_eir(const uint8_t *eir, uint8_t eir_len, bool le)
3341 while (len < eir_len - 1) {
3342 uint8_t field_len = eir[0];
3343 const uint8_t *data = &eir[2];
3345 char name[239], label[100];
3346 uint8_t flags, mask;
3349 /* Check for the end of EIR */
3353 len += field_len + 1;
3355 /* Do not continue EIR Data parsing if got incorrect length */
3356 if (len > eir_len) {
3357 len -= field_len + 1;
3361 data_len = field_len - 1;
3368 print_field("Flags: 0x%2.2x", flags);
3370 for (i = 0; eir_flags_table[i].str; i++) {
3371 if (flags & (1 << eir_flags_table[i].bit)) {
3373 eir_flags_table[i].str);
3374 mask &= ~(1 << eir_flags_table[i].bit);
3379 print_text(COLOR_UNKNOWN_SERVICE_CLASS,
3380 " Unknown flags (0x%2.2x)", mask);
3383 case BT_EIR_UUID16_SOME:
3384 if (data_len < sizeof(uint16_t))
3386 print_uuid16_list("16-bit Service UUIDs (partial)",
3390 case BT_EIR_UUID16_ALL:
3391 if (data_len < sizeof(uint16_t))
3393 print_uuid16_list("16-bit Service UUIDs (complete)",
3397 case BT_EIR_UUID32_SOME:
3398 if (data_len < sizeof(uint32_t))
3400 print_uuid32_list("32-bit Service UUIDs (partial)",
3404 case BT_EIR_UUID32_ALL:
3405 if (data_len < sizeof(uint32_t))
3407 print_uuid32_list("32-bit Service UUIDs (complete)",
3411 case BT_EIR_UUID128_SOME:
3414 print_uuid128_list("128-bit Service UUIDs (partial)",
3418 case BT_EIR_UUID128_ALL:
3421 print_uuid128_list("128-bit Service UUIDs (complete)",
3425 case BT_EIR_NAME_SHORT:
3426 memset(name, 0, sizeof(name));
3427 memcpy(name, data, data_len);
3428 print_field("Name (short): %s", name);
3431 case BT_EIR_NAME_COMPLETE:
3432 memset(name, 0, sizeof(name));
3433 memcpy(name, data, data_len);
3434 print_field("Name (complete): %s", name);
3437 case BT_EIR_TX_POWER:
3440 print_field("TX power: %d dBm", (int8_t) *data);
3443 case BT_EIR_CLASS_OF_DEV:
3446 print_dev_class(data);
3449 case BT_EIR_SSP_HASH_P192:
3452 print_hash_p192(data);
3455 case BT_EIR_SSP_RANDOMIZER_P192:
3458 print_randomizer_p192(data);
3461 case BT_EIR_DEVICE_ID:
3462 /* SMP TK has the same value as Device ID */
3464 print_hex_field("SMP TK", data, data_len);
3465 else if (data_len >= 8)
3466 print_device_id(data, data_len);
3469 case BT_EIR_SMP_OOB_FLAGS:
3470 print_field("SMP OOB Flags: 0x%2.2x", *data);
3473 case BT_EIR_SLAVE_CONN_INTERVAL:
3476 print_field("Slave Conn. Interval: 0x%4.4x - 0x%4.4x",
3478 get_le16(&data[2]));
3481 case BT_EIR_SERVICE_UUID16:
3482 if (data_len < sizeof(uint16_t))
3484 print_uuid16_list("16-bit Service UUIDs",
3488 case BT_EIR_SERVICE_UUID128:
3491 print_uuid128_list("128-bit Service UUIDs",
3495 case BT_EIR_SERVICE_DATA:
3498 sprintf(label, "Service Data (UUID 0x%4.4x)",
3499 get_le16(&data[0]));
3500 print_hex_field(label, &data[2], data_len - 2);
3503 case BT_EIR_RANDOM_ADDRESS:
3506 print_addr("Random Address", data, 0x01);
3509 case BT_EIR_PUBLIC_ADDRESS:
3512 print_addr("Public Address", data, 0x00);
3515 case BT_EIR_GAP_APPEARANCE:
3518 print_appearance(get_le16(data));
3521 case BT_EIR_SSP_HASH_P256:
3524 print_hash_p256(data);
3527 case BT_EIR_SSP_RANDOMIZER_P256:
3530 print_randomizer_p256(data);
3533 case BT_EIR_3D_INFO_DATA:
3534 print_hex_field("3D Information Data", data, data_len);
3541 print_field(" Features: 0x%2.2x", flags);
3543 for (i = 0; eir_3d_table[i].str; i++) {
3544 if (flags & (1 << eir_3d_table[i].bit)) {
3546 eir_3d_table[i].str);
3547 mask &= ~(1 << eir_3d_table[i].bit);
3552 print_text(COLOR_UNKNOWN_FEATURE_BIT,
3553 " Unknown features (0x%2.2x)", mask);
3555 print_field(" Path Loss Threshold: %d", data[1]);
3558 case BT_EIR_MANUFACTURER_DATA:
3561 print_manufacturer_data(data, data_len);
3565 sprintf(label, "Unknown EIR field 0x%2.2x", eir[1]);
3566 print_hex_field(label, data, data_len);
3570 eir += field_len + 1;
3573 if (len < eir_len && eir[0] != 0)
3574 packet_hexdump(eir, eir_len - len);
3577 void packet_print_addr(const char *label, const void *data, bool random)
3579 print_addr(label ? : "Address", data, random ? 0x01 : 0x00);
3582 void packet_print_ad(const void *data, uint8_t size)
3584 print_eir(data, size, true);
3587 struct broadcast_message {
3588 uint32_t frame_sync_instant;
3589 uint16_t bluetooth_clock_phase;
3590 uint16_t left_open_offset;
3591 uint16_t left_close_offset;
3592 uint16_t right_open_offset;
3593 uint16_t right_close_offset;
3594 uint16_t frame_sync_period;
3595 uint8_t frame_sync_period_fraction;
3596 } __attribute__ ((packed));
3598 static void print_3d_broadcast(const void *data, uint8_t size)
3600 const struct broadcast_message *msg = data;
3602 uint16_t left_open, left_close, right_open, right_close;
3603 uint16_t phase, period;
3604 uint8_t period_frac;
3607 instant = le32_to_cpu(msg->frame_sync_instant);
3608 mode = !!(instant & 0x40000000);
3609 phase = le16_to_cpu(msg->bluetooth_clock_phase);
3610 left_open = le16_to_cpu(msg->left_open_offset);
3611 left_close = le16_to_cpu(msg->left_close_offset);
3612 right_open = le16_to_cpu(msg->right_open_offset);
3613 right_close = le16_to_cpu(msg->right_close_offset);
3614 period = le16_to_cpu(msg->frame_sync_period);
3615 period_frac = msg->frame_sync_period_fraction;
3617 print_field(" Frame sync instant: 0x%8.8x", instant & 0x7fffffff);
3618 print_field(" Video mode: %s (%d)", mode ? "Dual View" : "3D", mode);
3619 print_field(" Bluetooth clock phase: %d usec (0x%4.4x)",
3621 print_field(" Left lense shutter open offset: %d usec (0x%4.4x)",
3622 left_open, left_open);
3623 print_field(" Left lense shutter close offset: %d usec (0x%4.4x)",
3624 left_close, left_close);
3625 print_field(" Right lense shutter open offset: %d usec (0x%4.4x)",
3626 right_open, right_open);
3627 print_field(" Right lense shutter close offset: %d usec (0x%4.4x)",
3628 right_close, right_close);
3629 print_field(" Frame sync period: %d.%d usec (0x%4.4x 0x%2.2x)",
3630 period, period_frac * 256,
3631 period, period_frac);
3634 void packet_hexdump(const unsigned char *buf, uint16_t len)
3636 static const char hexdigits[] = "0123456789abcdef";
3643 for (i = 0; i < len; i++) {
3644 str[((i % 16) * 3) + 0] = hexdigits[buf[i] >> 4];
3645 str[((i % 16) * 3) + 1] = hexdigits[buf[i] & 0xf];
3646 str[((i % 16) * 3) + 2] = ' ';
3647 str[(i % 16) + 49] = isprint(buf[i]) ? buf[i] : '.';
3649 if ((i + 1) % 16 == 0) {
3653 print_text(COLOR_WHITE, "%s", str);
3660 for (j = (i % 16); j < 16; j++) {
3661 str[(j * 3) + 0] = ' ';
3662 str[(j * 3) + 1] = ' ';
3663 str[(j * 3) + 2] = ' ';
3669 print_text(COLOR_WHITE, "%s", str);
3673 void packet_control(struct timeval *tv, struct ucred *cred,
3674 uint16_t index, uint16_t opcode,
3675 const void *data, uint16_t size)
3677 if (index_filter && index_number != index)
3680 control_message(opcode, data, size);
3683 static int addr2str(const uint8_t *addr, char *str)
3685 return sprintf(str, "%2.2X:%2.2X:%2.2X:%2.2X:%2.2X:%2.2X",
3686 addr[5], addr[4], addr[3], addr[2], addr[1], addr[0]);
3689 #define MAX_INDEX 16
3694 uint16_t manufacturer;
3697 static struct index_data index_list[MAX_INDEX];
3699 void packet_monitor(struct timeval *tv, struct ucred *cred,
3700 uint16_t index, uint16_t opcode,
3701 const void *data, uint16_t size)
3703 const struct btsnoop_opcode_new_index *ni;
3704 const struct btsnoop_opcode_index_info *ii;
3705 const struct btsnoop_opcode_user_logging *ul;
3706 char str[18], extra_str[24];
3707 uint16_t manufacturer;
3710 if (index_filter && index_number != index)
3713 index_current = index;
3715 if (tv && time_offset == ((time_t) -1))
3716 time_offset = tv->tv_sec;
3719 case BTSNOOP_OPCODE_NEW_INDEX:
3722 if (index < MAX_INDEX) {
3723 index_list[index].type = ni->type;
3724 memcpy(index_list[index].bdaddr, ni->bdaddr, 6);
3725 index_list[index].manufacturer = UNKNOWN_MANUFACTURER;
3728 addr2str(ni->bdaddr, str);
3729 packet_new_index(tv, index, str, ni->type, ni->bus, ni->name);
3731 case BTSNOOP_OPCODE_DEL_INDEX:
3732 if (index < MAX_INDEX)
3733 addr2str(index_list[index].bdaddr, str);
3735 sprintf(str, "00:00:00:00:00:00");
3737 packet_del_index(tv, index, str);
3739 case BTSNOOP_OPCODE_COMMAND_PKT:
3740 packet_hci_command(tv, cred, index, data, size);
3742 case BTSNOOP_OPCODE_EVENT_PKT:
3743 packet_hci_event(tv, cred, index, data, size);
3745 case BTSNOOP_OPCODE_ACL_TX_PKT:
3746 packet_hci_acldata(tv, cred, index, false, data, size);
3748 case BTSNOOP_OPCODE_ACL_RX_PKT:
3749 packet_hci_acldata(tv, cred, index, true, data, size);
3751 case BTSNOOP_OPCODE_SCO_TX_PKT:
3752 packet_hci_scodata(tv, cred, index, false, data, size);
3754 case BTSNOOP_OPCODE_SCO_RX_PKT:
3755 packet_hci_scodata(tv, cred, index, true, data, size);
3757 case BTSNOOP_OPCODE_OPEN_INDEX:
3758 if (index < MAX_INDEX)
3759 addr2str(index_list[index].bdaddr, str);
3761 sprintf(str, "00:00:00:00:00:00");
3763 packet_open_index(tv, index, str);
3765 case BTSNOOP_OPCODE_CLOSE_INDEX:
3766 if (index < MAX_INDEX)
3767 addr2str(index_list[index].bdaddr, str);
3769 sprintf(str, "00:00:00:00:00:00");
3771 packet_close_index(tv, index, str);
3773 case BTSNOOP_OPCODE_INDEX_INFO:
3775 manufacturer = le16_to_cpu(ii->manufacturer);
3777 if (index < MAX_INDEX) {
3778 memcpy(index_list[index].bdaddr, ii->bdaddr, 6);
3779 index_list[index].manufacturer = manufacturer;
3782 addr2str(ii->bdaddr, str);
3783 packet_index_info(tv, index, str, manufacturer);
3785 case BTSNOOP_OPCODE_VENDOR_DIAG:
3786 if (index < MAX_INDEX)
3787 manufacturer = index_list[index].manufacturer;
3789 manufacturer = UNKNOWN_MANUFACTURER;
3791 packet_vendor_diag(tv, index, manufacturer, data, size);
3793 case BTSNOOP_OPCODE_SYSTEM_NOTE:
3794 packet_system_note(tv, cred, index, data);
3796 case BTSNOOP_OPCODE_USER_LOGGING:
3798 ident = ul->ident_len ? data + sizeof(*ul) : NULL;
3800 packet_user_logging(tv, cred, index, ul->priority, ident,
3801 data + sizeof(*ul) + ul->ident_len);
3804 sprintf(extra_str, "(code %d len %d)", opcode, size);
3805 print_packet(tv, cred, index, '*', COLOR_ERROR,
3806 "Unknown packet", NULL, extra_str);
3807 packet_hexdump(data, size);
3812 void packet_simulator(struct timeval *tv, uint16_t frequency,
3813 const void *data, uint16_t size)
3817 if (tv && time_offset == ((time_t) -1))
3818 time_offset = tv->tv_sec;
3820 sprintf(str, "%u MHz", frequency);
3822 print_packet(tv, NULL, 0, '*', COLOR_PHY_PACKET,
3823 "Physical packet:", NULL, str);
3825 ll_packet(frequency, data, size, false);
3828 static void null_cmd(const void *data, uint8_t size)
3832 static void status_rsp(const void *data, uint8_t size)
3834 uint8_t status = *((const uint8_t *) data);
3836 print_status(status);
3839 static void status_bdaddr_rsp(const void *data, uint8_t size)
3841 uint8_t status = *((const uint8_t *) data);
3843 print_status(status);
3844 print_bdaddr(data + 1);
3847 static void inquiry_cmd(const void *data, uint8_t size)
3849 const struct bt_hci_cmd_inquiry *cmd = data;
3851 print_iac(cmd->lap);
3852 print_field("Length: %.2fs (0x%2.2x)",
3853 cmd->length * 1.28, cmd->length);
3854 print_num_resp(cmd->num_resp);
3857 static void periodic_inquiry_cmd(const void *data, uint8_t size)
3859 const struct bt_hci_cmd_periodic_inquiry *cmd = data;
3861 print_field("Max period: %.2fs (0x%2.2x)",
3862 cmd->max_period * 1.28, cmd->max_period);
3863 print_field("Min period: %.2fs (0x%2.2x)",
3864 cmd->min_period * 1.28, cmd->min_period);
3865 print_iac(cmd->lap);
3866 print_field("Length: %.2fs (0x%2.2x)",
3867 cmd->length * 1.28, cmd->length);
3868 print_num_resp(cmd->num_resp);
3871 static void create_conn_cmd(const void *data, uint8_t size)
3873 const struct bt_hci_cmd_create_conn *cmd = data;
3876 print_bdaddr(cmd->bdaddr);
3877 print_pkt_type(cmd->pkt_type);
3878 print_pscan_rep_mode(cmd->pscan_rep_mode);
3879 print_pscan_mode(cmd->pscan_mode);
3880 print_clock_offset(cmd->clock_offset);
3882 switch (cmd->role_switch) {
3884 str = "Stay master";
3887 str = "Allow slave";
3894 print_field("Role switch: %s (0x%2.2x)", str, cmd->role_switch);
3897 static void disconnect_cmd(const void *data, uint8_t size)
3899 const struct bt_hci_cmd_disconnect *cmd = data;
3901 print_handle(cmd->handle);
3902 print_reason(cmd->reason);
3905 static void add_sco_conn_cmd(const void *data, uint8_t size)
3907 const struct bt_hci_cmd_add_sco_conn *cmd = data;
3909 print_handle(cmd->handle);
3910 print_pkt_type_sco(cmd->pkt_type);
3913 static void create_conn_cancel_cmd(const void *data, uint8_t size)
3915 const struct bt_hci_cmd_create_conn_cancel *cmd = data;
3917 print_bdaddr(cmd->bdaddr);
3920 static void accept_conn_request_cmd(const void *data, uint8_t size)
3922 const struct bt_hci_cmd_accept_conn_request *cmd = data;
3924 print_bdaddr(cmd->bdaddr);
3925 print_role(cmd->role);
3928 static void reject_conn_request_cmd(const void *data, uint8_t size)
3930 const struct bt_hci_cmd_reject_conn_request *cmd = data;
3932 print_bdaddr(cmd->bdaddr);
3933 print_reason(cmd->reason);
3936 static void link_key_request_reply_cmd(const void *data, uint8_t size)
3938 const struct bt_hci_cmd_link_key_request_reply *cmd = data;
3940 print_bdaddr(cmd->bdaddr);
3941 print_link_key(cmd->link_key);
3944 static void link_key_request_neg_reply_cmd(const void *data, uint8_t size)
3946 const struct bt_hci_cmd_link_key_request_neg_reply *cmd = data;
3948 print_bdaddr(cmd->bdaddr);
3951 static void pin_code_request_reply_cmd(const void *data, uint8_t size)
3953 const struct bt_hci_cmd_pin_code_request_reply *cmd = data;
3955 print_bdaddr(cmd->bdaddr);
3956 print_field("PIN length: %d", cmd->pin_len);
3957 print_pin_code(cmd->pin_code, cmd->pin_len);
3960 static void pin_code_request_neg_reply_cmd(const void *data, uint8_t size)
3962 const struct bt_hci_cmd_pin_code_request_neg_reply *cmd = data;
3964 print_bdaddr(cmd->bdaddr);
3967 static void change_conn_pkt_type_cmd(const void *data, uint8_t size)
3969 const struct bt_hci_cmd_change_conn_pkt_type *cmd = data;
3971 print_handle(cmd->handle);
3972 print_pkt_type(cmd->pkt_type);
3975 static void auth_requested_cmd(const void *data, uint8_t size)
3977 const struct bt_hci_cmd_auth_requested *cmd = data;
3979 print_handle(cmd->handle);
3982 static void set_conn_encrypt_cmd(const void *data, uint8_t size)
3984 const struct bt_hci_cmd_set_conn_encrypt *cmd = data;
3986 print_handle(cmd->handle);
3987 print_encr_mode(cmd->encr_mode);
3990 static void change_conn_link_key_cmd(const void *data, uint8_t size)
3992 const struct bt_hci_cmd_change_conn_link_key *cmd = data;
3994 print_handle(cmd->handle);
3997 static void master_link_key_cmd(const void *data, uint8_t size)
3999 const struct bt_hci_cmd_master_link_key *cmd = data;
4001 print_key_flag(cmd->key_flag);
4004 static void remote_name_request_cmd(const void *data, uint8_t size)
4006 const struct bt_hci_cmd_remote_name_request *cmd = data;
4008 print_bdaddr(cmd->bdaddr);
4009 print_pscan_rep_mode(cmd->pscan_rep_mode);
4010 print_pscan_mode(cmd->pscan_mode);
4011 print_clock_offset(cmd->clock_offset);
4014 static void remote_name_request_cancel_cmd(const void *data, uint8_t size)
4016 const struct bt_hci_cmd_remote_name_request_cancel *cmd = data;
4018 print_bdaddr(cmd->bdaddr);
4021 static void read_remote_features_cmd(const void *data, uint8_t size)
4023 const struct bt_hci_cmd_read_remote_features *cmd = data;
4025 print_handle(cmd->handle);
4028 static void read_remote_ext_features_cmd(const void *data, uint8_t size)
4030 const struct bt_hci_cmd_read_remote_ext_features *cmd = data;
4032 print_handle(cmd->handle);
4033 print_field("Page: %d", cmd->page);
4036 static void read_remote_version_cmd(const void *data, uint8_t size)
4038 const struct bt_hci_cmd_read_remote_version *cmd = data;
4040 print_handle(cmd->handle);
4043 static void read_clock_offset_cmd(const void *data, uint8_t size)
4045 const struct bt_hci_cmd_read_clock_offset *cmd = data;
4047 print_handle(cmd->handle);
4050 static void read_lmp_handle_cmd(const void *data, uint8_t size)
4052 const struct bt_hci_cmd_read_lmp_handle *cmd = data;
4054 print_handle(cmd->handle);
4057 static void read_lmp_handle_rsp(const void *data, uint8_t size)
4059 const struct bt_hci_rsp_read_lmp_handle *rsp = data;
4061 print_status(rsp->status);
4062 print_handle(rsp->handle);
4063 print_field("LMP handle: %d", rsp->lmp_handle);
4064 print_field("Reserved: %d", le32_to_cpu(rsp->reserved));
4067 static void setup_sync_conn_cmd(const void *data, uint8_t size)
4069 const struct bt_hci_cmd_setup_sync_conn *cmd = data;
4071 print_handle(cmd->handle);
4072 print_field("Transmit bandwidth: %d", le32_to_cpu(cmd->tx_bandwidth));
4073 print_field("Receive bandwidth: %d", le32_to_cpu(cmd->rx_bandwidth));
4074 print_field("Max latency: %d", le16_to_cpu(cmd->max_latency));
4075 print_voice_setting(cmd->voice_setting);
4076 print_retransmission_effort(cmd->retrans_effort);
4077 print_pkt_type_sco(cmd->pkt_type);
4080 static void accept_sync_conn_request_cmd(const void *data, uint8_t size)
4082 const struct bt_hci_cmd_accept_sync_conn_request *cmd = data;
4084 print_bdaddr(cmd->bdaddr);
4085 print_field("Transmit bandwidth: %d", le32_to_cpu(cmd->tx_bandwidth));
4086 print_field("Receive bandwidth: %d", le32_to_cpu(cmd->rx_bandwidth));
4087 print_field("Max latency: %d", le16_to_cpu(cmd->max_latency));
4088 print_voice_setting(cmd->voice_setting);
4089 print_retransmission_effort(cmd->retrans_effort);
4090 print_pkt_type_sco(cmd->pkt_type);
4093 static void reject_sync_conn_request_cmd(const void *data, uint8_t size)
4095 const struct bt_hci_cmd_reject_sync_conn_request *cmd = data;
4097 print_bdaddr(cmd->bdaddr);
4098 print_reason(cmd->reason);
4101 static void io_capability_request_reply_cmd(const void *data, uint8_t size)
4103 const struct bt_hci_cmd_io_capability_request_reply *cmd = data;
4105 print_bdaddr(cmd->bdaddr);
4106 print_io_capability(cmd->capability);
4107 print_oob_data(cmd->oob_data);
4108 print_authentication(cmd->authentication);
4111 static void user_confirm_request_reply_cmd(const void *data, uint8_t size)
4113 const struct bt_hci_cmd_user_confirm_request_reply *cmd = data;
4115 print_bdaddr(cmd->bdaddr);
4118 static void user_confirm_request_neg_reply_cmd(const void *data, uint8_t size)
4120 const struct bt_hci_cmd_user_confirm_request_neg_reply *cmd = data;
4122 print_bdaddr(cmd->bdaddr);
4125 static void user_passkey_request_reply_cmd(const void *data, uint8_t size)
4127 const struct bt_hci_cmd_user_passkey_request_reply *cmd = data;
4129 print_bdaddr(cmd->bdaddr);
4130 print_passkey(cmd->passkey);
4133 static void user_passkey_request_neg_reply_cmd(const void *data, uint8_t size)
4135 const struct bt_hci_cmd_user_passkey_request_neg_reply *cmd = data;
4137 print_bdaddr(cmd->bdaddr);
4140 static void remote_oob_data_request_reply_cmd(const void *data, uint8_t size)
4142 const struct bt_hci_cmd_remote_oob_data_request_reply *cmd = data;
4144 print_bdaddr(cmd->bdaddr);
4145 print_hash_p192(cmd->hash);
4146 print_randomizer_p192(cmd->randomizer);
4149 static void remote_oob_data_request_neg_reply_cmd(const void *data, uint8_t size)
4151 const struct bt_hci_cmd_remote_oob_data_request_neg_reply *cmd = data;
4153 print_bdaddr(cmd->bdaddr);
4156 static void io_capability_request_neg_reply_cmd(const void *data, uint8_t size)
4158 const struct bt_hci_cmd_io_capability_request_neg_reply *cmd = data;
4160 print_bdaddr(cmd->bdaddr);
4161 print_reason(cmd->reason);
4164 static void create_phy_link_cmd(const void *data, uint8_t size)
4166 const struct bt_hci_cmd_create_phy_link *cmd = data;
4168 print_phy_handle(cmd->phy_handle);
4169 print_key_len(cmd->key_len);
4170 print_key_type(cmd->key_type);
4172 packet_hexdump(data + 3, size - 3);
4175 static void accept_phy_link_cmd(const void *data, uint8_t size)
4177 const struct bt_hci_cmd_accept_phy_link *cmd = data;
4179 print_phy_handle(cmd->phy_handle);
4180 print_key_len(cmd->key_len);
4181 print_key_type(cmd->key_type);
4183 packet_hexdump(data + 3, size - 3);
4186 static void disconn_phy_link_cmd(const void *data, uint8_t size)
4188 const struct bt_hci_cmd_disconn_phy_link *cmd = data;
4190 print_phy_handle(cmd->phy_handle);
4191 print_reason(cmd->reason);
4194 static void create_logic_link_cmd(const void *data, uint8_t size)
4196 const struct bt_hci_cmd_create_logic_link *cmd = data;
4198 print_phy_handle(cmd->phy_handle);
4199 print_flow_spec("TX", cmd->tx_flow_spec);
4200 print_flow_spec("RX", cmd->rx_flow_spec);
4203 static void accept_logic_link_cmd(const void *data, uint8_t size)
4205 const struct bt_hci_cmd_accept_logic_link *cmd = data;
4207 print_phy_handle(cmd->phy_handle);
4208 print_flow_spec("TX", cmd->tx_flow_spec);
4209 print_flow_spec("RX", cmd->rx_flow_spec);
4212 static void disconn_logic_link_cmd(const void *data, uint8_t size)
4214 const struct bt_hci_cmd_disconn_logic_link *cmd = data;
4216 print_handle(cmd->handle);
4219 static void logic_link_cancel_cmd(const void *data, uint8_t size)
4221 const struct bt_hci_cmd_logic_link_cancel *cmd = data;
4223 print_phy_handle(cmd->phy_handle);
4224 print_field("TX flow spec: 0x%2.2x", cmd->flow_spec);
4227 static void logic_link_cancel_rsp(const void *data, uint8_t size)
4229 const struct bt_hci_rsp_logic_link_cancel *rsp = data;
4231 print_status(rsp->status);
4232 print_phy_handle(rsp->phy_handle);
4233 print_field("TX flow spec: 0x%2.2x", rsp->flow_spec);
4236 static void flow_spec_modify_cmd(const void *data, uint8_t size)
4238 const struct bt_hci_cmd_flow_spec_modify *cmd = data;
4240 print_handle(cmd->handle);
4241 print_flow_spec("TX", cmd->tx_flow_spec);
4242 print_flow_spec("RX", cmd->rx_flow_spec);
4245 static void enhanced_setup_sync_conn_cmd(const void *data, uint8_t size)
4247 const struct bt_hci_cmd_enhanced_setup_sync_conn *cmd = data;
4249 print_handle(cmd->handle);
4250 print_field("Transmit bandwidth: %d", le32_to_cpu(cmd->tx_bandwidth));
4251 print_field("Receive bandwidth: %d", le32_to_cpu(cmd->rx_bandwidth));
4255 print_field("Max latency: %d", le16_to_cpu(cmd->max_latency));
4256 print_pkt_type_sco(cmd->pkt_type);
4257 print_retransmission_effort(cmd->retrans_effort);
4260 static void enhanced_accept_sync_conn_request_cmd(const void *data, uint8_t size)
4262 const struct bt_hci_cmd_enhanced_accept_sync_conn_request *cmd = data;
4264 print_bdaddr(cmd->bdaddr);
4265 print_field("Transmit bandwidth: %d", le32_to_cpu(cmd->tx_bandwidth));
4266 print_field("Receive bandwidth: %d", le32_to_cpu(cmd->rx_bandwidth));
4270 print_field("Max latency: %d", le16_to_cpu(cmd->max_latency));
4271 print_pkt_type_sco(cmd->pkt_type);
4272 print_retransmission_effort(cmd->retrans_effort);
4275 static void truncated_page_cmd(const void *data, uint8_t size)
4277 const struct bt_hci_cmd_truncated_page *cmd = data;
4279 print_bdaddr(cmd->bdaddr);
4280 print_pscan_rep_mode(cmd->pscan_rep_mode);
4281 print_clock_offset(cmd->clock_offset);
4284 static void truncated_page_cancel_cmd(const void *data, uint8_t size)
4286 const struct bt_hci_cmd_truncated_page_cancel *cmd = data;
4288 print_bdaddr(cmd->bdaddr);
4291 static void set_slave_broadcast_cmd(const void *data, uint8_t size)
4293 const struct bt_hci_cmd_set_slave_broadcast *cmd = data;
4295 print_field("Enable: 0x%2.2x", cmd->enable);
4296 print_lt_addr(cmd->lt_addr);
4297 print_lpo_allowed(cmd->lpo_allowed);
4298 print_pkt_type(cmd->pkt_type);
4299 print_slot_625("Min interval", cmd->min_interval);
4300 print_slot_625("Max interval", cmd->max_interval);
4301 print_slot_625("Supervision timeout", cmd->timeout);
4304 static void set_slave_broadcast_rsp(const void *data, uint8_t size)
4306 const struct bt_hci_rsp_set_slave_broadcast *rsp = data;
4308 print_status(rsp->status);
4309 print_lt_addr(rsp->lt_addr);
4310 print_interval(rsp->interval);
4313 static void set_slave_broadcast_receive_cmd(const void *data, uint8_t size)
4315 const struct bt_hci_cmd_set_slave_broadcast_receive *cmd = data;
4317 print_field("Enable: 0x%2.2x", cmd->enable);
4318 print_bdaddr(cmd->bdaddr);
4319 print_lt_addr(cmd->lt_addr);
4320 print_interval(cmd->interval);
4321 print_field("Offset: 0x%8.8x", le32_to_cpu(cmd->offset));
4322 print_field("Next broadcast instant: 0x%4.4x",
4323 le16_to_cpu(cmd->instant));
4324 print_slot_625("Supervision timeout", cmd->timeout);
4325 print_field("Remote timing accuracy: %d ppm", cmd->accuracy);
4326 print_field("Skip: 0x%2.2x", cmd->skip);
4327 print_pkt_type(cmd->pkt_type);
4328 print_channel_map(cmd->map);
4331 static void set_slave_broadcast_receive_rsp(const void *data, uint8_t size)
4333 const struct bt_hci_rsp_set_slave_broadcast_receive *rsp = data;
4335 print_status(rsp->status);
4336 print_bdaddr(rsp->bdaddr);
4337 print_lt_addr(rsp->lt_addr);
4340 static void receive_sync_train_cmd(const void *data, uint8_t size)
4342 const struct bt_hci_cmd_receive_sync_train *cmd = data;
4344 print_bdaddr(cmd->bdaddr);
4345 print_timeout(cmd->timeout);
4346 print_window(cmd->window);
4347 print_interval(cmd->interval);
4350 static void remote_oob_ext_data_request_reply_cmd(const void *data, uint8_t size)
4352 const struct bt_hci_cmd_remote_oob_ext_data_request_reply *cmd = data;
4354 print_bdaddr(cmd->bdaddr);
4355 print_hash_p192(cmd->hash192);
4356 print_randomizer_p192(cmd->randomizer192);
4357 print_hash_p256(cmd->hash256);
4358 print_randomizer_p256(cmd->randomizer256);
4361 static void hold_mode_cmd(const void *data, uint8_t size)
4363 const struct bt_hci_cmd_hold_mode *cmd = data;
4365 print_handle(cmd->handle);
4366 print_slot_625("Hold max interval", cmd->max_interval);
4367 print_slot_625("Hold min interval", cmd->min_interval);
4370 static void sniff_mode_cmd(const void *data, uint8_t size)
4372 const struct bt_hci_cmd_sniff_mode *cmd = data;
4374 print_handle(cmd->handle);
4375 print_slot_625("Sniff max interval", cmd->max_interval);
4376 print_slot_625("Sniff min interval", cmd->min_interval);
4377 print_slot_125("Sniff attempt", cmd->attempt);
4378 print_slot_125("Sniff timeout", cmd->timeout);
4381 static void exit_sniff_mode_cmd(const void *data, uint8_t size)
4383 const struct bt_hci_cmd_exit_sniff_mode *cmd = data;
4385 print_handle(cmd->handle);
4388 static void park_state_cmd(const void *data, uint8_t size)
4390 const struct bt_hci_cmd_park_state *cmd = data;
4392 print_handle(cmd->handle);
4393 print_slot_625("Beacon max interval", cmd->max_interval);
4394 print_slot_625("Beacon min interval", cmd->min_interval);
4397 static void exit_park_state_cmd(const void *data, uint8_t size)
4399 const struct bt_hci_cmd_exit_park_state *cmd = data;
4401 print_handle(cmd->handle);
4404 static void qos_setup_cmd(const void *data, uint8_t size)
4406 const struct bt_hci_cmd_qos_setup *cmd = data;
4408 print_handle(cmd->handle);
4409 print_field("Flags: 0x%2.2x", cmd->flags);
4411 print_service_type(cmd->service_type);
4413 print_field("Token rate: %d", le32_to_cpu(cmd->token_rate));
4414 print_field("Peak bandwidth: %d", le32_to_cpu(cmd->peak_bandwidth));
4415 print_field("Latency: %d", le32_to_cpu(cmd->latency));
4416 print_field("Delay variation: %d", le32_to_cpu(cmd->delay_variation));
4419 static void role_discovery_cmd(const void *data, uint8_t size)
4421 const struct bt_hci_cmd_role_discovery *cmd = data;
4423 print_handle(cmd->handle);
4426 static void role_discovery_rsp(const void *data, uint8_t size)
4428 const struct bt_hci_rsp_role_discovery *rsp = data;
4430 print_status(rsp->status);
4431 print_handle(rsp->handle);
4432 print_role(rsp->role);
4435 static void switch_role_cmd(const void *data, uint8_t size)
4437 const struct bt_hci_cmd_switch_role *cmd = data;
4439 print_bdaddr(cmd->bdaddr);
4440 print_role(cmd->role);
4443 static void read_link_policy_cmd(const void *data, uint8_t size)
4445 const struct bt_hci_cmd_read_link_policy *cmd = data;
4447 print_handle(cmd->handle);
4450 static void read_link_policy_rsp(const void *data, uint8_t size)
4452 const struct bt_hci_rsp_read_link_policy *rsp = data;
4454 print_status(rsp->status);
4455 print_handle(rsp->handle);
4456 print_link_policy(rsp->policy);
4459 static void write_link_policy_cmd(const void *data, uint8_t size)
4461 const struct bt_hci_cmd_write_link_policy *cmd = data;
4463 print_handle(cmd->handle);
4464 print_link_policy(cmd->policy);
4467 static void write_link_policy_rsp(const void *data, uint8_t size)
4469 const struct bt_hci_rsp_write_link_policy *rsp = data;
4471 print_status(rsp->status);
4472 print_handle(rsp->handle);
4475 static void read_default_link_policy_rsp(const void *data, uint8_t size)
4477 const struct bt_hci_rsp_read_default_link_policy *rsp = data;
4479 print_status(rsp->status);
4480 print_link_policy(rsp->policy);
4483 static void write_default_link_policy_cmd(const void *data, uint8_t size)
4485 const struct bt_hci_cmd_write_default_link_policy *cmd = data;
4487 print_link_policy(cmd->policy);
4490 static void flow_spec_cmd(const void *data, uint8_t size)
4492 const struct bt_hci_cmd_flow_spec *cmd = data;
4494 print_handle(cmd->handle);
4495 print_field("Flags: 0x%2.2x", cmd->flags);
4497 print_flow_direction(cmd->direction);
4498 print_service_type(cmd->service_type);
4500 print_field("Token rate: %d", le32_to_cpu(cmd->token_rate));
4501 print_field("Token bucket size: %d",
4502 le32_to_cpu(cmd->token_bucket_size));
4503 print_field("Peak bandwidth: %d", le32_to_cpu(cmd->peak_bandwidth));
4504 print_field("Access latency: %d", le32_to_cpu(cmd->access_latency));
4507 static void sniff_subrating_cmd(const void *data, uint8_t size)
4509 const struct bt_hci_cmd_sniff_subrating *cmd = data;
4511 print_handle(cmd->handle);
4512 print_slot_625("Max latency", cmd->max_latency);
4513 print_slot_625("Min remote timeout", cmd->min_remote_timeout);
4514 print_slot_625("Min local timeout", cmd->min_local_timeout);
4517 static void sniff_subrating_rsp(const void *data, uint8_t size)
4519 const struct bt_hci_rsp_sniff_subrating *rsp = data;
4521 print_status(rsp->status);
4522 print_handle(rsp->handle);
4525 static void set_event_mask_cmd(const void *data, uint8_t size)
4527 const struct bt_hci_cmd_set_event_mask *cmd = data;
4529 print_event_mask(cmd->mask);
4532 static void set_event_filter_cmd(const void *data, uint8_t size)
4534 uint8_t type = *((const uint8_t *) data);
4540 str = "Clear All Filters";
4543 str = "Inquiry Result";
4546 str = "Connection Setup";
4553 print_field("Type: %s (0x%2.2x)", str, type);
4558 print_text(COLOR_ERROR, " invalid parameter size");
4559 packet_hexdump(data + 1, size - 1);
4564 filter = *((const uint8_t *) (data + 1));
4568 str = "Return responses from all devices";
4571 str = "Device with specific Class of Device";
4574 str = "Device with specific BD_ADDR";
4581 print_field("Filter: %s (0x%2.2x)", str, filter);
4582 packet_hexdump(data + 2, size - 2);
4586 filter = *((const uint8_t *) (data + 1));
4590 str = "Allow connections all devices";
4593 str = "Allow connections with specific Class of Device";
4596 str = "Allow connections with specific BD_ADDR";
4603 print_field("Filter: %s (0x%2.2x)", str, filter);
4604 packet_hexdump(data + 2, size - 2);
4608 filter = *((const uint8_t *) (data + 1));
4610 print_field("Filter: Reserved (0x%2.2x)", filter);
4611 packet_hexdump(data + 2, size - 2);
4616 static void flush_cmd(const void *data, uint8_t size)
4618 const struct bt_hci_cmd_flush *cmd = data;
4620 print_handle(cmd->handle);
4623 static void flush_rsp(const void *data, uint8_t size)
4625 const struct bt_hci_rsp_flush *rsp = data;
4627 print_status(rsp->status);
4628 print_handle(rsp->handle);
4631 static void read_pin_type_rsp(const void *data, uint8_t size)
4633 const struct bt_hci_rsp_read_pin_type *rsp = data;
4635 print_status(rsp->status);
4636 print_pin_type(rsp->pin_type);
4639 static void write_pin_type_cmd(const void *data, uint8_t size)
4641 const struct bt_hci_cmd_write_pin_type *cmd = data;
4643 print_pin_type(cmd->pin_type);
4646 static void read_stored_link_key_cmd(const void *data, uint8_t size)
4648 const struct bt_hci_cmd_read_stored_link_key *cmd = data;
4650 print_bdaddr(cmd->bdaddr);
4651 print_field("Read all: 0x%2.2x", cmd->read_all);
4654 static void read_stored_link_key_rsp(const void *data, uint8_t size)
4656 const struct bt_hci_rsp_read_stored_link_key *rsp = data;
4658 print_status(rsp->status);
4659 print_field("Max num keys: %d", le16_to_cpu(rsp->max_num_keys));
4660 print_field("Num keys: %d", le16_to_cpu(rsp->num_keys));
4663 static void write_stored_link_key_cmd(const void *data, uint8_t size)
4665 const struct bt_hci_cmd_write_stored_link_key *cmd = data;
4667 print_field("Num keys: %d", cmd->num_keys);
4669 packet_hexdump(data + 1, size - 1);
4672 static void write_stored_link_key_rsp(const void *data, uint8_t size)
4674 const struct bt_hci_rsp_write_stored_link_key *rsp = data;
4676 print_status(rsp->status);
4677 print_field("Num keys: %d", rsp->num_keys);
4680 static void delete_stored_link_key_cmd(const void *data, uint8_t size)
4682 const struct bt_hci_cmd_delete_stored_link_key *cmd = data;
4684 print_bdaddr(cmd->bdaddr);
4685 print_field("Delete all: 0x%2.2x", cmd->delete_all);
4688 static void delete_stored_link_key_rsp(const void *data, uint8_t size)
4690 const struct bt_hci_rsp_delete_stored_link_key *rsp = data;
4692 print_status(rsp->status);
4693 print_field("Num keys: %d", le16_to_cpu(rsp->num_keys));
4696 static void write_local_name_cmd(const void *data, uint8_t size)
4698 const struct bt_hci_cmd_write_local_name *cmd = data;
4700 print_name(cmd->name);
4703 static void read_local_name_rsp(const void *data, uint8_t size)
4705 const struct bt_hci_rsp_read_local_name *rsp = data;
4707 print_status(rsp->status);
4708 print_name(rsp->name);
4711 static void read_conn_accept_timeout_rsp(const void *data, uint8_t size)
4713 const struct bt_hci_rsp_read_conn_accept_timeout *rsp = data;
4715 print_status(rsp->status);
4716 print_timeout(rsp->timeout);
4719 static void write_conn_accept_timeout_cmd(const void *data, uint8_t size)
4721 const struct bt_hci_cmd_write_conn_accept_timeout *cmd = data;
4723 print_timeout(cmd->timeout);
4726 static void read_page_timeout_rsp(const void *data, uint8_t size)
4728 const struct bt_hci_rsp_read_page_timeout *rsp = data;
4730 print_status(rsp->status);
4731 print_timeout(rsp->timeout);
4734 static void write_page_timeout_cmd(const void *data, uint8_t size)
4736 const struct bt_hci_cmd_write_page_timeout *cmd = data;
4738 print_timeout(cmd->timeout);
4741 static void read_scan_enable_rsp(const void *data, uint8_t size)
4743 const struct bt_hci_rsp_read_scan_enable *rsp = data;
4745 print_status(rsp->status);
4746 print_scan_enable(rsp->enable);
4749 static void write_scan_enable_cmd(const void *data, uint8_t size)
4751 const struct bt_hci_cmd_write_scan_enable *cmd = data;
4753 print_scan_enable(cmd->enable);
4756 static void read_page_scan_activity_rsp(const void *data, uint8_t size)
4758 const struct bt_hci_rsp_read_page_scan_activity *rsp = data;
4760 print_status(rsp->status);
4761 print_interval(rsp->interval);
4762 print_window(rsp->window);
4765 static void write_page_scan_activity_cmd(const void *data, uint8_t size)
4767 const struct bt_hci_cmd_write_page_scan_activity *cmd = data;
4769 print_interval(cmd->interval);
4770 print_window(cmd->window);
4773 static void read_inquiry_scan_activity_rsp(const void *data, uint8_t size)
4775 const struct bt_hci_rsp_read_inquiry_scan_activity *rsp = data;
4777 print_status(rsp->status);
4778 print_interval(rsp->interval);
4779 print_window(rsp->window);
4782 static void write_inquiry_scan_activity_cmd(const void *data, uint8_t size)
4784 const struct bt_hci_cmd_write_inquiry_scan_activity *cmd = data;
4786 print_interval(cmd->interval);
4787 print_window(cmd->window);
4790 static void read_auth_enable_rsp(const void *data, uint8_t size)
4792 const struct bt_hci_rsp_read_auth_enable *rsp = data;
4794 print_status(rsp->status);
4795 print_auth_enable(rsp->enable);
4798 static void write_auth_enable_cmd(const void *data, uint8_t size)
4800 const struct bt_hci_cmd_write_auth_enable *cmd = data;
4802 print_auth_enable(cmd->enable);
4805 static void read_encrypt_mode_rsp(const void *data, uint8_t size)
4807 const struct bt_hci_rsp_read_encrypt_mode *rsp = data;
4809 print_status(rsp->status);
4810 print_encrypt_mode(rsp->mode);
4813 static void write_encrypt_mode_cmd(const void *data, uint8_t size)
4815 const struct bt_hci_cmd_write_encrypt_mode *cmd = data;
4817 print_encrypt_mode(cmd->mode);
4820 static void read_class_of_dev_rsp(const void *data, uint8_t size)
4822 const struct bt_hci_rsp_read_class_of_dev *rsp = data;
4824 print_status(rsp->status);
4825 print_dev_class(rsp->dev_class);
4828 static void write_class_of_dev_cmd(const void *data, uint8_t size)
4830 const struct bt_hci_cmd_write_class_of_dev *cmd = data;
4832 print_dev_class(cmd->dev_class);
4835 static void read_voice_setting_rsp(const void *data, uint8_t size)
4837 const struct bt_hci_rsp_read_voice_setting *rsp = data;
4839 print_status(rsp->status);
4840 print_voice_setting(rsp->setting);
4843 static void write_voice_setting_cmd(const void *data, uint8_t size)
4845 const struct bt_hci_cmd_write_voice_setting *cmd = data;
4847 print_voice_setting(cmd->setting);
4850 static void read_auto_flush_timeout_cmd(const void *data, uint8_t size)
4852 const struct bt_hci_cmd_read_auto_flush_timeout *cmd = data;
4854 print_handle(cmd->handle);
4857 static void read_auto_flush_timeout_rsp(const void *data, uint8_t size)
4859 const struct bt_hci_rsp_read_auto_flush_timeout *rsp = data;
4861 print_status(rsp->status);
4862 print_handle(rsp->handle);
4863 print_flush_timeout(rsp->timeout);
4866 static void write_auto_flush_timeout_cmd(const void *data, uint8_t size)
4868 const struct bt_hci_cmd_write_auto_flush_timeout *cmd = data;
4870 print_handle(cmd->handle);
4871 print_flush_timeout(cmd->timeout);
4874 static void write_auto_flush_timeout_rsp(const void *data, uint8_t size)
4876 const struct bt_hci_rsp_write_auto_flush_timeout *rsp = data;
4878 print_status(rsp->status);
4879 print_handle(rsp->handle);
4882 static void read_num_broadcast_retrans_rsp(const void *data, uint8_t size)
4884 const struct bt_hci_rsp_read_num_broadcast_retrans *rsp = data;
4886 print_status(rsp->status);
4887 print_num_broadcast_retrans(rsp->num_retrans);
4890 static void write_num_broadcast_retrans_cmd(const void *data, uint8_t size)
4892 const struct bt_hci_cmd_write_num_broadcast_retrans *cmd = data;
4894 print_num_broadcast_retrans(cmd->num_retrans);
4897 static void read_hold_mode_activity_rsp(const void *data, uint8_t size)
4899 const struct bt_hci_rsp_read_hold_mode_activity *rsp = data;
4901 print_status(rsp->status);
4902 print_hold_mode_activity(rsp->activity);
4905 static void write_hold_mode_activity_cmd(const void *data, uint8_t size)
4907 const struct bt_hci_cmd_write_hold_mode_activity *cmd = data;
4909 print_hold_mode_activity(cmd->activity);
4912 static void read_tx_power_cmd(const void *data, uint8_t size)
4914 const struct bt_hci_cmd_read_tx_power *cmd = data;
4916 print_handle(cmd->handle);
4917 print_power_type(cmd->type);
4920 static void read_tx_power_rsp(const void *data, uint8_t size)
4922 const struct bt_hci_rsp_read_tx_power *rsp = data;
4924 print_status(rsp->status);
4925 print_handle(rsp->handle);
4926 print_power_level(rsp->level, NULL);
4929 static void read_sync_flow_control_rsp(const void *data, uint8_t size)
4931 const struct bt_hci_rsp_read_sync_flow_control *rsp = data;
4933 print_status(rsp->status);
4934 print_sync_flow_control(rsp->enable);
4937 static void write_sync_flow_control_cmd(const void *data, uint8_t size)
4939 const struct bt_hci_cmd_write_sync_flow_control *cmd = data;
4941 print_sync_flow_control(cmd->enable);
4944 static void set_host_flow_control_cmd(const void *data, uint8_t size)
4946 const struct bt_hci_cmd_set_host_flow_control *cmd = data;
4948 print_host_flow_control(cmd->enable);
4951 static void host_buffer_size_cmd(const void *data, uint8_t size)
4953 const struct bt_hci_cmd_host_buffer_size *cmd = data;
4955 print_field("ACL MTU: %-4d ACL max packet: %d",
4956 le16_to_cpu(cmd->acl_mtu),
4957 le16_to_cpu(cmd->acl_max_pkt));
4958 print_field("SCO MTU: %-4d SCO max packet: %d",
4960 le16_to_cpu(cmd->sco_max_pkt));
4963 static void host_num_completed_packets_cmd(const void *data, uint8_t size)
4965 const struct bt_hci_cmd_host_num_completed_packets *cmd = data;
4967 print_field("Num handles: %d", cmd->num_handles);
4968 print_handle(cmd->handle);
4969 print_field("Count: %d", le16_to_cpu(cmd->count));
4971 if (size > sizeof(*cmd))
4972 packet_hexdump(data + sizeof(*cmd), size - sizeof(*cmd));
4975 static void read_link_supv_timeout_cmd(const void *data, uint8_t size)
4977 const struct bt_hci_cmd_read_link_supv_timeout *cmd = data;
4979 print_handle(cmd->handle);
4982 static void read_link_supv_timeout_rsp(const void *data, uint8_t size)
4984 const struct bt_hci_rsp_read_link_supv_timeout *rsp = data;
4986 print_status(rsp->status);
4987 print_handle(rsp->handle);
4988 print_timeout(rsp->timeout);
4991 static void write_link_supv_timeout_cmd(const void *data, uint8_t size)
4993 const struct bt_hci_cmd_write_link_supv_timeout *cmd = data;
4995 print_handle(cmd->handle);
4996 print_timeout(cmd->timeout);
4999 static void write_link_supv_timeout_rsp(const void *data, uint8_t size)
5001 const struct bt_hci_rsp_write_link_supv_timeout *rsp = data;
5003 print_status(rsp->status);
5004 print_handle(rsp->handle);
5007 static void read_num_supported_iac_rsp(const void *data, uint8_t size)
5009 const struct bt_hci_rsp_read_num_supported_iac *rsp = data;
5011 print_status(rsp->status);
5012 print_field("Number of IAC: %d", rsp->num_iac);
5015 static void read_current_iac_lap_rsp(const void *data, uint8_t size)
5017 const struct bt_hci_rsp_read_current_iac_lap *rsp = data;
5020 print_status(rsp->status);
5021 print_field("Number of IAC: %d", rsp->num_iac);
5023 for (i = 0; i < rsp->num_iac; i++)
5024 print_iac(rsp->iac_lap + (i * 3));
5027 static void write_current_iac_lap_cmd(const void *data, uint8_t size)
5029 const struct bt_hci_cmd_write_current_iac_lap *cmd = data;
5032 print_field("Number of IAC: %d", cmd->num_iac);
5034 for (i = 0; i < cmd->num_iac; i++)
5035 print_iac(cmd->iac_lap + (i * 3));
5038 static void read_page_scan_period_mode_rsp(const void *data, uint8_t size)
5040 const struct bt_hci_rsp_read_page_scan_period_mode *rsp = data;
5042 print_status(rsp->status);
5043 print_pscan_period_mode(rsp->mode);
5046 static void write_page_scan_period_mode_cmd(const void *data, uint8_t size)
5048 const struct bt_hci_cmd_write_page_scan_period_mode *cmd = data;
5050 print_pscan_period_mode(cmd->mode);
5053 static void read_page_scan_mode_rsp(const void *data, uint8_t size)
5055 const struct bt_hci_rsp_read_page_scan_mode *rsp = data;
5057 print_status(rsp->status);
5058 print_pscan_mode(rsp->mode);
5061 static void write_page_scan_mode_cmd(const void *data, uint8_t size)
5063 const struct bt_hci_cmd_write_page_scan_mode *cmd = data;
5065 print_pscan_mode(cmd->mode);
5068 static void set_afh_host_classification_cmd(const void *data, uint8_t size)
5070 const struct bt_hci_cmd_set_afh_host_classification *cmd = data;
5072 print_channel_map(cmd->map);
5075 static void read_inquiry_scan_type_rsp(const void *data, uint8_t size)
5077 const struct bt_hci_rsp_read_inquiry_scan_type *rsp = data;
5079 print_status(rsp->status);
5080 print_inquiry_scan_type(rsp->type);
5083 static void write_inquiry_scan_type_cmd(const void *data, uint8_t size)
5085 const struct bt_hci_cmd_write_inquiry_scan_type *cmd = data;
5087 print_inquiry_scan_type(cmd->type);
5090 static void read_inquiry_mode_rsp(const void *data, uint8_t size)
5092 const struct bt_hci_rsp_read_inquiry_mode *rsp = data;
5094 print_status(rsp->status);
5095 print_inquiry_mode(rsp->mode);
5098 static void write_inquiry_mode_cmd(const void *data, uint8_t size)
5100 const struct bt_hci_cmd_write_inquiry_mode *cmd = data;
5102 print_inquiry_mode(cmd->mode);
5105 static void read_page_scan_type_rsp(const void *data, uint8_t size)
5107 const struct bt_hci_rsp_read_page_scan_type *rsp = data;
5109 print_status(rsp->status);
5110 print_pscan_type(rsp->type);
5113 static void write_page_scan_type_cmd(const void *data, uint8_t size)
5115 const struct bt_hci_cmd_write_page_scan_type *cmd = data;
5117 print_pscan_type(cmd->type);
5120 static void read_afh_assessment_mode_rsp(const void *data, uint8_t size)
5122 const struct bt_hci_rsp_read_afh_assessment_mode *rsp = data;
5124 print_status(rsp->status);
5125 print_afh_mode(rsp->mode);
5128 static void write_afh_assessment_mode_cmd(const void *data, uint8_t size)
5130 const struct bt_hci_cmd_write_afh_assessment_mode *cmd = data;
5132 print_afh_mode(cmd->mode);
5135 static void read_ext_inquiry_response_rsp(const void *data, uint8_t size)
5137 const struct bt_hci_rsp_read_ext_inquiry_response *rsp = data;
5139 print_status(rsp->status);
5140 print_fec(rsp->fec);
5141 print_eir(rsp->data, sizeof(rsp->data), false);
5144 static void write_ext_inquiry_response_cmd(const void *data, uint8_t size)
5146 const struct bt_hci_cmd_write_ext_inquiry_response *cmd = data;
5148 print_fec(cmd->fec);
5149 print_eir(cmd->data, sizeof(cmd->data), false);
5152 static void refresh_encrypt_key_cmd(const void *data, uint8_t size)
5154 const struct bt_hci_cmd_refresh_encrypt_key *cmd = data;
5156 print_handle(cmd->handle);
5159 static void read_simple_pairing_mode_rsp(const void *data, uint8_t size)
5161 const struct bt_hci_rsp_read_simple_pairing_mode *rsp = data;
5163 print_status(rsp->status);
5164 print_simple_pairing_mode(rsp->mode);
5167 static void write_simple_pairing_mode_cmd(const void *data, uint8_t size)
5169 const struct bt_hci_cmd_write_simple_pairing_mode *cmd = data;
5171 print_simple_pairing_mode(cmd->mode);
5174 static void read_local_oob_data_rsp(const void *data, uint8_t size)
5176 const struct bt_hci_rsp_read_local_oob_data *rsp = data;
5178 print_status(rsp->status);
5179 print_hash_p192(rsp->hash);
5180 print_randomizer_p192(rsp->randomizer);
5183 static void read_inquiry_resp_tx_power_rsp(const void *data, uint8_t size)
5185 const struct bt_hci_rsp_read_inquiry_resp_tx_power *rsp = data;
5187 print_status(rsp->status);
5188 print_power_level(rsp->level, NULL);
5191 static void write_inquiry_tx_power_cmd(const void *data, uint8_t size)
5193 const struct bt_hci_cmd_write_inquiry_tx_power *cmd = data;
5195 print_power_level(cmd->level, NULL);
5198 static void read_erroneous_reporting_rsp(const void *data, uint8_t size)
5200 const struct bt_hci_rsp_read_erroneous_reporting *rsp = data;
5202 print_status(rsp->status);
5203 print_erroneous_reporting(rsp->mode);
5206 static void write_erroneous_reporting_cmd(const void *data, uint8_t size)
5208 const struct bt_hci_cmd_write_erroneous_reporting *cmd = data;
5210 print_erroneous_reporting(cmd->mode);
5213 static void enhanced_flush_cmd(const void *data, uint8_t size)
5215 const struct bt_hci_cmd_enhanced_flush *cmd = data;
5218 print_handle(cmd->handle);
5220 switch (cmd->type) {
5222 str = "Automatic flushable only";
5229 print_field("Type: %s (0x%2.2x)", str, cmd->type);
5232 static void send_keypress_notify_cmd(const void *data, uint8_t size)
5234 const struct bt_hci_cmd_send_keypress_notify *cmd = data;
5237 print_bdaddr(cmd->bdaddr);
5239 switch (cmd->type) {
5241 str = "Passkey entry started";
5244 str = "Passkey digit entered";
5247 str = "Passkey digit erased";
5250 str = "Passkey cleared";
5253 str = "Passkey entry completed";
5260 print_field("Type: %s (0x%2.2x)", str, cmd->type);
5263 static void send_keypress_notify_rsp(const void *data, uint8_t size)
5265 const struct bt_hci_rsp_send_keypress_notify *rsp = data;
5267 print_status(rsp->status);
5268 print_bdaddr(rsp->bdaddr);
5271 static void set_event_mask_page2_cmd(const void *data, uint8_t size)
5273 const struct bt_hci_cmd_set_event_mask_page2 *cmd = data;
5275 print_event_mask_page2(cmd->mask);
5278 static void read_location_data_rsp(const void *data, uint8_t size)
5280 const struct bt_hci_rsp_read_location_data *rsp = data;
5282 print_status(rsp->status);
5283 print_location_domain_aware(rsp->domain_aware);
5284 print_location_domain(rsp->domain);
5285 print_location_domain_options(rsp->domain_options);
5286 print_location_options(rsp->options);
5289 static void write_location_data_cmd(const void *data, uint8_t size)
5291 const struct bt_hci_cmd_write_location_data *cmd = data;
5293 print_location_domain_aware(cmd->domain_aware);
5294 print_location_domain(cmd->domain);
5295 print_location_domain_options(cmd->domain_options);
5296 print_location_options(cmd->options);
5299 static void read_flow_control_mode_rsp(const void *data, uint8_t size)
5301 const struct bt_hci_rsp_read_flow_control_mode *rsp = data;
5303 print_status(rsp->status);
5304 print_flow_control_mode(rsp->mode);
5307 static void write_flow_control_mode_cmd(const void *data, uint8_t size)
5309 const struct bt_hci_cmd_write_flow_control_mode *cmd = data;
5311 print_flow_control_mode(cmd->mode);
5314 static void read_enhanced_tx_power_cmd(const void *data, uint8_t size)
5316 const struct bt_hci_cmd_read_enhanced_tx_power *cmd = data;
5318 print_handle(cmd->handle);
5319 print_power_type(cmd->type);
5322 static void read_enhanced_tx_power_rsp(const void *data, uint8_t size)
5324 const struct bt_hci_rsp_read_enhanced_tx_power *rsp = data;
5326 print_status(rsp->status);
5327 print_handle(rsp->handle);
5328 print_power_level(rsp->level_gfsk, "GFSK");
5329 print_power_level(rsp->level_dqpsk, "DQPSK");
5330 print_power_level(rsp->level_8dpsk, "8DPSK");
5333 static void short_range_mode_cmd(const void *data, uint8_t size)
5335 const struct bt_hci_cmd_short_range_mode *cmd = data;
5337 print_phy_handle(cmd->phy_handle);
5338 print_short_range_mode(cmd->mode);
5341 static void read_le_host_supported_rsp(const void *data, uint8_t size)
5343 const struct bt_hci_rsp_read_le_host_supported *rsp = data;
5345 print_status(rsp->status);
5346 print_field("Supported: 0x%2.2x", rsp->supported);
5347 print_field("Simultaneous: 0x%2.2x", rsp->simultaneous);
5350 static void write_le_host_supported_cmd(const void *data, uint8_t size)
5352 const struct bt_hci_cmd_write_le_host_supported *cmd = data;
5354 print_field("Supported: 0x%2.2x", cmd->supported);
5355 print_field("Simultaneous: 0x%2.2x", cmd->simultaneous);
5358 static void set_reserved_lt_addr_cmd(const void *data, uint8_t size)
5360 const struct bt_hci_cmd_set_reserved_lt_addr *cmd = data;
5362 print_lt_addr(cmd->lt_addr);
5365 static void set_reserved_lt_addr_rsp(const void *data, uint8_t size)
5367 const struct bt_hci_rsp_set_reserved_lt_addr *rsp = data;
5369 print_status(rsp->status);
5370 print_lt_addr(rsp->lt_addr);
5373 static void delete_reserved_lt_addr_cmd(const void *data, uint8_t size)
5375 const struct bt_hci_cmd_delete_reserved_lt_addr *cmd = data;
5377 print_lt_addr(cmd->lt_addr);
5380 static void delete_reserved_lt_addr_rsp(const void *data, uint8_t size)
5382 const struct bt_hci_rsp_delete_reserved_lt_addr *rsp = data;
5384 print_status(rsp->status);
5385 print_lt_addr(rsp->lt_addr);
5388 static void set_slave_broadcast_data_cmd(const void *data, uint8_t size)
5390 const struct bt_hci_cmd_set_slave_broadcast_data *cmd = data;
5392 print_lt_addr(cmd->lt_addr);
5393 print_broadcast_fragment(cmd->fragment);
5394 print_field("Length: %d", cmd->length);
5396 if (size - 3 != cmd->length)
5397 print_text(COLOR_ERROR, "invalid data size (%d != %d)",
5398 size - 3, cmd->length);
5400 packet_hexdump(data + 3, size - 3);
5403 static void set_slave_broadcast_data_rsp(const void *data, uint8_t size)
5405 const struct bt_hci_rsp_set_slave_broadcast_data *rsp = data;
5407 print_status(rsp->status);
5408 print_lt_addr(rsp->lt_addr);
5411 static void read_sync_train_params_rsp(const void *data, uint8_t size)
5413 const struct bt_hci_rsp_read_sync_train_params *rsp = data;
5415 print_status(rsp->status);
5416 print_interval(rsp->interval);
5417 print_field("Timeout: %.3f msec (0x%8.8x)",
5418 le32_to_cpu(rsp->timeout) * 0.625,
5419 le32_to_cpu(rsp->timeout));
5420 print_field("Service data: 0x%2.2x", rsp->service_data);
5423 static void write_sync_train_params_cmd(const void *data, uint8_t size)
5425 const struct bt_hci_cmd_write_sync_train_params *cmd = data;
5427 print_slot_625("Min interval", cmd->min_interval);
5428 print_slot_625("Max interval", cmd->max_interval);
5429 print_field("Timeout: %.3f msec (0x%8.8x)",
5430 le32_to_cpu(cmd->timeout) * 0.625,
5431 le32_to_cpu(cmd->timeout));
5432 print_field("Service data: 0x%2.2x", cmd->service_data);
5435 static void write_sync_train_params_rsp(const void *data, uint8_t size)
5437 const struct bt_hci_rsp_write_sync_train_params *rsp = data;
5439 print_status(rsp->status);
5440 print_interval(rsp->interval);
5443 static void read_secure_conn_support_rsp(const void *data, uint8_t size)
5445 const struct bt_hci_rsp_read_secure_conn_support *rsp = data;
5447 print_status(rsp->status);
5448 print_secure_conn_support(rsp->support);
5451 static void write_secure_conn_support_cmd(const void *data, uint8_t size)
5453 const struct bt_hci_cmd_write_secure_conn_support *cmd = data;
5455 print_secure_conn_support(cmd->support);
5458 static void read_auth_payload_timeout_cmd(const void *data, uint8_t size)
5460 const struct bt_hci_cmd_read_auth_payload_timeout *cmd = data;
5462 print_handle(cmd->handle);
5465 static void read_auth_payload_timeout_rsp(const void *data, uint8_t size)
5467 const struct bt_hci_rsp_read_auth_payload_timeout *rsp = data;
5469 print_status(rsp->status);
5470 print_handle(rsp->handle);
5471 print_auth_payload_timeout(rsp->timeout);
5474 static void write_auth_payload_timeout_cmd(const void *data, uint8_t size)
5476 const struct bt_hci_cmd_write_auth_payload_timeout *cmd = data;
5478 print_handle(cmd->handle);
5479 print_auth_payload_timeout(cmd->timeout);
5482 static void write_auth_payload_timeout_rsp(const void *data, uint8_t size)
5484 const struct bt_hci_rsp_write_auth_payload_timeout *rsp = data;
5486 print_status(rsp->status);
5487 print_handle(rsp->handle);
5490 static void read_local_oob_ext_data_rsp(const void *data, uint8_t size)
5492 const struct bt_hci_rsp_read_local_oob_ext_data *rsp = data;
5494 print_status(rsp->status);
5495 print_hash_p192(rsp->hash192);
5496 print_randomizer_p192(rsp->randomizer192);
5497 print_hash_p256(rsp->hash256);
5498 print_randomizer_p256(rsp->randomizer256);
5501 static void read_ext_page_timeout_rsp(const void *data, uint8_t size)
5503 const struct bt_hci_rsp_read_ext_page_timeout *rsp = data;
5505 print_status(rsp->status);
5506 print_timeout(rsp->timeout);
5509 static void write_ext_page_timeout_cmd(const void *data, uint8_t size)
5511 const struct bt_hci_cmd_write_ext_page_timeout *cmd = data;
5513 print_timeout(cmd->timeout);
5516 static void read_ext_inquiry_length_rsp(const void *data, uint8_t size)
5518 const struct bt_hci_rsp_read_ext_inquiry_length *rsp = data;
5520 print_status(rsp->status);
5521 print_interval(rsp->interval);
5524 static void write_ext_inquiry_length_cmd(const void *data, uint8_t size)
5526 const struct bt_hci_cmd_write_ext_inquiry_length *cmd = data;
5528 print_interval(cmd->interval);
5531 static void read_local_version_rsp(const void *data, uint8_t size)
5533 const struct bt_hci_rsp_read_local_version *rsp = data;
5534 uint16_t manufacturer;
5536 print_status(rsp->status);
5537 print_hci_version(rsp->hci_ver, rsp->hci_rev);
5539 manufacturer = le16_to_cpu(rsp->manufacturer);
5541 if (index_current < MAX_INDEX) {
5542 switch (index_list[index_current].type) {
5544 print_lmp_version(rsp->lmp_ver, rsp->lmp_subver);
5547 print_pal_version(rsp->lmp_ver, rsp->lmp_subver);
5551 index_list[index_current].manufacturer = manufacturer;
5554 print_manufacturer(rsp->manufacturer);
5556 switch (manufacturer) {
5558 print_manufacturer_broadcom(rsp->lmp_subver, rsp->hci_rev);
5563 static void read_local_commands_rsp(const void *data, uint8_t size)
5565 const struct bt_hci_rsp_read_local_commands *rsp = data;
5567 print_status(rsp->status);
5568 print_commands(rsp->commands);
5571 static void read_local_features_rsp(const void *data, uint8_t size)
5573 const struct bt_hci_rsp_read_local_features *rsp = data;
5575 print_status(rsp->status);
5576 print_features(0, rsp->features, 0x00);
5579 static void read_local_ext_features_cmd(const void *data, uint8_t size)
5581 const struct bt_hci_cmd_read_local_ext_features *cmd = data;
5583 print_field("Page: %d", cmd->page);
5586 static void read_local_ext_features_rsp(const void *data, uint8_t size)
5588 const struct bt_hci_rsp_read_local_ext_features *rsp = data;
5590 print_status(rsp->status);
5591 print_field("Page: %d/%d", rsp->page, rsp->max_page);
5592 print_features(rsp->page, rsp->features, 0x00);
5595 static void read_buffer_size_rsp(const void *data, uint8_t size)
5597 const struct bt_hci_rsp_read_buffer_size *rsp = data;
5599 print_status(rsp->status);
5600 print_field("ACL MTU: %-4d ACL max packet: %d",
5601 le16_to_cpu(rsp->acl_mtu),
5602 le16_to_cpu(rsp->acl_max_pkt));
5603 print_field("SCO MTU: %-4d SCO max packet: %d",
5605 le16_to_cpu(rsp->sco_max_pkt));
5608 static void read_country_code_rsp(const void *data, uint8_t size)
5610 const struct bt_hci_rsp_read_country_code *rsp = data;
5613 print_status(rsp->status);
5615 switch (rsp->code) {
5617 str = "North America, Europe*, Japan";
5627 print_field("Country code: %s (0x%2.2x)", str, rsp->code);
5630 static void read_bd_addr_rsp(const void *data, uint8_t size)
5632 const struct bt_hci_rsp_read_bd_addr *rsp = data;
5634 print_status(rsp->status);
5635 print_bdaddr(rsp->bdaddr);
5637 if (index_current < MAX_INDEX)
5638 memcpy(index_list[index_current].bdaddr, rsp->bdaddr, 6);
5641 static void read_data_block_size_rsp(const void *data, uint8_t size)
5643 const struct bt_hci_rsp_read_data_block_size *rsp = data;
5645 print_status(rsp->status);
5646 print_field("Max ACL length: %d", le16_to_cpu(rsp->max_acl_len));
5647 print_field("Block length: %d", le16_to_cpu(rsp->block_len));
5648 print_field("Num blocks: %d", le16_to_cpu(rsp->num_blocks));
5651 static void read_local_codecs_rsp(const void *data, uint8_t size)
5653 const struct bt_hci_rsp_read_local_codecs *rsp = data;
5654 uint8_t i, num_vnd_codecs;
5656 print_status(rsp->status);
5657 print_field("Number of supported codecs: %d", rsp->num_codecs);
5659 for (i = 0; i < rsp->num_codecs; i++)
5660 print_codec(" Codec", rsp->codec[i]);
5662 num_vnd_codecs = rsp->codec[rsp->num_codecs];
5664 print_field("Number of vendor codecs: %d", num_vnd_codecs);
5666 packet_hexdump(data + rsp->num_codecs + 3,
5667 size - rsp->num_codecs - 3);
5670 static void read_failed_contact_counter_cmd(const void *data, uint8_t size)
5672 const struct bt_hci_cmd_read_failed_contact_counter *cmd = data;
5674 print_handle(cmd->handle);
5677 static void read_failed_contact_counter_rsp(const void *data, uint8_t size)
5679 const struct bt_hci_rsp_read_failed_contact_counter *rsp = data;
5681 print_status(rsp->status);
5682 print_handle(rsp->handle);
5683 print_field("Counter: %u", le16_to_cpu(rsp->counter));
5686 static void reset_failed_contact_counter_cmd(const void *data, uint8_t size)
5688 const struct bt_hci_cmd_reset_failed_contact_counter *cmd = data;
5690 print_handle(cmd->handle);
5693 static void reset_failed_contact_counter_rsp(const void *data, uint8_t size)
5695 const struct bt_hci_rsp_reset_failed_contact_counter *rsp = data;
5697 print_status(rsp->status);
5698 print_handle(rsp->handle);
5701 static void read_link_quality_cmd(const void *data, uint8_t size)
5703 const struct bt_hci_cmd_read_link_quality *cmd = data;
5705 print_handle(cmd->handle);
5708 static void read_link_quality_rsp(const void *data, uint8_t size)
5710 const struct bt_hci_rsp_read_link_quality *rsp = data;
5712 print_status(rsp->status);
5713 print_handle(rsp->handle);
5714 print_field("Link quality: 0x%2.2x", rsp->link_quality);
5717 static void read_rssi_cmd(const void *data, uint8_t size)
5719 const struct bt_hci_cmd_read_rssi *cmd = data;
5721 print_handle(cmd->handle);
5724 static void read_rssi_rsp(const void *data, uint8_t size)
5726 const struct bt_hci_rsp_read_rssi *rsp = data;
5728 print_status(rsp->status);
5729 print_handle(rsp->handle);
5730 print_rssi(rsp->rssi);
5733 static void read_afh_channel_map_cmd(const void *data, uint8_t size)
5735 const struct bt_hci_cmd_read_afh_channel_map *cmd = data;
5737 print_handle(cmd->handle);
5740 static void read_afh_channel_map_rsp(const void *data, uint8_t size)
5742 const struct bt_hci_rsp_read_afh_channel_map *rsp = data;
5744 print_status(rsp->status);
5745 print_handle(rsp->handle);
5746 print_afh_mode(rsp->mode);
5747 print_channel_map(rsp->map);
5750 static void read_clock_cmd(const void *data, uint8_t size)
5752 const struct bt_hci_cmd_read_clock *cmd = data;
5754 print_handle(cmd->handle);
5755 print_clock_type(cmd->type);
5758 static void read_clock_rsp(const void *data, uint8_t size)
5760 const struct bt_hci_rsp_read_clock *rsp = data;
5762 print_status(rsp->status);
5763 print_handle(rsp->handle);
5764 print_clock(rsp->clock);
5765 print_clock_accuracy(rsp->accuracy);
5768 static void read_encrypt_key_size_cmd(const void *data, uint8_t size)
5770 const struct bt_hci_cmd_read_encrypt_key_size *cmd = data;
5772 print_handle(cmd->handle);
5775 static void read_encrypt_key_size_rsp(const void *data, uint8_t size)
5777 const struct bt_hci_rsp_read_encrypt_key_size *rsp = data;
5779 print_status(rsp->status);
5780 print_handle(rsp->handle);
5781 print_key_size(rsp->key_size);
5784 static void read_local_amp_info_rsp(const void *data, uint8_t size)
5786 const struct bt_hci_rsp_read_local_amp_info *rsp = data;
5789 print_status(rsp->status);
5790 print_amp_status(rsp->amp_status);
5792 print_field("Total bandwidth: %d kbps", le32_to_cpu(rsp->total_bw));
5793 print_field("Max guaranteed bandwidth: %d kbps",
5794 le32_to_cpu(rsp->max_bw));
5795 print_field("Min latency: %d", le32_to_cpu(rsp->min_latency));
5796 print_field("Max PDU size: %d", le32_to_cpu(rsp->max_pdu));
5798 switch (rsp->amp_type) {
5800 str = "Primary BR/EDR Controller";
5803 str = "802.11 AMP Controller";
5810 print_field("Controller type: %s (0x%2.2x)", str, rsp->amp_type);
5812 print_field("PAL capabilities: 0x%4.4x", le16_to_cpu(rsp->pal_cap));
5813 print_field("Max ASSOC length: %d", le16_to_cpu(rsp->max_assoc_len));
5814 print_field("Max flush timeout: %d", le32_to_cpu(rsp->max_flush_to));
5815 print_field("Best effort flush timeout: %d",
5816 le32_to_cpu(rsp->be_flush_to));
5819 static void read_local_amp_assoc_cmd(const void *data, uint8_t size)
5821 const struct bt_hci_cmd_read_local_amp_assoc *cmd = data;
5823 print_phy_handle(cmd->phy_handle);
5824 print_field("Length so far: %d", le16_to_cpu(cmd->len_so_far));
5825 print_field("Max ASSOC length: %d", le16_to_cpu(cmd->max_assoc_len));
5828 static void read_local_amp_assoc_rsp(const void *data, uint8_t size)
5830 const struct bt_hci_rsp_read_local_amp_assoc *rsp = data;
5832 print_status(rsp->status);
5833 print_phy_handle(rsp->phy_handle);
5834 print_field("Remaining ASSOC length: %d",
5835 le16_to_cpu(rsp->remain_assoc_len));
5837 packet_hexdump(data + 4, size - 4);
5840 static void write_remote_amp_assoc_cmd(const void *data, uint8_t size)
5842 const struct bt_hci_cmd_write_remote_amp_assoc *cmd = data;
5844 print_phy_handle(cmd->phy_handle);
5845 print_field("Length so far: %d", le16_to_cpu(cmd->len_so_far));
5846 print_field("Remaining ASSOC length: %d",
5847 le16_to_cpu(cmd->remain_assoc_len));
5849 packet_hexdump(data + 5, size - 5);
5852 static void write_remote_amp_assoc_rsp(const void *data, uint8_t size)
5854 const struct bt_hci_rsp_write_remote_amp_assoc *rsp = data;
5856 print_status(rsp->status);
5857 print_phy_handle(rsp->phy_handle);
5860 static void get_mws_transport_config_rsp(const void *data, uint8_t size)
5862 const struct bt_hci_rsp_get_mws_transport_config *rsp = data;
5863 uint8_t sum_baud_rates = 0;
5866 print_status(rsp->status);
5867 print_field("Number of transports: %d", rsp->num_transports);
5869 for (i = 0; i < rsp->num_transports; i++) {
5870 uint8_t transport = rsp->transport[0];
5871 uint8_t num_baud_rates = rsp->transport[1];
5874 switch (transport) {
5889 print_field(" Transport layer: %s (0x%2.2x)", str, transport);
5890 print_field(" Number of baud rates: %d", num_baud_rates);
5892 sum_baud_rates += num_baud_rates;
5895 print_field("Baud rate list: %u entr%s", sum_baud_rates,
5896 sum_baud_rates == 1 ? "y" : "ies");
5898 for (i = 0; i < sum_baud_rates; i++) {
5899 uint32_t to_baud_rate, from_baud_rate;
5901 to_baud_rate = get_le32(data + 2 +
5902 rsp->num_transports * 2 + i * 4);
5903 from_baud_rate = get_le32(data + 2 +
5904 rsp->num_transports * 2 +
5905 sum_baud_rates * 4 + i * 4);
5907 print_field(" Bluetooth to MWS: %d", to_baud_rate);
5908 print_field(" MWS to Bluetooth: %d", from_baud_rate);
5911 packet_hexdump(data + 2 + rsp->num_transports * 2 + sum_baud_rates * 8,
5912 size - 2 - rsp->num_transports * 2 - sum_baud_rates * 8);
5915 static void set_triggered_clock_capture_cmd(const void *data, uint8_t size)
5917 const struct bt_hci_cmd_set_triggered_clock_capture *cmd = data;
5920 print_handle(cmd->handle);
5922 switch (cmd->enable) {
5934 print_field("Capture: %s (0x%2.2x)", str, cmd->enable);
5936 print_clock_type(cmd->type);
5937 print_lpo_allowed(cmd->lpo_allowed);
5938 print_field("Clock captures to filter: %u", cmd->num_filter);
5941 static void read_loopback_mode_rsp(const void *data, uint8_t size)
5943 const struct bt_hci_rsp_read_loopback_mode *rsp = data;
5945 print_status(rsp->status);
5946 print_loopback_mode(rsp->mode);
5949 static void write_loopback_mode_cmd(const void *data, uint8_t size)
5951 const struct bt_hci_cmd_write_loopback_mode *cmd = data;
5953 print_loopback_mode(cmd->mode);
5956 static void write_ssp_debug_mode_cmd(const void *data, uint8_t size)
5958 const struct bt_hci_cmd_write_ssp_debug_mode *cmd = data;
5960 print_ssp_debug_mode(cmd->mode);
5963 static void le_set_event_mask_cmd(const void *data, uint8_t size)
5965 const struct bt_hci_cmd_le_set_event_mask *cmd = data;
5967 print_event_mask_le(cmd->mask);
5970 static void le_read_buffer_size_rsp(const void *data, uint8_t size)
5972 const struct bt_hci_rsp_le_read_buffer_size *rsp = data;
5974 print_status(rsp->status);
5975 print_field("Data packet length: %d", le16_to_cpu(rsp->le_mtu));
5976 print_field("Num data packets: %d", rsp->le_max_pkt);
5979 static void le_read_local_features_rsp(const void *data, uint8_t size)
5981 const struct bt_hci_rsp_le_read_local_features *rsp = data;
5983 print_status(rsp->status);
5984 print_features(0, rsp->features, 0x01);
5987 static void le_set_random_address_cmd(const void *data, uint8_t size)
5989 const struct bt_hci_cmd_le_set_random_address *cmd = data;
5991 print_addr("Address", cmd->addr, 0x01);
5994 static void le_set_adv_parameters_cmd(const void *data, uint8_t size)
5996 const struct bt_hci_cmd_le_set_adv_parameters *cmd = data;
5999 print_slot_625("Min advertising interval", cmd->min_interval);
6000 print_slot_625("Max advertising interval", cmd->max_interval);
6002 switch (cmd->type) {
6004 str = "Connectable undirected - ADV_IND";
6007 str = "Connectable directed - ADV_DIRECT_IND (high duty cycle)";
6010 str = "Scannable undirected - ADV_SCAN_IND";
6013 str = "Non connectable undirected - ADV_NONCONN_IND";
6016 str = "Connectable directed - ADV_DIRECT_IND (low duty cycle)";
6023 print_field("Type: %s (0x%2.2x)", str, cmd->type);
6025 print_own_addr_type(cmd->own_addr_type);
6026 print_addr_type("Direct address type", cmd->direct_addr_type);
6027 print_addr("Direct address", cmd->direct_addr, cmd->direct_addr_type);
6029 switch (cmd->channel_map) {
6056 print_field("Channel map: %s (0x%2.2x)", str, cmd->channel_map);
6058 switch (cmd->filter_policy) {
6060 str = "Allow Scan Request from Any, "
6061 "Allow Connect Request from Any";
6064 str = "Allow Scan Request from White List Only, "
6065 "Allow Connect Request from Any";
6068 str = "Allow Scan Request from Any, "
6069 "Allow Connect Request from White List Only";
6072 str = "Allow Scan Request from White List Only, "
6073 "Allow Connect Request from White List Only";
6080 print_field("Filter policy: %s (0x%2.2x)", str, cmd->filter_policy);
6083 static void le_read_adv_tx_power_rsp(const void *data, uint8_t size)
6085 const struct bt_hci_rsp_le_read_adv_tx_power *rsp = data;
6087 print_status(rsp->status);
6088 print_power_level(rsp->level, NULL);
6091 static void le_set_adv_data_cmd(const void *data, uint8_t size)
6093 const struct bt_hci_cmd_le_set_adv_data *cmd = data;
6095 print_field("Length: %d", cmd->len);
6096 print_eir(cmd->data, cmd->len, true);
6099 static void le_set_scan_rsp_data_cmd(const void *data, uint8_t size)
6101 const struct bt_hci_cmd_le_set_scan_rsp_data *cmd = data;
6103 print_field("Length: %d", cmd->len);
6104 print_eir(cmd->data, cmd->len, true);
6107 static void le_set_adv_enable_cmd(const void *data, uint8_t size)
6109 const struct bt_hci_cmd_le_set_adv_enable *cmd = data;
6112 switch (cmd->enable) {
6124 print_field("Advertising: %s (0x%2.2x)", str, cmd->enable);
6127 static void le_set_scan_parameters_cmd(const void *data, uint8_t size)
6129 const struct bt_hci_cmd_le_set_scan_parameters *cmd = data;
6132 switch (cmd->type) {
6144 print_field("Type: %s (0x%2.2x)", str, cmd->type);
6146 print_interval(cmd->interval);
6147 print_window(cmd->window);
6148 print_own_addr_type(cmd->own_addr_type);
6150 switch (cmd->filter_policy) {
6152 str = "Accept all advertisement";
6155 str = "Ignore not in white list";
6162 print_field("Filter policy: %s (0x%2.2x)", str, cmd->filter_policy);
6165 static void le_set_scan_enable_cmd(const void *data, uint8_t size)
6167 const struct bt_hci_cmd_le_set_scan_enable *cmd = data;
6170 switch (cmd->enable) {
6182 print_field("Scanning: %s (0x%2.2x)", str, cmd->enable);
6184 switch (cmd->filter_dup) {
6196 print_field("Filter duplicates: %s (0x%2.2x)", str, cmd->filter_dup);
6199 static void le_create_conn_cmd(const void *data, uint8_t size)
6201 const struct bt_hci_cmd_le_create_conn *cmd = data;
6204 print_slot_625("Scan interval", cmd->scan_interval);
6205 print_slot_625("Scan window", cmd->scan_window);
6207 switch (cmd->filter_policy) {
6209 str = "White list is not used";
6212 str = "White list is used";
6219 print_field("Filter policy: %s (0x%2.2x)", str, cmd->filter_policy);
6221 print_peer_addr_type("Peer address type", cmd->peer_addr_type);
6222 print_addr("Peer address", cmd->peer_addr, cmd->peer_addr_type);
6223 print_own_addr_type(cmd->own_addr_type);
6225 print_slot_125("Min connection interval", cmd->min_interval);
6226 print_slot_125("Max connection interval", cmd->max_interval);
6227 print_field("Connection latency: 0x%4.4x", le16_to_cpu(cmd->latency));
6228 print_field("Supervision timeout: %d msec (0x%4.4x)",
6229 le16_to_cpu(cmd->supv_timeout) * 10,
6230 le16_to_cpu(cmd->supv_timeout));
6231 print_slot_625("Min connection length", cmd->min_length);
6232 print_slot_625("Max connection length", cmd->max_length);
6235 static void le_read_white_list_size_rsp(const void *data, uint8_t size)
6237 const struct bt_hci_rsp_le_read_white_list_size *rsp = data;
6239 print_status(rsp->status);
6240 print_field("Size: %u", rsp->size);
6243 static void le_add_to_white_list_cmd(const void *data, uint8_t size)
6245 const struct bt_hci_cmd_le_add_to_white_list *cmd = data;
6247 print_addr_type("Address type", cmd->addr_type);
6248 print_addr("Address", cmd->addr, cmd->addr_type);
6251 static void le_remove_from_white_list_cmd(const void *data, uint8_t size)
6253 const struct bt_hci_cmd_le_remove_from_white_list *cmd = data;
6255 print_addr_type("Address type", cmd->addr_type);
6256 print_addr("Address", cmd->addr, cmd->addr_type);
6259 static void le_conn_update_cmd(const void *data, uint8_t size)
6261 const struct bt_hci_cmd_le_conn_update *cmd = data;
6263 print_handle(cmd->handle);
6264 print_slot_125("Min connection interval", cmd->min_interval);
6265 print_slot_125("Max connection interval", cmd->max_interval);
6266 print_field("Connection latency: 0x%4.4x", le16_to_cpu(cmd->latency));
6267 print_field("Supervision timeout: %d msec (0x%4.4x)",
6268 le16_to_cpu(cmd->supv_timeout) * 10,
6269 le16_to_cpu(cmd->supv_timeout));
6270 print_slot_625("Min connection length", cmd->min_length);
6271 print_slot_625("Max connection length", cmd->max_length);
6274 static void le_set_host_classification_cmd(const void *data, uint8_t size)
6276 const struct bt_hci_cmd_le_set_host_classification *cmd = data;
6278 print_le_channel_map(cmd->map);
6281 static void le_read_channel_map_cmd(const void *data, uint8_t size)
6283 const struct bt_hci_cmd_le_read_channel_map *cmd = data;
6285 print_handle(cmd->handle);
6288 static void le_read_channel_map_rsp(const void *data, uint8_t size)
6290 const struct bt_hci_rsp_le_read_channel_map *rsp = data;
6292 print_status(rsp->status);
6293 print_handle(rsp->handle);
6294 print_le_channel_map(rsp->map);
6297 static void le_read_remote_features_cmd(const void *data, uint8_t size)
6299 const struct bt_hci_cmd_le_read_remote_features *cmd = data;
6301 print_handle(cmd->handle);
6304 static void le_encrypt_cmd(const void *data, uint8_t size)
6306 const struct bt_hci_cmd_le_encrypt *cmd = data;
6308 print_key("Key", cmd->key);
6309 print_key("Plaintext data", cmd->plaintext);
6312 static void le_encrypt_rsp(const void *data, uint8_t size)
6314 const struct bt_hci_rsp_le_encrypt *rsp = data;
6316 print_status(rsp->status);
6317 print_key("Encrypted data", rsp->data);
6320 static void le_rand_rsp(const void *data, uint8_t size)
6322 const struct bt_hci_rsp_le_rand *rsp = data;
6324 print_status(rsp->status);
6325 print_random_number(rsp->number);
6328 static void le_start_encrypt_cmd(const void *data, uint8_t size)
6330 const struct bt_hci_cmd_le_start_encrypt *cmd = data;
6332 print_handle(cmd->handle);
6333 print_random_number(cmd->rand);
6334 print_encrypted_diversifier(cmd->ediv);
6335 print_key("Long term key", cmd->ltk);
6338 static void le_ltk_req_reply_cmd(const void *data, uint8_t size)
6340 const struct bt_hci_cmd_le_ltk_req_reply *cmd = data;
6342 print_handle(cmd->handle);
6343 print_key("Long term key", cmd->ltk);
6346 static void le_ltk_req_reply_rsp(const void *data, uint8_t size)
6348 const struct bt_hci_rsp_le_ltk_req_reply *rsp = data;
6350 print_status(rsp->status);
6351 print_handle(rsp->handle);
6354 static void le_ltk_req_neg_reply_cmd(const void *data, uint8_t size)
6356 const struct bt_hci_cmd_le_ltk_req_neg_reply *cmd = data;
6358 print_handle(cmd->handle);
6361 static void le_ltk_req_neg_reply_rsp(const void *data, uint8_t size)
6363 const struct bt_hci_rsp_le_ltk_req_neg_reply *rsp = data;
6365 print_status(rsp->status);
6366 print_handle(rsp->handle);
6369 static void le_read_supported_states_rsp(const void *data, uint8_t size)
6371 const struct bt_hci_rsp_le_read_supported_states *rsp = data;
6373 print_status(rsp->status);
6374 print_le_states(rsp->states);
6377 static void le_receiver_test_cmd(const void *data, uint8_t size)
6379 const struct bt_hci_cmd_le_receiver_test *cmd = data;
6381 print_field("RX frequency: %d MHz (0x%2.2x)",
6382 (cmd->frequency * 2) + 2402, cmd->frequency);
6385 static void le_transmitter_test_cmd(const void *data, uint8_t size)
6387 const struct bt_hci_cmd_le_transmitter_test *cmd = data;
6389 print_field("TX frequency: %d MHz (0x%2.2x)",
6390 (cmd->frequency * 2) + 2402, cmd->frequency);
6391 print_field("Test data length: %d bytes", cmd->data_len);
6392 print_field("Packet payload: 0x%2.2x", cmd->payload);
6395 static void le_test_end_rsp(const void *data, uint8_t size)
6397 const struct bt_hci_rsp_le_test_end *rsp = data;
6399 print_status(rsp->status);
6400 print_field("Number of packets: %d", le16_to_cpu(rsp->num_packets));
6403 static void le_conn_param_req_reply_cmd(const void *data, uint8_t size)
6405 const struct bt_hci_cmd_le_conn_param_req_reply *cmd = data;
6407 print_handle(cmd->handle);
6408 print_slot_125("Min connection interval", cmd->min_interval);
6409 print_slot_125("Max connection interval", cmd->max_interval);
6410 print_field("Connection latency: 0x%4.4x", le16_to_cpu(cmd->latency));
6411 print_field("Supervision timeout: %d msec (0x%4.4x)",
6412 le16_to_cpu(cmd->supv_timeout) * 10,
6413 le16_to_cpu(cmd->supv_timeout));
6414 print_slot_625("Min connection length", cmd->min_length);
6415 print_slot_625("Max connection length", cmd->max_length);
6418 static void le_conn_param_req_reply_rsp(const void *data, uint8_t size)
6420 const struct bt_hci_rsp_le_conn_param_req_reply *rsp = data;
6422 print_status(rsp->status);
6423 print_handle(rsp->handle);
6426 static void le_conn_param_req_neg_reply_cmd(const void *data, uint8_t size)
6428 const struct bt_hci_cmd_le_conn_param_req_neg_reply *cmd = data;
6430 print_handle(cmd->handle);
6431 print_reason(cmd->reason);
6434 static void le_conn_param_req_neg_reply_rsp(const void *data, uint8_t size)
6436 const struct bt_hci_rsp_le_conn_param_req_neg_reply *rsp = data;
6438 print_status(rsp->status);
6439 print_handle(rsp->handle);
6442 static void le_set_data_length_cmd(const void *data, uint8_t size)
6444 const struct bt_hci_cmd_le_set_data_length *cmd = data;
6446 print_handle(cmd->handle);
6447 print_field("TX octets: %d", le16_to_cpu(cmd->tx_len));
6448 print_field("TX time: %d", le16_to_cpu(cmd->tx_time));
6451 static void le_set_data_length_rsp(const void *data, uint8_t size)
6453 const struct bt_hci_rsp_le_set_data_length *rsp = data;
6455 print_status(rsp->status);
6456 print_handle(rsp->handle);
6459 static void le_read_default_data_length_rsp(const void *data, uint8_t size)
6461 const struct bt_hci_rsp_le_read_default_data_length *rsp = data;
6463 print_status(rsp->status);
6464 print_field("TX octets: %d", le16_to_cpu(rsp->tx_len));
6465 print_field("TX time: %d", le16_to_cpu(rsp->tx_time));
6468 static void le_write_default_data_length_cmd(const void *data, uint8_t size)
6470 const struct bt_hci_cmd_le_write_default_data_length *cmd = data;
6472 print_field("TX octets: %d", le16_to_cpu(cmd->tx_len));
6473 print_field("TX time: %d", le16_to_cpu(cmd->tx_time));
6476 static void le_generate_dhkey_cmd(const void *data, uint8_t size)
6478 const struct bt_hci_cmd_le_generate_dhkey *cmd = data;
6480 print_pk256("Remote P-256 public key", cmd->remote_pk256);
6483 static void le_add_to_resolv_list_cmd(const void *data, uint8_t size)
6485 const struct bt_hci_cmd_le_add_to_resolv_list *cmd = data;
6487 print_addr_type("Address type", cmd->addr_type);
6488 print_addr("Address", cmd->addr, cmd->addr_type);
6489 print_key("Peer identity resolving key", cmd->peer_irk);
6490 print_key("Local identity resolving key", cmd->local_irk);
6493 static void le_remove_from_resolv_list_cmd(const void *data, uint8_t size)
6495 const struct bt_hci_cmd_le_remove_from_resolv_list *cmd = data;
6497 print_addr_type("Address type", cmd->addr_type);
6498 print_addr("Address", cmd->addr, cmd->addr_type);
6501 static void le_read_resolv_list_size_rsp(const void *data, uint8_t size)
6503 const struct bt_hci_rsp_le_read_resolv_list_size *rsp = data;
6505 print_status(rsp->status);
6506 print_field("Size: %u", rsp->size);
6509 static void le_read_peer_resolv_addr_cmd(const void *data, uint8_t size)
6511 const struct bt_hci_cmd_le_read_peer_resolv_addr *cmd = data;
6513 print_addr_type("Address type", cmd->addr_type);
6514 print_addr("Address", cmd->addr, cmd->addr_type);
6517 static void le_read_peer_resolv_addr_rsp(const void *data, uint8_t size)
6519 const struct bt_hci_rsp_le_read_peer_resolv_addr *rsp = data;
6521 print_status(rsp->status);
6522 print_addr("Address", rsp->addr, 0x01);
6525 static void le_read_local_resolv_addr_cmd(const void *data, uint8_t size)
6527 const struct bt_hci_cmd_le_read_local_resolv_addr *cmd = data;
6529 print_addr_type("Address type", cmd->addr_type);
6530 print_addr("Address", cmd->addr, cmd->addr_type);
6533 static void le_read_local_resolv_addr_rsp(const void *data, uint8_t size)
6535 const struct bt_hci_rsp_le_read_local_resolv_addr *rsp = data;
6537 print_status(rsp->status);
6538 print_addr("Address", rsp->addr, 0x01);
6541 static void le_set_resolv_enable_cmd(const void *data, uint8_t size)
6543 const struct bt_hci_cmd_le_set_resolv_enable *cmd = data;
6546 switch (cmd->enable) {
6558 print_field("Address resolution: %s (0x%2.2x)", str, cmd->enable);
6561 static void le_set_resolv_timeout_cmd(const void *data, uint8_t size)
6563 const struct bt_hci_cmd_le_set_resolv_timeout *cmd = data;
6565 print_field("Timeout: %u seconds", le16_to_cpu(cmd->timeout));
6568 static void le_read_max_data_length_rsp(const void *data, uint8_t size)
6570 const struct bt_hci_rsp_le_read_max_data_length *rsp = data;
6572 print_status(rsp->status);
6573 print_field("Max TX octets: %d", le16_to_cpu(rsp->max_tx_len));
6574 print_field("Max TX time: %d", le16_to_cpu(rsp->max_tx_time));
6575 print_field("Max RX octets: %d", le16_to_cpu(rsp->max_rx_len));
6576 print_field("Max RX time: %d", le16_to_cpu(rsp->max_rx_time));
6579 struct opcode_data {
6583 void (*cmd_func) (const void *data, uint8_t size);
6586 void (*rsp_func) (const void *data, uint8_t size);
6591 static const struct opcode_data opcode_table[] = {
6592 { 0x0000, -1, "NOP" },
6594 /* OGF 1 - Link Control */
6595 { 0x0401, 0, "Inquiry",
6596 inquiry_cmd, 5, true },
6597 { 0x0402, 1, "Inquiry Cancel",
6599 status_rsp, 1, true },
6600 { 0x0403, 2, "Periodic Inquiry Mode",
6601 periodic_inquiry_cmd, 9, true,
6602 status_rsp, 1, true },
6603 { 0x0404, 3, "Exit Periodic Inquiry Mode",
6605 status_rsp, 1, true },
6606 { 0x0405, 4, "Create Connection",
6607 create_conn_cmd, 13, true },
6608 { 0x0406, 5, "Disconnect",
6609 disconnect_cmd, 3, true },
6610 { 0x0407, 6, "Add SCO Connection",
6611 add_sco_conn_cmd, 4, true },
6612 { 0x0408, 7, "Create Connection Cancel",
6613 create_conn_cancel_cmd, 6, true,
6614 status_bdaddr_rsp, 7, true },
6615 { 0x0409, 8, "Accept Connection Request",
6616 accept_conn_request_cmd, 7, true },
6617 { 0x040a, 9, "Reject Connection Request",
6618 reject_conn_request_cmd, 7, true },
6619 { 0x040b, 10, "Link Key Request Reply",
6620 link_key_request_reply_cmd, 22, true,
6621 status_bdaddr_rsp, 7, true },
6622 { 0x040c, 11, "Link Key Request Negative Reply",
6623 link_key_request_neg_reply_cmd, 6, true,
6624 status_bdaddr_rsp, 7, true },
6625 { 0x040d, 12, "PIN Code Request Reply",
6626 pin_code_request_reply_cmd, 23, true,
6627 status_bdaddr_rsp, 7, true },
6628 { 0x040e, 13, "PIN Code Request Negative Reply",
6629 pin_code_request_neg_reply_cmd, 6, true,
6630 status_bdaddr_rsp, 7, true },
6631 { 0x040f, 14, "Change Connection Packet Type",
6632 change_conn_pkt_type_cmd, 4, true },
6633 { 0x0411, 15, "Authentication Requested",
6634 auth_requested_cmd, 2, true },
6635 { 0x0413, 16, "Set Connection Encryption",
6636 set_conn_encrypt_cmd, 3, true },
6637 { 0x0415, 17, "Change Connection Link Key",
6638 change_conn_link_key_cmd, 2, true },
6639 { 0x0417, 18, "Master Link Key",
6640 master_link_key_cmd, 1, true },
6641 { 0x0419, 19, "Remote Name Request",
6642 remote_name_request_cmd, 10, true },
6643 { 0x041a, 20, "Remote Name Request Cancel",
6644 remote_name_request_cancel_cmd, 6, true,
6645 status_bdaddr_rsp, 7, true },
6646 { 0x041b, 21, "Read Remote Supported Features",
6647 read_remote_features_cmd, 2, true },
6648 { 0x041c, 22, "Read Remote Extended Features",
6649 read_remote_ext_features_cmd, 3, true },
6650 { 0x041d, 23, "Read Remote Version Information",
6651 read_remote_version_cmd, 2, true },
6652 { 0x041f, 24, "Read Clock Offset",
6653 read_clock_offset_cmd, 2, true },
6654 { 0x0420, 25, "Read LMP Handle",
6655 read_lmp_handle_cmd, 2, true,
6656 read_lmp_handle_rsp, 8, true },
6657 { 0x0428, 131, "Setup Synchronous Connection",
6658 setup_sync_conn_cmd, 17, true },
6659 { 0x0429, 132, "Accept Synchronous Connection Request",
6660 accept_sync_conn_request_cmd, 21, true },
6661 { 0x042a, 133, "Reject Synchronous Connection Request",
6662 reject_sync_conn_request_cmd, 7, true },
6663 { 0x042b, 151, "IO Capability Request Reply",
6664 io_capability_request_reply_cmd, 9, true,
6665 status_bdaddr_rsp, 7, true },
6666 { 0x042c, 152, "User Confirmation Request Reply",
6667 user_confirm_request_reply_cmd, 6, true,
6668 status_bdaddr_rsp, 7, true },
6669 { 0x042d, 153, "User Confirmation Request Neg Reply",
6670 user_confirm_request_neg_reply_cmd, 6, true,
6671 status_bdaddr_rsp, 7, true },
6672 { 0x042e, 154, "User Passkey Request Reply",
6673 user_passkey_request_reply_cmd, 10, true,
6674 status_bdaddr_rsp, 7, true },
6675 { 0x042f, 155, "User Passkey Request Negative Reply",
6676 user_passkey_request_neg_reply_cmd, 6, true,
6677 status_bdaddr_rsp, 7, true },
6678 { 0x0430, 156, "Remote OOB Data Request Reply",
6679 remote_oob_data_request_reply_cmd, 38, true,
6680 status_bdaddr_rsp, 7, true },
6681 { 0x0433, 159, "Remote OOB Data Request Neg Reply",
6682 remote_oob_data_request_neg_reply_cmd, 6, true,
6683 status_bdaddr_rsp, 7, true },
6684 { 0x0434, 163, "IO Capability Request Negative Reply",
6685 io_capability_request_neg_reply_cmd, 7, true,
6686 status_bdaddr_rsp, 7, true },
6687 { 0x0435, 168, "Create Physical Link",
6688 create_phy_link_cmd, 3, false },
6689 { 0x0436, 169, "Accept Physical Link",
6690 accept_phy_link_cmd, 3, false },
6691 { 0x0437, 170, "Disconnect Physical Link",
6692 disconn_phy_link_cmd, 2, true },
6693 { 0x0438, 171, "Create Logical Link",
6694 create_logic_link_cmd, 33, true },
6695 { 0x0439, 172, "Accept Logical Link",
6696 accept_logic_link_cmd, 33, true },
6697 { 0x043a, 173, "Disconnect Logical Link",
6698 disconn_logic_link_cmd, 2, true },
6699 { 0x043b, 174, "Logical Link Cancel",
6700 logic_link_cancel_cmd, 2, true,
6701 logic_link_cancel_rsp, 3, true },
6702 { 0x043c, 175, "Flow Specifcation Modify",
6703 flow_spec_modify_cmd, 34, true },
6704 { 0x043d, 235, "Enhanced Setup Synchronous Connection",
6705 enhanced_setup_sync_conn_cmd, 59, true },
6706 { 0x043e, 236, "Enhanced Accept Synchronous Connection Request",
6707 enhanced_accept_sync_conn_request_cmd, 63, true },
6708 { 0x043f, 246, "Truncated Page",
6709 truncated_page_cmd, 9, true },
6710 { 0x0440, 247, "Truncated Page Cancel",
6711 truncated_page_cancel_cmd, 6, true,
6712 status_bdaddr_rsp, 7, true },
6713 { 0x0441, 248, "Set Connectionless Slave Broadcast",
6714 set_slave_broadcast_cmd, 11, true,
6715 set_slave_broadcast_rsp, 4, true },
6716 { 0x0442, 249, "Set Connectionless Slave Broadcast Receive",
6717 set_slave_broadcast_receive_cmd, 34, true,
6718 set_slave_broadcast_receive_rsp, 8, true },
6719 { 0x0443, 250, "Start Synchronization Train",
6720 null_cmd, 0, true },
6721 { 0x0444, 251, "Receive Synchronization Train",
6722 receive_sync_train_cmd, 12, true },
6723 { 0x0445, 257, "Remote OOB Extended Data Request Reply",
6724 remote_oob_ext_data_request_reply_cmd, 70, true,
6725 status_bdaddr_rsp, 7, true },
6727 /* OGF 2 - Link Policy */
6728 { 0x0801, 33, "Hold Mode",
6729 hold_mode_cmd, 6, true },
6730 { 0x0803, 34, "Sniff Mode",
6731 sniff_mode_cmd, 10, true },
6732 { 0x0804, 35, "Exit Sniff Mode",
6733 exit_sniff_mode_cmd, 2, true },
6734 { 0x0805, 36, "Park State",
6735 park_state_cmd, 6, true },
6736 { 0x0806, 37, "Exit Park State",
6737 exit_park_state_cmd, 2, true },
6738 { 0x0807, 38, "QoS Setup",
6739 qos_setup_cmd, 20, true },
6740 { 0x0809, 39, "Role Discovery",
6741 role_discovery_cmd, 2, true,
6742 role_discovery_rsp, 4, true },
6743 { 0x080b, 40, "Switch Role",
6744 switch_role_cmd, 7, true },
6745 { 0x080c, 41, "Read Link Policy Settings",
6746 read_link_policy_cmd, 2, true,
6747 read_link_policy_rsp, 5, true },
6748 { 0x080d, 42, "Write Link Policy Settings",
6749 write_link_policy_cmd, 4, true,
6750 write_link_policy_rsp, 3, true },
6751 { 0x080e, 43, "Read Default Link Policy Settings",
6753 read_default_link_policy_rsp, 3, true },
6754 { 0x080f, 44, "Write Default Link Policy Settings",
6755 write_default_link_policy_cmd, 2, true,
6756 status_rsp, 1, true },
6757 { 0x0810, 45, "Flow Specification",
6758 flow_spec_cmd, 21, true },
6759 { 0x0811, 140, "Sniff Subrating",
6760 sniff_subrating_cmd, 8, true,
6761 sniff_subrating_rsp, 3, true },
6763 /* OGF 3 - Host Control */
6764 { 0x0c01, 46, "Set Event Mask",
6765 set_event_mask_cmd, 8, true,
6766 status_rsp, 1, true },
6767 { 0x0c03, 47, "Reset",
6769 status_rsp, 1, true },
6770 { 0x0c05, 48, "Set Event Filter",
6771 set_event_filter_cmd, 1, false,
6772 status_rsp, 1, true },
6773 { 0x0c08, 49, "Flush",
6775 flush_rsp, 3, true },
6776 { 0x0c09, 50, "Read PIN Type",
6778 read_pin_type_rsp, 2, true },
6779 { 0x0c0a, 51, "Write PIN Type",
6780 write_pin_type_cmd, 1, true,
6781 status_rsp, 1, true },
6782 { 0x0c0b, 52, "Create New Unit Key",
6784 status_rsp, 1, true },
6785 { 0x0c0d, 53, "Read Stored Link Key",
6786 read_stored_link_key_cmd, 7, true,
6787 read_stored_link_key_rsp, 5, true },
6788 { 0x0c11, 54, "Write Stored Link Key",
6789 write_stored_link_key_cmd, 1, false,
6790 write_stored_link_key_rsp, 2, true },
6791 { 0x0c12, 55, "Delete Stored Link Key",
6792 delete_stored_link_key_cmd, 7, true,
6793 delete_stored_link_key_rsp, 3, true },
6794 { 0x0c13, 56, "Write Local Name",
6795 write_local_name_cmd, 248, true,
6796 status_rsp, 1, true },
6797 { 0x0c14, 57, "Read Local Name",
6799 read_local_name_rsp, 249, true },
6800 { 0x0c15, 58, "Read Connection Accept Timeout",
6802 read_conn_accept_timeout_rsp, 3, true },
6803 { 0x0c16, 59, "Write Connection Accept Timeout",
6804 write_conn_accept_timeout_cmd, 2, true,
6805 status_rsp, 1, true },
6806 { 0x0c17, 60, "Read Page Timeout",
6808 read_page_timeout_rsp, 3, true },
6809 { 0x0c18, 61, "Write Page Timeout",
6810 write_page_timeout_cmd, 2, true,
6811 status_rsp, 1, true },
6812 { 0x0c19, 62, "Read Scan Enable",
6814 read_scan_enable_rsp, 2, true },
6815 { 0x0c1a, 63, "Write Scan Enable",
6816 write_scan_enable_cmd, 1, true,
6817 status_rsp, 1, true },
6818 { 0x0c1b, 64, "Read Page Scan Activity",
6820 read_page_scan_activity_rsp, 5, true },
6821 { 0x0c1c, 65, "Write Page Scan Activity",
6822 write_page_scan_activity_cmd, 4, true,
6823 status_rsp, 1, true },
6824 { 0x0c1d, 66, "Read Inquiry Scan Activity",
6826 read_inquiry_scan_activity_rsp, 5, true },
6827 { 0x0c1e, 67, "Write Inquiry Scan Activity",
6828 write_inquiry_scan_activity_cmd, 4, true,
6829 status_rsp, 1, true },
6830 { 0x0c1f, 68, "Read Authentication Enable",
6832 read_auth_enable_rsp, 2, true },
6833 { 0x0c20, 69, "Write Authentication Enable",
6834 write_auth_enable_cmd, 1, true,
6835 status_rsp, 1, true },
6836 { 0x0c21, 70, "Read Encryption Mode",
6838 read_encrypt_mode_rsp, 2, true },
6839 { 0x0c22, 71, "Write Encryption Mode",
6840 write_encrypt_mode_cmd, 1, true,
6841 status_rsp, 1, true },
6842 { 0x0c23, 72, "Read Class of Device",
6844 read_class_of_dev_rsp, 4, true },
6845 { 0x0c24, 73, "Write Class of Device",
6846 write_class_of_dev_cmd, 3, true,
6847 status_rsp, 1, true },
6848 { 0x0c25, 74, "Read Voice Setting",
6850 read_voice_setting_rsp, 3, true },
6851 { 0x0c26, 75, "Write Voice Setting",
6852 write_voice_setting_cmd, 2, true,
6853 status_rsp, 1, true },
6854 { 0x0c27, 76, "Read Automatic Flush Timeout",
6855 read_auto_flush_timeout_cmd, 2, true,
6856 read_auto_flush_timeout_rsp, 5, true },
6857 { 0x0c28, 77, "Write Automatic Flush Timeout",
6858 write_auto_flush_timeout_cmd, 4, true,
6859 write_auto_flush_timeout_rsp, 3, true },
6860 { 0x0c29, 78, "Read Num Broadcast Retransmissions",
6862 read_num_broadcast_retrans_rsp, 2, true },
6863 { 0x0c2a, 79, "Write Num Broadcast Retransmissions",
6864 write_num_broadcast_retrans_cmd, 1, true,
6865 status_rsp, 1, true },
6866 { 0x0c2b, 80, "Read Hold Mode Activity",
6868 read_hold_mode_activity_rsp, 2, true },
6869 { 0x0c2c, 81, "Write Hold Mode Activity",
6870 write_hold_mode_activity_cmd, 1, true,
6871 status_rsp, 1, true },
6872 { 0x0c2d, 82, "Read Transmit Power Level",
6873 read_tx_power_cmd, 3, true,
6874 read_tx_power_rsp, 4, true },
6875 { 0x0c2e, 83, "Read Sync Flow Control Enable",
6877 read_sync_flow_control_rsp, 2, true },
6878 { 0x0c2f, 84, "Write Sync Flow Control Enable",
6879 write_sync_flow_control_cmd, 1, true,
6880 status_rsp, 1, true },
6881 { 0x0c31, 85, "Set Controller To Host Flow Control",
6882 set_host_flow_control_cmd, 1, true,
6883 status_rsp, 1, true },
6884 { 0x0c33, 86, "Host Buffer Size",
6885 host_buffer_size_cmd, 7, true,
6886 status_rsp, 1, true },
6887 { 0x0c35, 87, "Host Number of Completed Packets",
6888 host_num_completed_packets_cmd, 5, false },
6889 { 0x0c36, 88, "Read Link Supervision Timeout",
6890 read_link_supv_timeout_cmd, 2, true,
6891 read_link_supv_timeout_rsp, 5, true },
6892 { 0x0c37, 89, "Write Link Supervision Timeout",
6893 write_link_supv_timeout_cmd, 4, true,
6894 write_link_supv_timeout_rsp, 3, true },
6895 { 0x0c38, 90, "Read Number of Supported IAC",
6897 read_num_supported_iac_rsp, 2, true },
6898 { 0x0c39, 91, "Read Current IAC LAP",
6900 read_current_iac_lap_rsp, 2, false },
6901 { 0x0c3a, 92, "Write Current IAC LAP",
6902 write_current_iac_lap_cmd, 1, false,
6903 status_rsp, 1, true },
6904 { 0x0c3b, 93, "Read Page Scan Period Mode",
6906 read_page_scan_period_mode_rsp, 2, true },
6907 { 0x0c3c, 94, "Write Page Scan Period Mode",
6908 write_page_scan_period_mode_cmd, 1, true,
6909 status_rsp, 1, true },
6910 { 0x0c3d, 95, "Read Page Scan Mode",
6912 read_page_scan_mode_rsp, 2, true },
6913 { 0x0c3e, 96, "Write Page Scan Mode",
6914 write_page_scan_mode_cmd, 1, true,
6915 status_rsp, 1, true },
6916 { 0x0c3f, 97, "Set AFH Host Channel Classification",
6917 set_afh_host_classification_cmd, 10, true,
6918 status_rsp, 1, true },
6919 { 0x0c42, 100, "Read Inquiry Scan Type",
6921 read_inquiry_scan_type_rsp, 2, true },
6922 { 0x0c43, 101, "Write Inquiry Scan Type",
6923 write_inquiry_scan_type_cmd, 1, true,
6924 status_rsp, 1, true },
6925 { 0x0c44, 102, "Read Inquiry Mode",
6927 read_inquiry_mode_rsp, 2, true },
6928 { 0x0c45, 103, "Write Inquiry Mode",
6929 write_inquiry_mode_cmd, 1, true,
6930 status_rsp, 1, true },
6931 { 0x0c46, 104, "Read Page Scan Type",
6933 read_page_scan_type_rsp, 2, true },
6934 { 0x0c47, 105, "Write Page Scan Type",
6935 write_page_scan_type_cmd, 1, true,
6936 status_rsp, 1, true },
6937 { 0x0c48, 106, "Read AFH Channel Assessment Mode",
6939 read_afh_assessment_mode_rsp, 2, true },
6940 { 0x0c49, 107, "Write AFH Channel Assessment Mode",
6941 write_afh_assessment_mode_cmd, 1, true,
6942 status_rsp, 1, true },
6943 { 0x0c51, 136, "Read Extended Inquiry Response",
6945 read_ext_inquiry_response_rsp, 242, true },
6946 { 0x0c52, 137, "Write Extended Inquiry Response",
6947 write_ext_inquiry_response_cmd, 241, true,
6948 status_rsp, 1, true },
6949 { 0x0c53, 138, "Refresh Encryption Key",
6950 refresh_encrypt_key_cmd, 2, true },
6951 { 0x0c55, 141, "Read Simple Pairing Mode",
6953 read_simple_pairing_mode_rsp, 2, true },
6954 { 0x0c56, 142, "Write Simple Pairing Mode",
6955 write_simple_pairing_mode_cmd, 1, true,
6956 status_rsp, 1, true },
6957 { 0x0c57, 143, "Read Local OOB Data",
6959 read_local_oob_data_rsp, 33, true },
6960 { 0x0c58, 144, "Read Inquiry Response TX Power Level",
6962 read_inquiry_resp_tx_power_rsp, 2, true },
6963 { 0x0c59, 145, "Write Inquiry Transmit Power Level",
6964 write_inquiry_tx_power_cmd, 1, true,
6965 status_rsp, 1, true },
6966 { 0x0c5a, 146, "Read Default Erroneous Data Reporting",
6968 read_erroneous_reporting_rsp, 2, true },
6969 { 0x0c5b, 147, "Write Default Erroneous Data Reporting",
6970 write_erroneous_reporting_cmd, 1, true,
6971 status_rsp, 1, true },
6972 { 0x0c5f, 158, "Enhanced Flush",
6973 enhanced_flush_cmd, 3, true },
6974 { 0x0c60, 162, "Send Keypress Notification",
6975 send_keypress_notify_cmd, 7, true,
6976 send_keypress_notify_rsp, 7, true },
6977 { 0x0c61, 176, "Read Logical Link Accept Timeout" },
6978 { 0x0c62, 177, "Write Logical Link Accept Timeout" },
6979 { 0x0c63, 178, "Set Event Mask Page 2",
6980 set_event_mask_page2_cmd, 8, true,
6981 status_rsp, 1, true },
6982 { 0x0c64, 179, "Read Location Data",
6984 read_location_data_rsp, 6, true },
6985 { 0x0c65, 180, "Write Location Data",
6986 write_location_data_cmd, 5, true,
6987 status_rsp, 1, true },
6988 { 0x0c66, 184, "Read Flow Control Mode",
6990 read_flow_control_mode_rsp, 2, true },
6991 { 0x0c67, 185, "Write Flow Control Mode",
6992 write_flow_control_mode_cmd, 1, true,
6993 status_rsp, 1, true },
6994 { 0x0c68, 192, "Read Enhanced Transmit Power Level",
6995 read_enhanced_tx_power_cmd, 3, true,
6996 read_enhanced_tx_power_rsp, 6, true },
6997 { 0x0c69, 194, "Read Best Effort Flush Timeout" },
6998 { 0x0c6a, 195, "Write Best Effort Flush Timeout" },
6999 { 0x0c6b, 196, "Short Range Mode",
7000 short_range_mode_cmd, 2, true },
7001 { 0x0c6c, 197, "Read LE Host Supported",
7003 read_le_host_supported_rsp, 3, true },
7004 { 0x0c6d, 198, "Write LE Host Supported",
7005 write_le_host_supported_cmd, 2, true,
7006 status_rsp, 1, true },
7007 { 0x0c6e, 238, "Set MWS Channel Parameters" },
7008 { 0x0c6f, 239, "Set External Frame Configuration" },
7009 { 0x0c70, 240, "Set MWS Signaling" },
7010 { 0x0c71, 241, "Set MWS Transport Layer" },
7011 { 0x0c72, 242, "Set MWS Scan Frequency Table" },
7012 { 0x0c73, 244, "Set MWS Pattern Configuration" },
7013 { 0x0c74, 252, "Set Reserved LT_ADDR",
7014 set_reserved_lt_addr_cmd, 1, true,
7015 set_reserved_lt_addr_rsp, 2, true },
7016 { 0x0c75, 253, "Delete Reserved LT_ADDR",
7017 delete_reserved_lt_addr_cmd, 1, true,
7018 delete_reserved_lt_addr_rsp, 2, true },
7019 { 0x0c76, 254, "Set Connectionless Slave Broadcast Data",
7020 set_slave_broadcast_data_cmd, 3, false,
7021 set_slave_broadcast_data_rsp, 2, true },
7022 { 0x0c77, 255, "Read Synchronization Train Parameters",
7024 read_sync_train_params_rsp, 8, true },
7025 { 0x0c78, 256, "Write Synchronization Train Parameters",
7026 write_sync_train_params_cmd, 9, true,
7027 write_sync_train_params_rsp, 3, true },
7028 { 0x0c79, 258, "Read Secure Connections Host Support",
7030 read_secure_conn_support_rsp, 2, true },
7031 { 0x0c7a, 259, "Write Secure Connections Host Support",
7032 write_secure_conn_support_cmd, 1, true,
7033 status_rsp, 1, true },
7034 { 0x0c7b, 260, "Read Authenticated Payload Timeout",
7035 read_auth_payload_timeout_cmd, 2, true,
7036 read_auth_payload_timeout_rsp, 5, true },
7037 { 0x0c7c, 261, "Write Authenticated Payload Timeout",
7038 write_auth_payload_timeout_cmd, 4, true,
7039 write_auth_payload_timeout_rsp, 3, true },
7040 { 0x0c7d, 262, "Read Local OOB Extended Data",
7042 read_local_oob_ext_data_rsp, 65, true },
7043 { 0x0c7e, 264, "Read Extended Page Timeout",
7045 read_ext_page_timeout_rsp, 3, true },
7046 { 0x0c7f, 265, "Write Extended Page Timeout",
7047 write_ext_page_timeout_cmd, 2, true,
7048 status_rsp, 1, true },
7049 { 0x0c80, 266, "Read Extended Inquiry Length",
7051 read_ext_inquiry_length_rsp, 3, true },
7052 { 0x0c81, 267, "Write Extended Inquiry Length",
7053 write_ext_inquiry_length_cmd, 2, true,
7054 status_rsp, 1, true },
7056 /* OGF 4 - Information Parameter */
7057 { 0x1001, 115, "Read Local Version Information",
7059 read_local_version_rsp, 9, true },
7060 { 0x1002, 116, "Read Local Supported Commands",
7062 read_local_commands_rsp, 65, true },
7063 { 0x1003, 117, "Read Local Supported Features",
7065 read_local_features_rsp, 9, true },
7066 { 0x1004, 118, "Read Local Extended Features",
7067 read_local_ext_features_cmd, 1, true,
7068 read_local_ext_features_rsp, 11, true },
7069 { 0x1005, 119, "Read Buffer Size",
7071 read_buffer_size_rsp, 8, true },
7072 { 0x1007, 120, "Read Country Code",
7074 read_country_code_rsp, 2, true },
7075 { 0x1009, 121, "Read BD ADDR",
7077 read_bd_addr_rsp, 7, true },
7078 { 0x100a, 186, "Read Data Block Size",
7080 read_data_block_size_rsp, 7, true },
7081 { 0x100b, 237, "Read Local Supported Codecs",
7083 read_local_codecs_rsp, 3, false },
7085 /* OGF 5 - Status Parameter */
7086 { 0x1401, 122, "Read Failed Contact Counter",
7087 read_failed_contact_counter_cmd, 2, true,
7088 read_failed_contact_counter_rsp, 5, true },
7089 { 0x1402, 123, "Reset Failed Contact Counter",
7090 reset_failed_contact_counter_cmd, 2, true,
7091 reset_failed_contact_counter_rsp, 3, true },
7092 { 0x1403, 124, "Read Link Quality",
7093 read_link_quality_cmd, 2, true,
7094 read_link_quality_rsp, 4, true },
7095 { 0x1405, 125, "Read RSSI",
7096 read_rssi_cmd, 2, true,
7097 read_rssi_rsp, 4, true },
7098 { 0x1406, 126, "Read AFH Channel Map",
7099 read_afh_channel_map_cmd, 2, true,
7100 read_afh_channel_map_rsp, 14, true },
7101 { 0x1407, 127, "Read Clock",
7102 read_clock_cmd, 3, true,
7103 read_clock_rsp, 9, true },
7104 { 0x1408, 164, "Read Encryption Key Size",
7105 read_encrypt_key_size_cmd, 2, true,
7106 read_encrypt_key_size_rsp, 4, true },
7107 { 0x1409, 181, "Read Local AMP Info",
7109 read_local_amp_info_rsp, 31, true },
7110 { 0x140a, 182, "Read Local AMP ASSOC",
7111 read_local_amp_assoc_cmd, 5, true,
7112 read_local_amp_assoc_rsp, 5, false },
7113 { 0x140b, 183, "Write Remote AMP ASSOC",
7114 write_remote_amp_assoc_cmd, 6, false,
7115 write_remote_amp_assoc_rsp, 2, true },
7116 { 0x140c, 243, "Get MWS Transport Layer Configuration",
7118 get_mws_transport_config_rsp, 2, false },
7119 { 0x140d, 245, "Set Triggered Clock Capture",
7120 set_triggered_clock_capture_cmd, 6, true,
7121 status_rsp, 1, true },
7123 /* OGF 6 - Testing */
7124 { 0x1801, 128, "Read Loopback Mode",
7126 read_loopback_mode_rsp, 2, true },
7127 { 0x1802, 129, "Write Loopback Mode",
7128 write_loopback_mode_cmd, 1, true,
7129 status_rsp, 1, true },
7130 { 0x1803, 130, "Enable Device Under Test Mode",
7132 status_rsp, 1, true },
7133 { 0x1804, 157, "Write Simple Pairing Debug Mode",
7134 write_ssp_debug_mode_cmd, 1, true,
7135 status_rsp, 1, true },
7136 { 0x1807, 189, "Enable AMP Receiver Reports" },
7137 { 0x1808, 190, "AMP Test End" },
7138 { 0x1809, 191, "AMP Test" },
7139 { 0x180a, 263, "Write Secure Connections Test Mode" },
7141 /* OGF 8 - LE Control */
7142 { 0x2001, 200, "LE Set Event Mask",
7143 le_set_event_mask_cmd, 8, true,
7144 status_rsp, 1, true },
7145 { 0x2002, 201, "LE Read Buffer Size",
7147 le_read_buffer_size_rsp, 4, true },
7148 { 0x2003, 202, "LE Read Local Supported Features",
7150 le_read_local_features_rsp, 9, true },
7151 { 0x2005, 204, "LE Set Random Address",
7152 le_set_random_address_cmd, 6, true,
7153 status_rsp, 1, true },
7154 { 0x2006, 205, "LE Set Advertising Parameters",
7155 le_set_adv_parameters_cmd, 15, true,
7156 status_rsp, 1, true },
7157 { 0x2007, 206, "LE Read Advertising Channel TX Power",
7159 le_read_adv_tx_power_rsp, 2, true },
7160 { 0x2008, 207, "LE Set Advertising Data",
7161 le_set_adv_data_cmd, 32, true,
7162 status_rsp, 1, true },
7163 { 0x2009, 208, "LE Set Scan Response Data",
7164 le_set_scan_rsp_data_cmd, 32, true,
7165 status_rsp, 1, true },
7166 { 0x200a, 209, "LE Set Advertise Enable",
7167 le_set_adv_enable_cmd, 1, true,
7168 status_rsp, 1, true },
7169 { 0x200b, 210, "LE Set Scan Parameters",
7170 le_set_scan_parameters_cmd, 7, true,
7171 status_rsp, 1, true },
7172 { 0x200c, 211, "LE Set Scan Enable",
7173 le_set_scan_enable_cmd, 2, true,
7174 status_rsp, 1, true },
7175 { 0x200d, 212, "LE Create Connection",
7176 le_create_conn_cmd, 25, true },
7177 { 0x200e, 213, "LE Create Connection Cancel",
7179 status_rsp, 1, true },
7180 { 0x200f, 214, "LE Read White List Size",
7182 le_read_white_list_size_rsp, 2, true },
7183 { 0x2010, 215, "LE Clear White List",
7185 status_rsp, 1, true },
7186 { 0x2011, 216, "LE Add Device To White List",
7187 le_add_to_white_list_cmd, 7, true,
7188 status_rsp, 1, true },
7189 { 0x2012, 217, "LE Remove Device From White List",
7190 le_remove_from_white_list_cmd, 7, true,
7191 status_rsp, 1, true },
7192 { 0x2013, 218, "LE Connection Update",
7193 le_conn_update_cmd, 14, true },
7194 { 0x2014, 219, "LE Set Host Channel Classification",
7195 le_set_host_classification_cmd, 5, true,
7196 status_rsp, 1, true },
7197 { 0x2015, 220, "LE Read Channel Map",
7198 le_read_channel_map_cmd, 2, true,
7199 le_read_channel_map_rsp, 8, true },
7200 { 0x2016, 221, "LE Read Remote Used Features",
7201 le_read_remote_features_cmd, 2, true },
7202 { 0x2017, 222, "LE Encrypt",
7203 le_encrypt_cmd, 32, true,
7204 le_encrypt_rsp, 17, true },
7205 { 0x2018, 223, "LE Rand",
7207 le_rand_rsp, 9, true },
7208 { 0x2019, 224, "LE Start Encryption",
7209 le_start_encrypt_cmd, 28, true },
7210 { 0x201a, 225, "LE Long Term Key Request Reply",
7211 le_ltk_req_reply_cmd, 18, true,
7212 le_ltk_req_reply_rsp, 3, true },
7213 { 0x201b, 226, "LE Long Term Key Request Neg Reply",
7214 le_ltk_req_neg_reply_cmd, 2, true,
7215 le_ltk_req_neg_reply_rsp, 3, true },
7216 { 0x201c, 227, "LE Read Supported States",
7218 le_read_supported_states_rsp, 9, true },
7219 { 0x201d, 228, "LE Receiver Test",
7220 le_receiver_test_cmd, 1, true,
7221 status_rsp, 1, true },
7222 { 0x201e, 229, "LE Transmitter Test",
7223 le_transmitter_test_cmd, 3, true,
7224 status_rsp, 1, true },
7225 { 0x201f, 230, "LE Test End",
7227 le_test_end_rsp, 3, true },
7228 { 0x2020, 268, "LE Remote Connection Parameter Request Reply",
7229 le_conn_param_req_reply_cmd, 14, true,
7230 le_conn_param_req_reply_rsp, 3, true },
7231 { 0x2021, 269, "LE Remote Connection Parameter Request Negative Reply",
7232 le_conn_param_req_neg_reply_cmd, 3, true,
7233 le_conn_param_req_neg_reply_rsp, 3, true },
7234 { 0x2022, 270, "LE Set Data Length",
7235 le_set_data_length_cmd, 6, true,
7236 le_set_data_length_rsp, 3, true },
7237 { 0x2023, 271, "LE Read Suggested Default Data Length",
7239 le_read_default_data_length_rsp, 5, true },
7240 { 0x2024, 272, "LE Write Suggested Default Data Length",
7241 le_write_default_data_length_cmd, 4, true,
7242 status_rsp, 1, true },
7243 { 0x2025, 273, "LE Read Local P-256 Public Key",
7244 null_cmd, 0, true },
7245 { 0x2026, 274, "LE Generate DHKey",
7246 le_generate_dhkey_cmd, 64, true },
7247 { 0x2027, 275, "LE Add Device To Resolving List",
7248 le_add_to_resolv_list_cmd, 39, true,
7249 status_rsp, 1, true },
7250 { 0x2028, 276, "LE Remove Device From Resolving List",
7251 le_remove_from_resolv_list_cmd, 7, true,
7252 status_rsp, 1, true },
7253 { 0x2029, 277, "LE Clear Resolving List",
7255 status_rsp, 1, true },
7256 { 0x202a, 278, "LE Read Resolving List Size",
7258 le_read_resolv_list_size_rsp, 2, true },
7259 { 0x202b, 279, "LE Read Peer Resolvable Address",
7260 le_read_peer_resolv_addr_cmd, 7, true,
7261 le_read_peer_resolv_addr_rsp, 7, true },
7262 { 0x202c, 280, "LE Read Local Resolvable Address",
7263 le_read_local_resolv_addr_cmd, 7, true,
7264 le_read_local_resolv_addr_rsp, 7, true },
7265 { 0x202d, 281, "LE Set Address Resolution Enable",
7266 le_set_resolv_enable_cmd, 1, true,
7267 status_rsp, 1, true },
7268 { 0x202e, 282, "LE Set Resolvable Private Address Timeout",
7269 le_set_resolv_timeout_cmd, 2, true,
7270 status_rsp, 1, true },
7271 { 0x202f, 283, "LE Read Maximum Data Length",
7273 le_read_max_data_length_rsp, 9, true },
7277 static const char *get_supported_command(int bit)
7281 for (i = 0; opcode_table[i].str; i++) {
7282 if (opcode_table[i].bit == bit)
7283 return opcode_table[i].str;
7289 static const char *current_vendor_str(void)
7291 uint16_t manufacturer;
7293 if (index_current < MAX_INDEX)
7294 manufacturer = index_list[index_current].manufacturer;
7296 manufacturer = UNKNOWN_MANUFACTURER;
7298 switch (manufacturer) {
7308 static const struct vendor_ocf *current_vendor_ocf(uint16_t ocf)
7310 uint16_t manufacturer;
7312 if (index_current < MAX_INDEX)
7313 manufacturer = index_list[index_current].manufacturer;
7315 manufacturer = UNKNOWN_MANUFACTURER;
7317 switch (manufacturer) {
7319 return intel_vendor_ocf(ocf);
7321 return broadcom_vendor_ocf(ocf);
7327 static const struct vendor_evt *current_vendor_evt(uint8_t evt)
7329 uint16_t manufacturer;
7331 if (index_current < MAX_INDEX)
7332 manufacturer = index_list[index_current].manufacturer;
7334 manufacturer = UNKNOWN_MANUFACTURER;
7336 switch (manufacturer) {
7338 return intel_vendor_evt(evt);
7340 return broadcom_vendor_evt(evt);
7346 static void inquiry_complete_evt(const void *data, uint8_t size)
7348 const struct bt_hci_evt_inquiry_complete *evt = data;
7350 print_status(evt->status);
7353 static void inquiry_result_evt(const void *data, uint8_t size)
7355 const struct bt_hci_evt_inquiry_result *evt = data;
7357 print_num_resp(evt->num_resp);
7358 print_bdaddr(evt->bdaddr);
7359 print_pscan_rep_mode(evt->pscan_rep_mode);
7360 print_pscan_period_mode(evt->pscan_period_mode);
7361 print_pscan_mode(evt->pscan_mode);
7362 print_dev_class(evt->dev_class);
7363 print_clock_offset(evt->clock_offset);
7365 if (size > sizeof(*evt))
7366 packet_hexdump(data + sizeof(*evt), size - sizeof(*evt));
7369 static void conn_complete_evt(const void *data, uint8_t size)
7371 const struct bt_hci_evt_conn_complete *evt = data;
7373 print_status(evt->status);
7374 print_handle(evt->handle);
7375 print_bdaddr(evt->bdaddr);
7376 print_link_type(evt->link_type);
7377 print_encr_mode(evt->encr_mode);
7379 if (evt->status == 0x00)
7380 assign_handle(le16_to_cpu(evt->handle), 0x00);
7383 static void conn_request_evt(const void *data, uint8_t size)
7385 const struct bt_hci_evt_conn_request *evt = data;
7387 print_bdaddr(evt->bdaddr);
7388 print_dev_class(evt->dev_class);
7389 print_link_type(evt->link_type);
7392 static void disconnect_complete_evt(const void *data, uint8_t size)
7394 const struct bt_hci_evt_disconnect_complete *evt = data;
7396 print_status(evt->status);
7397 print_handle(evt->handle);
7398 print_reason(evt->reason);
7400 if (evt->status == 0x00)
7401 release_handle(le16_to_cpu(evt->handle));
7404 static void auth_complete_evt(const void *data, uint8_t size)
7406 const struct bt_hci_evt_auth_complete *evt = data;
7408 print_status(evt->status);
7409 print_handle(evt->handle);
7412 static void remote_name_request_complete_evt(const void *data, uint8_t size)
7414 const struct bt_hci_evt_remote_name_request_complete *evt = data;
7416 print_status(evt->status);
7417 print_bdaddr(evt->bdaddr);
7418 print_name(evt->name);
7421 static void encrypt_change_evt(const void *data, uint8_t size)
7423 const struct bt_hci_evt_encrypt_change *evt = data;
7425 print_status(evt->status);
7426 print_handle(evt->handle);
7427 print_encr_mode_change(evt->encr_mode, evt->handle);
7430 static void change_conn_link_key_complete_evt(const void *data, uint8_t size)
7432 const struct bt_hci_evt_change_conn_link_key_complete *evt = data;
7434 print_status(evt->status);
7435 print_handle(evt->handle);
7438 static void master_link_key_complete_evt(const void *data, uint8_t size)
7440 const struct bt_hci_evt_master_link_key_complete *evt = data;
7442 print_status(evt->status);
7443 print_handle(evt->handle);
7444 print_key_flag(evt->key_flag);
7447 static void remote_features_complete_evt(const void *data, uint8_t size)
7449 const struct bt_hci_evt_remote_features_complete *evt = data;
7451 print_status(evt->status);
7452 print_handle(evt->handle);
7453 print_features(0, evt->features, 0x00);
7456 static void remote_version_complete_evt(const void *data, uint8_t size)
7458 const struct bt_hci_evt_remote_version_complete *evt = data;
7460 print_status(evt->status);
7461 print_handle(evt->handle);
7462 print_lmp_version(evt->lmp_ver, evt->lmp_subver);
7463 print_manufacturer(evt->manufacturer);
7465 switch (le16_to_cpu(evt->manufacturer)) {
7467 print_manufacturer_broadcom(evt->lmp_subver, 0xffff);
7472 static void qos_setup_complete_evt(const void *data, uint8_t size)
7474 const struct bt_hci_evt_qos_setup_complete *evt = data;
7476 print_status(evt->status);
7477 print_handle(evt->handle);
7478 print_field("Flags: 0x%2.2x", evt->flags);
7480 print_service_type(evt->service_type);
7482 print_field("Token rate: %d", le32_to_cpu(evt->token_rate));
7483 print_field("Peak bandwidth: %d", le32_to_cpu(evt->peak_bandwidth));
7484 print_field("Latency: %d", le32_to_cpu(evt->latency));
7485 print_field("Delay variation: %d", le32_to_cpu(evt->delay_variation));
7488 static void cmd_complete_evt(const void *data, uint8_t size)
7490 const struct bt_hci_evt_cmd_complete *evt = data;
7491 uint16_t opcode = le16_to_cpu(evt->opcode);
7492 uint16_t ogf = cmd_opcode_ogf(opcode);
7493 uint16_t ocf = cmd_opcode_ocf(opcode);
7494 struct opcode_data vendor_data;
7495 const struct opcode_data *opcode_data = NULL;
7496 const char *opcode_color, *opcode_str;
7497 char vendor_str[150];
7500 for (i = 0; opcode_table[i].str; i++) {
7501 if (opcode_table[i].opcode == opcode) {
7502 opcode_data = &opcode_table[i];
7508 if (opcode_data->rsp_func)
7509 opcode_color = COLOR_HCI_COMMAND;
7511 opcode_color = COLOR_HCI_COMMAND_UNKNOWN;
7512 opcode_str = opcode_data->str;
7515 const struct vendor_ocf *vnd = current_vendor_ocf(ocf);
7518 const char *str = current_vendor_str();
7521 snprintf(vendor_str, sizeof(vendor_str),
7522 "%s %s", str, vnd->str);
7523 vendor_data.str = vendor_str;
7525 vendor_data.str = vnd->str;
7526 vendor_data.rsp_func = vnd->rsp_func;
7527 vendor_data.rsp_size = vnd->rsp_size;
7528 vendor_data.rsp_fixed = vnd->rsp_fixed;
7530 opcode_data = &vendor_data;
7532 if (opcode_data->rsp_func)
7533 opcode_color = COLOR_HCI_COMMAND;
7535 opcode_color = COLOR_HCI_COMMAND_UNKNOWN;
7536 opcode_str = opcode_data->str;
7538 opcode_color = COLOR_HCI_COMMAND;
7539 opcode_str = "Vendor";
7542 opcode_color = COLOR_HCI_COMMAND_UNKNOWN;
7543 opcode_str = "Unknown";
7547 print_indent(6, opcode_color, "", opcode_str, COLOR_OFF,
7548 " (0x%2.2x|0x%4.4x) ncmd %d", ogf, ocf, evt->ncmd);
7550 if (!opcode_data || !opcode_data->rsp_func) {
7552 uint8_t status = *((uint8_t *) (data + 3));
7554 print_status(status);
7555 packet_hexdump(data + 4, size - 4);
7560 if (opcode_data->rsp_size > 1 && size - 3 == 1) {
7561 uint8_t status = *((uint8_t *) (data + 3));
7563 print_status(status);
7567 if (opcode_data->rsp_fixed) {
7568 if (size - 3 != opcode_data->rsp_size) {
7569 print_text(COLOR_ERROR, "invalid packet size");
7570 packet_hexdump(data + 3, size - 3);
7574 if (size - 3 < opcode_data->rsp_size) {
7575 print_text(COLOR_ERROR, "too short packet");
7576 packet_hexdump(data + 3, size - 3);
7581 opcode_data->rsp_func(data + 3, size - 3);
7584 static void cmd_status_evt(const void *data, uint8_t size)
7586 const struct bt_hci_evt_cmd_status *evt = data;
7587 uint16_t opcode = le16_to_cpu(evt->opcode);
7588 uint16_t ogf = cmd_opcode_ogf(opcode);
7589 uint16_t ocf = cmd_opcode_ocf(opcode);
7590 const struct opcode_data *opcode_data = NULL;
7591 const char *opcode_color, *opcode_str;
7592 char vendor_str[150];
7595 for (i = 0; opcode_table[i].str; i++) {
7596 if (opcode_table[i].opcode == opcode) {
7597 opcode_data = &opcode_table[i];
7603 opcode_color = COLOR_HCI_COMMAND;
7604 opcode_str = opcode_data->str;
7607 const struct vendor_ocf *vnd = current_vendor_ocf(ocf);
7610 const char *str = current_vendor_str();
7613 snprintf(vendor_str, sizeof(vendor_str),
7614 "%s %s", str, vnd->str);
7615 opcode_str = vendor_str;
7617 opcode_str = vnd->str;
7619 opcode_color = COLOR_HCI_COMMAND;
7621 opcode_color = COLOR_HCI_COMMAND;
7622 opcode_str = "Vendor";
7625 opcode_color = COLOR_HCI_COMMAND_UNKNOWN;
7626 opcode_str = "Unknown";
7630 print_indent(6, opcode_color, "", opcode_str, COLOR_OFF,
7631 " (0x%2.2x|0x%4.4x) ncmd %d", ogf, ocf, evt->ncmd);
7633 print_status(evt->status);
7636 static void hardware_error_evt(const void *data, uint8_t size)
7638 const struct bt_hci_evt_hardware_error *evt = data;
7640 print_field("Code: 0x%2.2x", evt->code);
7643 static void flush_occurred_evt(const void *data, uint8_t size)
7645 const struct bt_hci_evt_flush_occurred *evt = data;
7647 print_handle(evt->handle);
7650 static void role_change_evt(const void *data, uint8_t size)
7652 const struct bt_hci_evt_role_change *evt = data;
7654 print_status(evt->status);
7655 print_bdaddr(evt->bdaddr);
7656 print_role(evt->role);
7659 static void num_completed_packets_evt(const void *data, uint8_t size)
7661 const struct bt_hci_evt_num_completed_packets *evt = data;
7663 print_field("Num handles: %d", evt->num_handles);
7664 print_handle(evt->handle);
7665 print_field("Count: %d", le16_to_cpu(evt->count));
7667 if (size > sizeof(*evt))
7668 packet_hexdump(data + sizeof(*evt), size - sizeof(*evt));
7671 static void mode_change_evt(const void *data, uint8_t size)
7673 const struct bt_hci_evt_mode_change *evt = data;
7675 print_status(evt->status);
7676 print_handle(evt->handle);
7677 print_mode(evt->mode);
7678 print_interval(evt->interval);
7681 static void return_link_keys_evt(const void *data, uint8_t size)
7683 const struct bt_hci_evt_return_link_keys *evt = data;
7686 print_field("Num keys: %d", evt->num_keys);
7688 for (i = 0; i < evt->num_keys; i++) {
7689 print_bdaddr(evt->keys + (i * 22));
7690 print_link_key(evt->keys + (i * 22) + 6);
7694 static void pin_code_request_evt(const void *data, uint8_t size)
7696 const struct bt_hci_evt_pin_code_request *evt = data;
7698 print_bdaddr(evt->bdaddr);
7701 static void link_key_request_evt(const void *data, uint8_t size)
7703 const struct bt_hci_evt_link_key_request *evt = data;
7705 print_bdaddr(evt->bdaddr);
7708 static void link_key_notify_evt(const void *data, uint8_t size)
7710 const struct bt_hci_evt_link_key_notify *evt = data;
7712 print_bdaddr(evt->bdaddr);
7713 print_link_key(evt->link_key);
7714 print_key_type(evt->key_type);
7717 static void loopback_command_evt(const void *data, uint8_t size)
7719 packet_hexdump(data, size);
7722 static void data_buffer_overflow_evt(const void *data, uint8_t size)
7724 const struct bt_hci_evt_data_buffer_overflow *evt = data;
7726 print_link_type(evt->link_type);
7729 static void max_slots_change_evt(const void *data, uint8_t size)
7731 const struct bt_hci_evt_max_slots_change *evt = data;
7733 print_handle(evt->handle);
7734 print_field("Max slots: %d", evt->max_slots);
7737 static void clock_offset_complete_evt(const void *data, uint8_t size)
7739 const struct bt_hci_evt_clock_offset_complete *evt = data;
7741 print_status(evt->status);
7742 print_handle(evt->handle);
7743 print_clock_offset(evt->clock_offset);
7746 static void conn_pkt_type_changed_evt(const void *data, uint8_t size)
7748 const struct bt_hci_evt_conn_pkt_type_changed *evt = data;
7750 print_status(evt->status);
7751 print_handle(evt->handle);
7752 print_pkt_type(evt->pkt_type);
7755 static void qos_violation_evt(const void *data, uint8_t size)
7757 const struct bt_hci_evt_qos_violation *evt = data;
7759 print_handle(evt->handle);
7762 static void pscan_mode_change_evt(const void *data, uint8_t size)
7764 const struct bt_hci_evt_pscan_mode_change *evt = data;
7766 print_bdaddr(evt->bdaddr);
7767 print_pscan_mode(evt->pscan_mode);
7770 static void pscan_rep_mode_change_evt(const void *data, uint8_t size)
7772 const struct bt_hci_evt_pscan_rep_mode_change *evt = data;
7774 print_bdaddr(evt->bdaddr);
7775 print_pscan_rep_mode(evt->pscan_rep_mode);
7778 static void flow_spec_complete_evt(const void *data, uint8_t size)
7780 const struct bt_hci_evt_flow_spec_complete *evt = data;
7782 print_status(evt->status);
7783 print_handle(evt->handle);
7784 print_field("Flags: 0x%2.2x", evt->flags);
7786 print_flow_direction(evt->direction);
7787 print_service_type(evt->service_type);
7789 print_field("Token rate: %d", le32_to_cpu(evt->token_rate));
7790 print_field("Token bucket size: %d",
7791 le32_to_cpu(evt->token_bucket_size));
7792 print_field("Peak bandwidth: %d", le32_to_cpu(evt->peak_bandwidth));
7793 print_field("Access latency: %d", le32_to_cpu(evt->access_latency));
7796 static void inquiry_result_with_rssi_evt(const void *data, uint8_t size)
7798 const struct bt_hci_evt_inquiry_result_with_rssi *evt = data;
7800 print_num_resp(evt->num_resp);
7801 print_bdaddr(evt->bdaddr);
7802 print_pscan_rep_mode(evt->pscan_rep_mode);
7803 print_pscan_period_mode(evt->pscan_period_mode);
7804 print_dev_class(evt->dev_class);
7805 print_clock_offset(evt->clock_offset);
7806 print_rssi(evt->rssi);
7808 if (size > sizeof(*evt))
7809 packet_hexdump(data + sizeof(*evt), size - sizeof(*evt));
7812 static void remote_ext_features_complete_evt(const void *data, uint8_t size)
7814 const struct bt_hci_evt_remote_ext_features_complete *evt = data;
7816 print_status(evt->status);
7817 print_handle(evt->handle);
7818 print_field("Page: %d/%d", evt->page, evt->max_page);
7819 print_features(evt->page, evt->features, 0x00);
7822 static void sync_conn_complete_evt(const void *data, uint8_t size)
7824 const struct bt_hci_evt_sync_conn_complete *evt = data;
7826 print_status(evt->status);
7827 print_handle(evt->handle);
7828 print_bdaddr(evt->bdaddr);
7829 print_link_type(evt->link_type);
7830 print_field("Transmission interval: 0x%2.2x", evt->tx_interval);
7831 print_field("Retransmission window: 0x%2.2x", evt->retrans_window);
7832 print_field("RX packet length: %d", le16_to_cpu(evt->rx_pkt_len));
7833 print_field("TX packet length: %d", le16_to_cpu(evt->tx_pkt_len));
7834 print_air_mode(evt->air_mode);
7837 static void sync_conn_changed_evt(const void *data, uint8_t size)
7839 const struct bt_hci_evt_sync_conn_changed *evt = data;
7841 print_status(evt->status);
7842 print_handle(evt->handle);
7843 print_field("Transmission interval: 0x%2.2x", evt->tx_interval);
7844 print_field("Retransmission window: 0x%2.2x", evt->retrans_window);
7845 print_field("RX packet length: %d", le16_to_cpu(evt->rx_pkt_len));
7846 print_field("TX packet length: %d", le16_to_cpu(evt->tx_pkt_len));
7849 static void sniff_subrating_evt(const void *data, uint8_t size)
7851 const struct bt_hci_evt_sniff_subrating *evt = data;
7853 print_status(evt->status);
7854 print_handle(evt->handle);
7855 print_slot_625("Max transmit latency", evt->max_tx_latency);
7856 print_slot_625("Max receive latency", evt->max_rx_latency);
7857 print_slot_625("Min remote timeout", evt->min_remote_timeout);
7858 print_slot_625("Min local timeout", evt->min_local_timeout);
7861 static void ext_inquiry_result_evt(const void *data, uint8_t size)
7863 const struct bt_hci_evt_ext_inquiry_result *evt = data;
7865 print_num_resp(evt->num_resp);
7866 print_bdaddr(evt->bdaddr);
7867 print_pscan_rep_mode(evt->pscan_rep_mode);
7868 print_pscan_period_mode(evt->pscan_period_mode);
7869 print_dev_class(evt->dev_class);
7870 print_clock_offset(evt->clock_offset);
7871 print_rssi(evt->rssi);
7872 print_eir(evt->data, sizeof(evt->data), false);
7875 static void encrypt_key_refresh_complete_evt(const void *data, uint8_t size)
7877 const struct bt_hci_evt_encrypt_key_refresh_complete *evt = data;
7879 print_status(evt->status);
7880 print_handle(evt->handle);
7883 static void io_capability_request_evt(const void *data, uint8_t size)
7885 const struct bt_hci_evt_io_capability_request *evt = data;
7887 print_bdaddr(evt->bdaddr);
7890 static void io_capability_response_evt(const void *data, uint8_t size)
7892 const struct bt_hci_evt_io_capability_response *evt = data;
7894 print_bdaddr(evt->bdaddr);
7895 print_io_capability(evt->capability);
7896 print_oob_data_response(evt->oob_data);
7897 print_authentication(evt->authentication);
7900 static void user_confirm_request_evt(const void *data, uint8_t size)
7902 const struct bt_hci_evt_user_confirm_request *evt = data;
7904 print_bdaddr(evt->bdaddr);
7905 print_passkey(evt->passkey);
7908 static void user_passkey_request_evt(const void *data, uint8_t size)
7910 const struct bt_hci_evt_user_passkey_request *evt = data;
7912 print_bdaddr(evt->bdaddr);
7915 static void remote_oob_data_request_evt(const void *data, uint8_t size)
7917 const struct bt_hci_evt_remote_oob_data_request *evt = data;
7919 print_bdaddr(evt->bdaddr);
7922 static void simple_pairing_complete_evt(const void *data, uint8_t size)
7924 const struct bt_hci_evt_simple_pairing_complete *evt = data;
7926 print_status(evt->status);
7927 print_bdaddr(evt->bdaddr);
7930 static void link_supv_timeout_changed_evt(const void *data, uint8_t size)
7932 const struct bt_hci_evt_link_supv_timeout_changed *evt = data;
7934 print_handle(evt->handle);
7935 print_timeout(evt->timeout);
7938 static void enhanced_flush_complete_evt(const void *data, uint8_t size)
7940 const struct bt_hci_evt_enhanced_flush_complete *evt = data;
7942 print_handle(evt->handle);
7945 static void user_passkey_notify_evt(const void *data, uint8_t size)
7947 const struct bt_hci_evt_user_passkey_notify *evt = data;
7949 print_bdaddr(evt->bdaddr);
7950 print_passkey(evt->passkey);
7953 static void keypress_notify_evt(const void *data, uint8_t size)
7955 const struct bt_hci_evt_keypress_notify *evt = data;
7958 print_bdaddr(evt->bdaddr);
7960 switch (evt->type) {
7962 str = "Passkey entry started";
7965 str = "Passkey digit entered";
7968 str = "Passkey digit erased";
7971 str = "Passkey clared";
7974 str = "Passkey entry completed";
7981 print_field("Notification type: %s (0x%2.2x)", str, evt->type);
7984 static void remote_host_features_notify_evt(const void *data, uint8_t size)
7986 const struct bt_hci_evt_remote_host_features_notify *evt = data;
7988 print_bdaddr(evt->bdaddr);
7989 print_features(1, evt->features, 0x00);
7992 static void phy_link_complete_evt(const void *data, uint8_t size)
7994 const struct bt_hci_evt_phy_link_complete *evt = data;
7996 print_status(evt->status);
7997 print_phy_handle(evt->phy_handle);
8000 static void channel_selected_evt(const void *data, uint8_t size)
8002 const struct bt_hci_evt_channel_selected *evt = data;
8004 print_phy_handle(evt->phy_handle);
8007 static void disconn_phy_link_complete_evt(const void *data, uint8_t size)
8009 const struct bt_hci_evt_disconn_phy_link_complete *evt = data;
8011 print_status(evt->status);
8012 print_phy_handle(evt->phy_handle);
8013 print_reason(evt->reason);
8016 static void phy_link_loss_early_warning_evt(const void *data, uint8_t size)
8018 const struct bt_hci_evt_phy_link_loss_early_warning *evt = data;
8021 print_phy_handle(evt->phy_handle);
8023 switch (evt->reason) {
8028 str = "Range related";
8031 str = "Bandwidth related";
8034 str = "Resolving conflict";
8037 str = "Interference";
8044 print_field("Reason: %s (0x%2.2x)", str, evt->reason);
8047 static void phy_link_recovery_evt(const void *data, uint8_t size)
8049 const struct bt_hci_evt_phy_link_recovery *evt = data;
8051 print_phy_handle(evt->phy_handle);
8054 static void logic_link_complete_evt(const void *data, uint8_t size)
8056 const struct bt_hci_evt_logic_link_complete *evt = data;
8058 print_status(evt->status);
8059 print_handle(evt->handle);
8060 print_phy_handle(evt->phy_handle);
8061 print_field("TX flow spec: 0x%2.2x", evt->flow_spec);
8064 static void disconn_logic_link_complete_evt(const void *data, uint8_t size)
8066 const struct bt_hci_evt_disconn_logic_link_complete *evt = data;
8068 print_status(evt->status);
8069 print_handle(evt->handle);
8070 print_reason(evt->reason);
8073 static void flow_spec_modify_complete_evt(const void *data, uint8_t size)
8075 const struct bt_hci_evt_flow_spec_modify_complete *evt = data;
8077 print_status(evt->status);
8078 print_handle(evt->handle);
8081 static void num_completed_data_blocks_evt(const void *data, uint8_t size)
8083 const struct bt_hci_evt_num_completed_data_blocks *evt = data;
8085 print_field("Total num data blocks: %d",
8086 le16_to_cpu(evt->total_num_blocks));
8087 print_field("Num handles: %d", evt->num_handles);
8088 print_handle(evt->handle);
8089 print_field("Num packets: %d", evt->num_packets);
8090 print_field("Num blocks: %d", evt->num_blocks);
8092 if (size > sizeof(*evt))
8093 packet_hexdump(data + sizeof(*evt), size - sizeof(*evt));
8096 static void short_range_mode_change_evt(const void *data, uint8_t size)
8098 const struct bt_hci_evt_short_range_mode_change *evt = data;
8100 print_status(evt->status);
8101 print_phy_handle(evt->phy_handle);
8102 print_short_range_mode(evt->mode);
8105 static void amp_status_change_evt(const void *data, uint8_t size)
8107 const struct bt_hci_evt_amp_status_change *evt = data;
8109 print_status(evt->status);
8110 print_amp_status(evt->amp_status);
8113 static void triggered_clock_capture_evt(const void *data, uint8_t size)
8115 const struct bt_hci_evt_triggered_clock_capture *evt = data;
8117 print_handle(evt->handle);
8118 print_clock_type(evt->type);
8119 print_clock(evt->clock);
8120 print_clock_offset(evt->clock_offset);
8123 static void sync_train_complete_evt(const void *data, uint8_t size)
8125 const struct bt_hci_evt_sync_train_complete *evt = data;
8127 print_status(evt->status);
8130 static void sync_train_received_evt(const void *data, uint8_t size)
8132 const struct bt_hci_evt_sync_train_received *evt = data;
8134 print_status(evt->status);
8135 print_bdaddr(evt->bdaddr);
8136 print_field("Offset: 0x%8.8x", le32_to_cpu(evt->offset));
8137 print_channel_map(evt->map);
8138 print_lt_addr(evt->lt_addr);
8139 print_field("Next broadcast instant: 0x%4.4x",
8140 le16_to_cpu(evt->instant));
8141 print_interval(evt->interval);
8142 print_field("Service Data: 0x%2.2x", evt->service_data);
8145 static void slave_broadcast_receive_evt(const void *data, uint8_t size)
8147 const struct bt_hci_evt_slave_broadcast_receive *evt = data;
8149 print_bdaddr(evt->bdaddr);
8150 print_lt_addr(evt->lt_addr);
8151 print_field("Clock: 0x%8.8x", le32_to_cpu(evt->clock));
8152 print_field("Offset: 0x%8.8x", le32_to_cpu(evt->offset));
8153 print_field("Receive status: 0x%2.2x", evt->status);
8154 print_broadcast_fragment(evt->fragment);
8155 print_field("Length: %d", evt->length);
8157 if (size - 18 != evt->length)
8158 print_text(COLOR_ERROR, "invalid data size (%d != %d)",
8159 size - 18, evt->length);
8161 if (evt->lt_addr == 0x01 && evt->length == 17)
8162 print_3d_broadcast(data + 18, size - 18);
8164 packet_hexdump(data + 18, size - 18);
8167 static void slave_broadcast_timeout_evt(const void *data, uint8_t size)
8169 const struct bt_hci_evt_slave_broadcast_timeout *evt = data;
8171 print_bdaddr(evt->bdaddr);
8172 print_lt_addr(evt->lt_addr);
8175 static void truncated_page_complete_evt(const void *data, uint8_t size)
8177 const struct bt_hci_evt_truncated_page_complete *evt = data;
8179 print_status(evt->status);
8180 print_bdaddr(evt->bdaddr);
8183 static void slave_page_response_timeout_evt(const void *data, uint8_t size)
8187 static void slave_broadcast_channel_map_change_evt(const void *data, uint8_t size)
8189 const struct bt_hci_evt_slave_broadcast_channel_map_change *evt = data;
8191 print_channel_map(evt->map);
8194 static void inquiry_response_notify_evt(const void *data, uint8_t size)
8196 const struct bt_hci_evt_inquiry_response_notify *evt = data;
8198 print_iac(evt->lap);
8199 print_rssi(evt->rssi);
8202 static void auth_payload_timeout_expired_evt(const void *data, uint8_t size)
8204 const struct bt_hci_evt_auth_payload_timeout_expired *evt = data;
8206 print_handle(evt->handle);
8209 static void le_conn_complete_evt(const void *data, uint8_t size)
8211 const struct bt_hci_evt_le_conn_complete *evt = data;
8213 print_status(evt->status);
8214 print_handle(evt->handle);
8215 print_role(evt->role);
8216 print_peer_addr_type("Peer address type", evt->peer_addr_type);
8217 print_addr("Peer address", evt->peer_addr, evt->peer_addr_type);
8218 print_slot_125("Connection interval", evt->interval);
8219 print_slot_125("Connection latency", evt->latency);
8220 print_field("Supervision timeout: %d msec (0x%4.4x)",
8221 le16_to_cpu(evt->supv_timeout) * 10,
8222 le16_to_cpu(evt->supv_timeout));
8223 print_field("Master clock accuracy: 0x%2.2x", evt->clock_accuracy);
8225 if (evt->status == 0x00)
8226 assign_handle(le16_to_cpu(evt->handle), 0x01);
8229 static void le_adv_report_evt(const void *data, uint8_t size)
8231 const struct bt_hci_evt_le_adv_report *evt = data;
8235 print_num_reports(evt->num_reports);
8238 print_adv_event_type(evt->event_type);
8239 print_peer_addr_type("Address type", evt->addr_type);
8240 print_addr("Address", evt->addr, evt->addr_type);
8241 print_field("Data length: %d", evt->data_len);
8242 print_eir(evt->data, evt->data_len, true);
8244 rssi = (int8_t *) (evt->data + evt->data_len);
8247 evt_len = sizeof(*evt) + evt->data_len + 1;
8249 if (size > evt_len) {
8250 data += evt_len - 1;
8251 size -= evt_len - 1;
8257 static void le_conn_update_complete_evt(const void *data, uint8_t size)
8259 const struct bt_hci_evt_le_conn_update_complete *evt = data;
8261 print_status(evt->status);
8262 print_handle(evt->handle);
8263 print_slot_125("Connection interval", evt->interval);
8264 print_slot_125("Connection latency", evt->latency);
8265 print_field("Supervision timeout: %d msec (0x%4.4x)",
8266 le16_to_cpu(evt->supv_timeout) * 10,
8267 le16_to_cpu(evt->supv_timeout));
8270 static void le_remote_features_complete_evt(const void *data, uint8_t size)
8272 const struct bt_hci_evt_le_remote_features_complete *evt = data;
8274 print_status(evt->status);
8275 print_handle(evt->handle);
8276 print_features(0, evt->features, 0x01);
8279 static void le_long_term_key_request_evt(const void *data, uint8_t size)
8281 const struct bt_hci_evt_le_long_term_key_request *evt = data;
8283 print_handle(evt->handle);
8284 print_random_number(evt->rand);
8285 print_encrypted_diversifier(evt->ediv);
8288 static void le_conn_param_request_evt(const void *data, uint8_t size)
8290 const struct bt_hci_evt_le_conn_param_request *evt = data;
8292 print_handle(evt->handle);
8293 print_slot_125("Min connection interval", evt->min_interval);
8294 print_slot_125("Max connection interval", evt->max_interval);
8295 print_field("Connection latency: 0x%4.4x", le16_to_cpu(evt->latency));
8296 print_field("Supervision timeout: %d msec (0x%4.4x)",
8297 le16_to_cpu(evt->supv_timeout) * 10,
8298 le16_to_cpu(evt->supv_timeout));
8301 static void le_data_length_change_evt(const void *data, uint8_t size)
8303 const struct bt_hci_evt_le_data_length_change *evt = data;
8305 print_handle(evt->handle);
8306 print_field("Max TX octets: %d", le16_to_cpu(evt->max_tx_len));
8307 print_field("Max TX time: %d", le16_to_cpu(evt->max_tx_time));
8308 print_field("Max RX octets: %d", le16_to_cpu(evt->max_rx_len));
8309 print_field("Max RX time: %d", le16_to_cpu(evt->max_rx_time));
8312 static void le_read_local_pk256_complete_evt(const void *data, uint8_t size)
8314 const struct bt_hci_evt_le_read_local_pk256_complete *evt = data;
8316 print_status(evt->status);
8317 print_pk256("Local P-256 public key", evt->local_pk256);
8320 static void le_generate_dhkey_complete_evt(const void *data, uint8_t size)
8322 const struct bt_hci_evt_le_generate_dhkey_complete *evt = data;
8324 print_status(evt->status);
8325 print_dhkey(evt->dhkey);
8328 static void le_enhanced_conn_complete_evt(const void *data, uint8_t size)
8330 const struct bt_hci_evt_le_enhanced_conn_complete *evt = data;
8332 print_status(evt->status);
8333 print_handle(evt->handle);
8334 print_role(evt->role);
8335 print_peer_addr_type("Peer address type", evt->peer_addr_type);
8336 print_addr("Peer address", evt->peer_addr, evt->peer_addr_type);
8337 print_addr("Local resolvable private address", evt->local_rpa, 0x01);
8338 print_addr("Peer resolvable private address", evt->peer_rpa, 0x01);
8339 print_slot_125("Connection interval", evt->interval);
8340 print_slot_125("Connection latency", evt->latency);
8341 print_field("Supervision timeout: %d msec (0x%4.4x)",
8342 le16_to_cpu(evt->supv_timeout) * 10,
8343 le16_to_cpu(evt->supv_timeout));
8344 print_field("Master clock accuracy: 0x%2.2x", evt->clock_accuracy);
8346 if (evt->status == 0x00)
8347 assign_handle(le16_to_cpu(evt->handle), 0x01);
8350 static void le_direct_adv_report_evt(const void *data, uint8_t size)
8352 const struct bt_hci_evt_le_direct_adv_report *evt = data;
8354 print_num_reports(evt->num_reports);
8356 print_adv_event_type(evt->event_type);
8357 print_peer_addr_type("Address type", evt->addr_type);
8358 print_addr("Address", evt->addr, evt->addr_type);
8359 print_addr_type("Direct address type", evt->direct_addr_type);
8360 print_addr("Direct address", evt->direct_addr, evt->direct_addr_type);
8361 print_rssi(evt->rssi);
8363 if (size > sizeof(*evt))
8364 packet_hexdump(data + sizeof(*evt), size - sizeof(*evt));
8367 struct subevent_data {
8370 void (*func) (const void *data, uint8_t size);
8375 static void print_subevent(const struct subevent_data *subevent_data,
8376 const void *data, uint8_t size)
8378 const char *subevent_color, *subevent_str;
8380 if (subevent_data) {
8381 if (subevent_data->func)
8382 subevent_color = COLOR_HCI_EVENT;
8384 subevent_color = COLOR_HCI_EVENT_UNKNOWN;
8385 subevent_str = subevent_data->str;
8387 subevent_color = COLOR_HCI_EVENT_UNKNOWN;
8388 subevent_str = "Unknown";
8391 print_indent(6, subevent_color, "", subevent_str, COLOR_OFF,
8392 " (0x%2.2x)", subevent_data->subevent);
8394 if (!subevent_data || !subevent_data->func) {
8395 packet_hexdump(data, size);
8399 if (subevent_data->fixed) {
8400 if (size != subevent_data->size) {
8401 print_text(COLOR_ERROR, "invalid packet size");
8402 packet_hexdump(data, size);
8406 if (size < subevent_data->size) {
8407 print_text(COLOR_ERROR, "too short packet");
8408 packet_hexdump(data, size);
8413 subevent_data->func(data, size);
8416 static const struct subevent_data le_meta_event_table[] = {
8417 { 0x01, "LE Connection Complete",
8418 le_conn_complete_evt, 18, true },
8419 { 0x02, "LE Advertising Report",
8420 le_adv_report_evt, 1, false },
8421 { 0x03, "LE Connection Update Complete",
8422 le_conn_update_complete_evt, 9, true },
8423 { 0x04, "LE Read Remote Used Features",
8424 le_remote_features_complete_evt, 11, true },
8425 { 0x05, "LE Long Term Key Request",
8426 le_long_term_key_request_evt, 12, true },
8427 { 0x06, "LE Remote Connection Parameter Request",
8428 le_conn_param_request_evt, 10, true },
8429 { 0x07, "LE Data Length Change",
8430 le_data_length_change_evt, 10, true },
8431 { 0x08, "LE Read Local P-256 Public Key Complete",
8432 le_read_local_pk256_complete_evt, 65, true },
8433 { 0x09, "LE Generate DHKey Complete",
8434 le_generate_dhkey_complete_evt, 33, true },
8435 { 0x0a, "LE Enhanced Connection Complete",
8436 le_enhanced_conn_complete_evt, 30, true },
8437 { 0x0b, "LE Direct Advertising Report",
8438 le_direct_adv_report_evt, 1, false },
8442 static void le_meta_event_evt(const void *data, uint8_t size)
8444 uint8_t subevent = *((const uint8_t *) data);
8445 const struct subevent_data *subevent_data = NULL;
8448 for (i = 0; le_meta_event_table[i].str; i++) {
8449 if (le_meta_event_table[i].subevent == subevent) {
8450 subevent_data = &le_meta_event_table[i];
8455 print_subevent(subevent_data, data + 1, size - 1);
8458 static void vendor_evt(const void *data, uint8_t size)
8460 uint8_t subevent = *((const uint8_t *) data);
8461 struct subevent_data vendor_data;
8462 char vendor_str[150];
8463 const struct vendor_evt *vnd = current_vendor_evt(subevent);
8466 const char *str = current_vendor_str();
8469 snprintf(vendor_str, sizeof(vendor_str),
8470 "%s %s", str, vnd->str);
8471 vendor_data.str = vendor_str;
8473 vendor_data.str = vnd->str;
8474 vendor_data.subevent = subevent;
8475 vendor_data.func = vnd->evt_func;
8476 vendor_data.size = vnd->evt_size;
8477 vendor_data.fixed = vnd->evt_fixed;
8479 print_subevent(&vendor_data, data + 1, size - 1);
8481 uint16_t manufacturer;
8483 if (index_current < MAX_INDEX)
8484 manufacturer = index_list[index_current].manufacturer;
8486 manufacturer = UNKNOWN_MANUFACTURER;
8488 vendor_event(manufacturer, data, size);
8495 void (*func) (const void *data, uint8_t size);
8500 static const struct event_data event_table[] = {
8501 { 0x01, "Inquiry Complete",
8502 inquiry_complete_evt, 1, true },
8503 { 0x02, "Inquiry Result",
8504 inquiry_result_evt, 1, false },
8505 { 0x03, "Connect Complete",
8506 conn_complete_evt, 11, true },
8507 { 0x04, "Connect Request",
8508 conn_request_evt, 10, true },
8509 { 0x05, "Disconnect Complete",
8510 disconnect_complete_evt, 4, true },
8511 { 0x06, "Auth Complete",
8512 auth_complete_evt, 3, true },
8513 { 0x07, "Remote Name Req Complete",
8514 remote_name_request_complete_evt, 255, true },
8515 { 0x08, "Encryption Change",
8516 encrypt_change_evt, 4, true },
8517 { 0x09, "Change Connection Link Key Complete",
8518 change_conn_link_key_complete_evt, 3, true },
8519 { 0x0a, "Master Link Key Complete",
8520 master_link_key_complete_evt, 4, true },
8521 { 0x0b, "Read Remote Supported Features",
8522 remote_features_complete_evt, 11, true },
8523 { 0x0c, "Read Remote Version Complete",
8524 remote_version_complete_evt, 8, true },
8525 { 0x0d, "QoS Setup Complete",
8526 qos_setup_complete_evt, 21, true },
8527 { 0x0e, "Command Complete",
8528 cmd_complete_evt, 3, false },
8529 { 0x0f, "Command Status",
8530 cmd_status_evt, 4, true },
8531 { 0x10, "Hardware Error",
8532 hardware_error_evt, 1, true },
8533 { 0x11, "Flush Occurred",
8534 flush_occurred_evt, 2, true },
8535 { 0x12, "Role Change",
8536 role_change_evt, 8, true },
8537 { 0x13, "Number of Completed Packets",
8538 num_completed_packets_evt, 1, false },
8539 { 0x14, "Mode Change",
8540 mode_change_evt, 6, true },
8541 { 0x15, "Return Link Keys",
8542 return_link_keys_evt, 1, false },
8543 { 0x16, "PIN Code Request",
8544 pin_code_request_evt, 6, true },
8545 { 0x17, "Link Key Request",
8546 link_key_request_evt, 6, true },
8547 { 0x18, "Link Key Notification",
8548 link_key_notify_evt, 23, true },
8549 { 0x19, "Loopback Command",
8550 loopback_command_evt, 3, false },
8551 { 0x1a, "Data Buffer Overflow",
8552 data_buffer_overflow_evt, 1, true },
8553 { 0x1b, "Max Slots Change",
8554 max_slots_change_evt, 3, true },
8555 { 0x1c, "Read Clock Offset Complete",
8556 clock_offset_complete_evt, 5, true },
8557 { 0x1d, "Connection Packet Type Changed",
8558 conn_pkt_type_changed_evt, 5, true },
8559 { 0x1e, "QoS Violation",
8560 qos_violation_evt, 2, true },
8561 { 0x1f, "Page Scan Mode Change",
8562 pscan_mode_change_evt, 7, true },
8563 { 0x20, "Page Scan Repetition Mode Change",
8564 pscan_rep_mode_change_evt, 7, true },
8565 { 0x21, "Flow Specification Complete",
8566 flow_spec_complete_evt, 22, true },
8567 { 0x22, "Inquiry Result with RSSI",
8568 inquiry_result_with_rssi_evt, 1, false },
8569 { 0x23, "Read Remote Extended Features",
8570 remote_ext_features_complete_evt, 13, true },
8571 { 0x2c, "Synchronous Connect Complete",
8572 sync_conn_complete_evt, 17, true },
8573 { 0x2d, "Synchronous Connect Changed",
8574 sync_conn_changed_evt, 9, true },
8575 { 0x2e, "Sniff Subrating",
8576 sniff_subrating_evt, 11, true },
8577 { 0x2f, "Extended Inquiry Result",
8578 ext_inquiry_result_evt, 1, false },
8579 { 0x30, "Encryption Key Refresh Complete",
8580 encrypt_key_refresh_complete_evt, 3, true },
8581 { 0x31, "IO Capability Request",
8582 io_capability_request_evt, 6, true },
8583 { 0x32, "IO Capability Response",
8584 io_capability_response_evt, 9, true },
8585 { 0x33, "User Confirmation Request",
8586 user_confirm_request_evt, 10, true },
8587 { 0x34, "User Passkey Request",
8588 user_passkey_request_evt, 6, true },
8589 { 0x35, "Remote OOB Data Request",
8590 remote_oob_data_request_evt, 6, true },
8591 { 0x36, "Simple Pairing Complete",
8592 simple_pairing_complete_evt, 7, true },
8593 { 0x38, "Link Supervision Timeout Changed",
8594 link_supv_timeout_changed_evt, 4, true },
8595 { 0x39, "Enhanced Flush Complete",
8596 enhanced_flush_complete_evt, 2, true },
8597 { 0x3b, "User Passkey Notification",
8598 user_passkey_notify_evt, 10, true },
8599 { 0x3c, "Keypress Notification",
8600 keypress_notify_evt, 7, true },
8601 { 0x3d, "Remote Host Supported Features",
8602 remote_host_features_notify_evt, 14, true },
8603 { 0x3e, "LE Meta Event",
8604 le_meta_event_evt, 1, false },
8605 { 0x40, "Physical Link Complete",
8606 phy_link_complete_evt, 2, true },
8607 { 0x41, "Channel Selected",
8608 channel_selected_evt, 1, true },
8609 { 0x42, "Disconnect Physical Link Complete",
8610 disconn_phy_link_complete_evt, 3, true },
8611 { 0x43, "Physical Link Loss Early Warning",
8612 phy_link_loss_early_warning_evt, 2, true },
8613 { 0x44, "Physical Link Recovery",
8614 phy_link_recovery_evt, 1, true },
8615 { 0x45, "Logical Link Complete",
8616 logic_link_complete_evt, 5, true },
8617 { 0x46, "Disconnect Logical Link Complete",
8618 disconn_logic_link_complete_evt, 4, true },
8619 { 0x47, "Flow Specification Modify Complete",
8620 flow_spec_modify_complete_evt, 3, true },
8621 { 0x48, "Number of Completed Data Blocks",
8622 num_completed_data_blocks_evt, 3, false },
8623 { 0x49, "AMP Start Test" },
8624 { 0x4a, "AMP Test End" },
8625 { 0x4b, "AMP Receiver Report" },
8626 { 0x4c, "Short Range Mode Change Complete",
8627 short_range_mode_change_evt, 3, true },
8628 { 0x4d, "AMP Status Change",
8629 amp_status_change_evt, 2, true },
8630 { 0x4e, "Triggered Clock Capture",
8631 triggered_clock_capture_evt, 9, true },
8632 { 0x4f, "Synchronization Train Complete",
8633 sync_train_complete_evt, 1, true },
8634 { 0x50, "Synchronization Train Received",
8635 sync_train_received_evt, 29, true },
8636 { 0x51, "Connectionless Slave Broadcast Receive",
8637 slave_broadcast_receive_evt, 18, false },
8638 { 0x52, "Connectionless Slave Broadcast Timeout",
8639 slave_broadcast_timeout_evt, 7, true },
8640 { 0x53, "Truncated Page Complete",
8641 truncated_page_complete_evt, 7, true },
8642 { 0x54, "Slave Page Response Timeout",
8643 slave_page_response_timeout_evt, 0, true },
8644 { 0x55, "Connectionless Slave Broadcast Channel Map Change",
8645 slave_broadcast_channel_map_change_evt, 10, true },
8646 { 0x56, "Inquiry Response Notification",
8647 inquiry_response_notify_evt, 4, true },
8648 { 0x57, "Authenticated Payload Timeout Expired",
8649 auth_payload_timeout_expired_evt, 2, true },
8650 { 0xfe, "Testing" },
8651 { 0xff, "Vendor", vendor_evt, 0, false },
8655 void packet_new_index(struct timeval *tv, uint16_t index, const char *label,
8656 uint8_t type, uint8_t bus, const char *name)
8660 sprintf(details, "(%s,%s,%s)", hci_typetostr(type),
8661 hci_bustostr(bus), name);
8663 print_packet(tv, NULL, index, '=', COLOR_NEW_INDEX, "New Index",
8667 void packet_del_index(struct timeval *tv, uint16_t index, const char *label)
8669 print_packet(tv, NULL, index, '=', COLOR_DEL_INDEX, "Delete Index",
8673 void packet_open_index(struct timeval *tv, uint16_t index, const char *label)
8675 print_packet(tv, NULL, index, '=', COLOR_OPEN_INDEX, "Open Index",
8679 void packet_close_index(struct timeval *tv, uint16_t index, const char *label)
8681 print_packet(tv, NULL, index, '=', COLOR_CLOSE_INDEX, "Close Index",
8685 void packet_index_info(struct timeval *tv, uint16_t index, const char *label,
8686 uint16_t manufacturer)
8690 sprintf(details, "(%s)", bt_compidtostr(manufacturer));
8692 print_packet(tv, NULL, index, '=', COLOR_INDEX_INFO, "Index Info",
8696 void packet_vendor_diag(struct timeval *tv, uint16_t index,
8697 uint16_t manufacturer,
8698 const void *data, uint16_t size)
8702 sprintf(extra_str, "(len %d)", size);
8704 print_packet(tv, NULL, index, '=', COLOR_VENDOR_DIAG,
8705 "Vendor Diagnostic", NULL, extra_str);
8707 switch (manufacturer) {
8709 broadcom_lm_diag(data, size);
8712 packet_hexdump(data, size);
8717 void packet_system_note(struct timeval *tv, struct ucred *cred,
8718 uint16_t index, const void *message)
8720 print_packet(tv, cred, index, '=', COLOR_INFO, "Note", message, NULL);
8723 void packet_user_logging(struct timeval *tv, struct ucred *cred,
8724 uint16_t index, uint8_t priority,
8725 const char *ident, const char *message)
8731 if (priority > priority_level)
8735 case BTSNOOP_PRIORITY_ERR:
8736 color = COLOR_ERROR;
8738 case BTSNOOP_PRIORITY_WARNING:
8741 case BTSNOOP_PRIORITY_INFO:
8744 case BTSNOOP_PRIORITY_DEBUG:
8745 color = COLOR_DEBUG;
8748 color = COLOR_WHITE_BG;
8753 char *path = alloca(24);
8757 snprintf(path, 23, "/proc/%u/comm", cred->pid);
8759 fp = fopen(path, "re");
8761 if (fgets(line, sizeof(line), fp)) {
8762 line[strcspn(line, "\r\n")] = '\0';
8763 snprintf(pid_str, sizeof(pid_str), "%s[%u]",
8766 snprintf(pid_str, sizeof(pid_str), "%u",
8770 snprintf(pid_str, sizeof(pid_str), "%u", cred->pid);
8780 print_packet(tv, cred, index, '=', color, label, message, NULL);
8783 void packet_hci_command(struct timeval *tv, struct ucred *cred, uint16_t index,
8784 const void *data, uint16_t size)
8786 const hci_command_hdr *hdr = data;
8787 uint16_t opcode = le16_to_cpu(hdr->opcode);
8788 uint16_t ogf = cmd_opcode_ogf(opcode);
8789 uint16_t ocf = cmd_opcode_ocf(opcode);
8790 struct opcode_data vendor_data;
8791 const struct opcode_data *opcode_data = NULL;
8792 const char *opcode_color, *opcode_str;
8793 char extra_str[25], vendor_str[150];
8796 if (size < HCI_COMMAND_HDR_SIZE) {
8797 sprintf(extra_str, "(len %d)", size);
8798 print_packet(tv, cred, index, '*', COLOR_ERROR,
8799 "Malformed HCI Command packet", NULL, extra_str);
8800 packet_hexdump(data, size);
8804 data += HCI_COMMAND_HDR_SIZE;
8805 size -= HCI_COMMAND_HDR_SIZE;
8807 for (i = 0; opcode_table[i].str; i++) {
8808 if (opcode_table[i].opcode == opcode) {
8809 opcode_data = &opcode_table[i];
8815 if (opcode_data->cmd_func)
8816 opcode_color = COLOR_HCI_COMMAND;
8818 opcode_color = COLOR_HCI_COMMAND_UNKNOWN;
8819 opcode_str = opcode_data->str;
8822 const struct vendor_ocf *vnd = current_vendor_ocf(ocf);
8825 const char *str = current_vendor_str();
8828 snprintf(vendor_str, sizeof(vendor_str),
8829 "%s %s", str, vnd->str);
8830 vendor_data.str = vendor_str;
8832 vendor_data.str = vnd->str;
8833 vendor_data.cmd_func = vnd->cmd_func;
8834 vendor_data.cmd_size = vnd->cmd_size;
8835 vendor_data.cmd_fixed = vnd->cmd_fixed;
8837 opcode_data = &vendor_data;
8839 if (opcode_data->cmd_func)
8840 opcode_color = COLOR_HCI_COMMAND;
8842 opcode_color = COLOR_HCI_COMMAND_UNKNOWN;
8843 opcode_str = opcode_data->str;
8845 opcode_color = COLOR_HCI_COMMAND;
8846 opcode_str = "Vendor";
8849 opcode_color = COLOR_HCI_COMMAND_UNKNOWN;
8850 opcode_str = "Unknown";
8854 sprintf(extra_str, "(0x%2.2x|0x%4.4x) plen %d", ogf, ocf, hdr->plen);
8856 print_packet(tv, cred, index, '<', opcode_color, "HCI Command",
8857 opcode_str, extra_str);
8859 if (!opcode_data || !opcode_data->cmd_func) {
8860 packet_hexdump(data, size);
8864 if (size != hdr->plen) {
8865 print_text(COLOR_ERROR, "invalid packet size (%u != %u)", size,
8867 packet_hexdump(data, size);
8871 if (opcode_data->cmd_fixed) {
8872 if (hdr->plen != opcode_data->cmd_size) {
8873 print_text(COLOR_ERROR, "invalid packet size");
8874 packet_hexdump(data, size);
8878 if (hdr->plen < opcode_data->cmd_size) {
8879 print_text(COLOR_ERROR, "too short packet");
8880 packet_hexdump(data, size);
8885 opcode_data->cmd_func(data, hdr->plen);
8888 void packet_hci_event(struct timeval *tv, struct ucred *cred, uint16_t index,
8889 const void *data, uint16_t size)
8891 const hci_event_hdr *hdr = data;
8892 const struct event_data *event_data = NULL;
8893 const char *event_color, *event_str;
8897 if (size < HCI_EVENT_HDR_SIZE) {
8898 sprintf(extra_str, "(len %d)", size);
8899 print_packet(tv, cred, index, '*', COLOR_ERROR,
8900 "Malformed HCI Event packet", NULL, extra_str);
8901 packet_hexdump(data, size);
8905 data += HCI_EVENT_HDR_SIZE;
8906 size -= HCI_EVENT_HDR_SIZE;
8908 for (i = 0; event_table[i].str; i++) {
8909 if (event_table[i].event == hdr->evt) {
8910 event_data = &event_table[i];
8916 if (event_data->func)
8917 event_color = COLOR_HCI_EVENT;
8919 event_color = COLOR_HCI_EVENT_UNKNOWN;
8920 event_str = event_data->str;
8922 event_color = COLOR_HCI_EVENT_UNKNOWN;
8923 event_str = "Unknown";
8926 sprintf(extra_str, "(0x%2.2x) plen %d", hdr->evt, hdr->plen);
8928 print_packet(tv, cred, index, '>', event_color, "HCI Event",
8929 event_str, extra_str);
8931 if (!event_data || !event_data->func) {
8932 packet_hexdump(data, size);
8936 if (size != hdr->plen) {
8937 print_text(COLOR_ERROR, "invalid packet size (%u != %u)", size,
8939 packet_hexdump(data, size);
8943 if (event_data->fixed) {
8944 if (hdr->plen != event_data->size) {
8945 print_text(COLOR_ERROR, "invalid packet size");
8946 packet_hexdump(data, size);
8950 if (hdr->plen < event_data->size) {
8951 print_text(COLOR_ERROR, "too short packet");
8952 packet_hexdump(data, size);
8957 event_data->func(data, hdr->plen);
8960 void packet_hci_acldata(struct timeval *tv, struct ucred *cred, uint16_t index,
8961 bool in, const void *data, uint16_t size)
8963 const struct bt_hci_acl_hdr *hdr = data;
8964 uint16_t handle = le16_to_cpu(hdr->handle);
8965 uint16_t dlen = le16_to_cpu(hdr->dlen);
8966 uint8_t flags = acl_flags(handle);
8967 char handle_str[16], extra_str[32];
8969 if (size < sizeof(*hdr)) {
8971 print_packet(tv, cred, index, '*', COLOR_ERROR,
8972 "Malformed ACL Data RX packet", NULL, NULL);
8974 print_packet(tv, cred, index, '*', COLOR_ERROR,
8975 "Malformed ACL Data TX packet", NULL, NULL);
8976 packet_hexdump(data, size);
8980 data += sizeof(*hdr);
8981 size -= sizeof(*hdr);
8983 sprintf(handle_str, "Handle %d", acl_handle(handle));
8984 sprintf(extra_str, "flags 0x%2.2x dlen %d", flags, dlen);
8986 print_packet(tv, cred, index, in ? '>' : '<', COLOR_HCI_ACLDATA,
8987 in ? "ACL Data RX" : "ACL Data TX",
8988 handle_str, extra_str);
8991 print_text(COLOR_ERROR, "invalid packet size (%d != %d)",
8993 packet_hexdump(data, size);
8997 if (filter_mask & PACKET_FILTER_SHOW_ACL_DATA)
8998 packet_hexdump(data, size);
9000 l2cap_packet(index, in, acl_handle(handle), flags, data, size);
9003 void packet_hci_scodata(struct timeval *tv, struct ucred *cred, uint16_t index,
9004 bool in, const void *data, uint16_t size)
9006 const hci_sco_hdr *hdr = data;
9007 uint16_t handle = le16_to_cpu(hdr->handle);
9008 uint8_t flags = acl_flags(handle);
9009 char handle_str[16], extra_str[32];
9011 if (size < HCI_SCO_HDR_SIZE) {
9013 print_packet(tv, cred, index, '*', COLOR_ERROR,
9014 "Malformed SCO Data RX packet", NULL, NULL);
9016 print_packet(tv, cred, index, '*', COLOR_ERROR,
9017 "Malformed SCO Data TX packet", NULL, NULL);
9018 packet_hexdump(data, size);
9022 data += HCI_SCO_HDR_SIZE;
9023 size -= HCI_SCO_HDR_SIZE;
9025 sprintf(handle_str, "Handle %d", acl_handle(handle));
9026 sprintf(extra_str, "flags 0x%2.2x dlen %d", flags, hdr->dlen);
9028 print_packet(tv, cred, index, in ? '>' : '<', COLOR_HCI_SCODATA,
9029 in ? "SCO Data RX" : "SCO Data TX",
9030 handle_str, extra_str);
9032 if (size != hdr->dlen) {
9033 print_text(COLOR_ERROR, "invalid packet size (%d != %d)",
9035 packet_hexdump(data, size);
9039 if (filter_mask & PACKET_FILTER_SHOW_SCO_DATA)
9040 packet_hexdump(data, size);
9043 void packet_todo(void)
9047 printf("HCI commands with missing decodings:\n");
9049 for (i = 0; opcode_table[i].str; i++) {
9050 if (opcode_table[i].bit < 0)
9053 if (opcode_table[i].cmd_func)
9056 printf("\t%s\n", opcode_table[i].str);
9059 printf("HCI events with missing decodings:\n");
9061 for (i = 0; event_table[i].str; i++) {
9062 if (event_table[i].func)
9065 printf("\t%s\n", event_table[i].str);
9068 for (i = 0; le_meta_event_table[i].str; i++) {
9069 if (le_meta_event_table[i].func)
9072 printf("\t%s\n", le_meta_event_table[i].str);