|  | /* hci_vs.h - Bluetooth Host Control Interface Vendor Specific definitions */ | 
|  |  | 
|  | /* | 
|  | * Copyright (c) 2015-2016 Intel Corporation | 
|  | * | 
|  | * SPDX-License-Identifier: Apache-2.0 | 
|  | */ | 
|  | #ifndef __BT_HCI_VS_H | 
|  | #define __BT_HCI_VS_H | 
|  |  | 
|  | #include <bluetooth/hci.h> | 
|  |  | 
|  | #ifdef __cplusplus | 
|  | extern "C" { | 
|  | #endif | 
|  |  | 
|  | #define BT_HCI_VS_HW_PLAT_INTEL                 0x0001 | 
|  | #define BT_HCI_VS_HW_PLAT_NORDIC                0x0002 | 
|  | #define BT_HCI_VS_HW_PLAT_NXP                   0x0003 | 
|  |  | 
|  | #define BT_HCI_VS_HW_VAR_NORDIC_NRF51X          0x0001 | 
|  | #define BT_HCI_VS_HW_VAR_NORDIC_NRF52X          0x0002 | 
|  |  | 
|  | #define BT_HCI_VS_FW_VAR_STANDARD_CTLR          0x0001 | 
|  | #define BT_HCI_VS_FW_VAR_VS_CTLR                0x0002 | 
|  | #define BT_HCI_VS_FW_VAR_FW_LOADER              0x0003 | 
|  | #define BT_HCI_VS_FW_VAR_RESCUE_IMG             0x0004 | 
|  | #define BT_HCI_OP_VS_READ_VERSION_INFO		BT_OP(BT_OGF_VS, 0x0001) | 
|  | struct bt_hci_rp_vs_read_version_info { | 
|  | u8_t  status; | 
|  | u16_t hw_platform; | 
|  | u16_t hw_variant; | 
|  | u8_t  fw_variant; | 
|  | u8_t  fw_version; | 
|  | u16_t fw_revision; | 
|  | u32_t fw_build; | 
|  | } __packed; | 
|  |  | 
|  | #define BT_HCI_OP_VS_READ_SUPPORTED_COMMANDS	BT_OP(BT_OGF_VS, 0x0002) | 
|  | struct bt_hci_rp_vs_read_supported_commands { | 
|  | u8_t  status; | 
|  | u8_t  commands[64]; | 
|  | } __packed; | 
|  |  | 
|  | #define BT_HCI_OP_VS_READ_SUPPORTED_FEATURES	BT_OP(BT_OGF_VS, 0x0003) | 
|  | struct bt_hci_rp_vs_read_supported_features { | 
|  | u8_t  status; | 
|  | u8_t  features[8]; | 
|  | } __packed; | 
|  |  | 
|  | #define BT_HCI_OP_VS_SET_EVENT_MASK             BT_OP(BT_OGF_VS, 0x0004) | 
|  | struct bt_hci_cp_vs_set_event_mask { | 
|  | u8_t  event_mask[8]; | 
|  | } __packed; | 
|  |  | 
|  | #define BT_HCI_VS_RESET_SOFT                    0x00 | 
|  | #define BT_HCI_VS_RESET_HARD                    0x01 | 
|  | #define BT_HCI_OP_VS_RESET                      BT_OP(BT_OGF_VS, 0x0005) | 
|  | struct bt_hci_cp_vs_reset { | 
|  | u8_t  type; | 
|  | } __packed; | 
|  |  | 
|  | #define BT_HCI_OP_VS_WRITE_BD_ADDR              BT_OP(BT_OGF_VS, 0x0006) | 
|  | struct bt_hci_cp_vs_write_bd_addr { | 
|  | bt_addr_t bdaddr; | 
|  | } __packed; | 
|  |  | 
|  | #define BT_HCI_VS_TRACE_DISABLED                0x00 | 
|  | #define BT_HCI_VS_TRACE_ENABLED                 0x01 | 
|  |  | 
|  | #define BT_HCI_VS_TRACE_HCI_EVTS                0x00 | 
|  | #define BT_HCI_VS_TRACE_VDC                     0x01 | 
|  | #define BT_HCI_OP_VS_SET_TRACE_ENABLE           BT_OP(BT_OGF_VS, 0x0007) | 
|  | struct bt_hci_cp_vs_set_trace_enable { | 
|  | u8_t  enable; | 
|  | u8_t  type; | 
|  | } __packed; | 
|  |  | 
|  | #define BT_HCI_OP_VS_READ_BUILD_INFO            BT_OP(BT_OGF_VS, 0x0008) | 
|  | struct bt_hci_rp_vs_read_build_info { | 
|  | u8_t  status; | 
|  | u8_t  info[0]; | 
|  | } __packed; | 
|  |  | 
|  | struct bt_hci_vs_static_addr { | 
|  | bt_addr_t bdaddr; | 
|  | u8_t      ir[16]; | 
|  | } __packed; | 
|  |  | 
|  | #define BT_HCI_OP_VS_READ_STATIC_ADDRS          BT_OP(BT_OGF_VS, 0x0009) | 
|  | struct bt_hci_rp_vs_read_static_addrs { | 
|  | u8_t   status; | 
|  | u8_t   num_addrs; | 
|  | struct bt_hci_vs_static_addr a[0]; | 
|  | } __packed; | 
|  |  | 
|  | #define BT_HCI_OP_VS_READ_KEY_HIERARCHY_ROOTS   BT_OP(BT_OGF_VS, 0x000a) | 
|  | struct bt_hci_rp_vs_read_key_hierarchy_roots { | 
|  | u8_t  status; | 
|  | u8_t  ir[16]; | 
|  | u8_t  er[16]; | 
|  | } __packed; | 
|  |  | 
|  | #define BT_HCI_OP_VS_READ_CHIP_TEMP             BT_OP(BT_OGF_VS, 0x000b) | 
|  | struct bt_hci_rp_vs_read_chip_temp { | 
|  | u8_t  status; | 
|  | s8_t  temps; | 
|  | } __packed; | 
|  |  | 
|  | struct bt_hci_vs_cmd { | 
|  | u16_t vendor_id; | 
|  | u16_t opcode_base; | 
|  | } __packed; | 
|  |  | 
|  | #define BT_HCI_VS_VID_ANDROID                   0x0001 | 
|  | #define BT_HCI_VS_VID_MICROSOFT                 0x0002 | 
|  | #define BT_HCI_OP_VS_READ_HOST_STACK_CMDS       BT_OP(BT_OGF_VS, 0x000c) | 
|  | struct bt_hci_rp_vs_read_host_stack_cmds { | 
|  | u8_t   status; | 
|  | u8_t   num_cmds; | 
|  | struct bt_hci_vs_cmd c[0]; | 
|  | } __packed; | 
|  |  | 
|  | #define BT_HCI_VS_SCAN_REQ_REPORTS_DISABLED     0x00 | 
|  | #define BT_HCI_VS_SCAN_REQ_REPORTS_ENABLED      0x01 | 
|  | #define BT_HCI_OP_VS_SET_SCAN_REQ_REPORTS       BT_OP(BT_OGF_VS, 0x000d) | 
|  | struct bt_hci_cp_vs_set_scan_req_reports { | 
|  | u8_t  enable; | 
|  | } __packed; | 
|  |  | 
|  | /* Events */ | 
|  |  | 
|  | struct bt_hci_evt_vs { | 
|  | u8_t  subevent; | 
|  | } __packed; | 
|  |  | 
|  | #define BT_HCI_EVT_VS_FATAL_ERROR              0x02 | 
|  | struct bt_hci_evt_vs_fatal_error { | 
|  | u64_t pc; | 
|  | u8_t  err_info[0]; | 
|  | } __packed; | 
|  |  | 
|  | #define BT_HCI_VS_TRACE_LMP_TX                 0x01 | 
|  | #define BT_HCI_VS_TRACE_LMP_RX                 0x02 | 
|  | #define BT_HCI_VS_TRACE_LLCP_TX                0x03 | 
|  | #define BT_HCI_VS_TRACE_LLCP_RX                0x04 | 
|  | #define BT_HCI_VS_TRACE_LE_CONN_IND            0x05 | 
|  | #define BT_HCI_EVT_VS_TRACE_INFO               0x03 | 
|  | struct bt_hci_evt_vs_trace_info { | 
|  | u8_t  type; | 
|  | u8_t  data[0]; | 
|  | } __packed; | 
|  |  | 
|  | #define BT_HCI_EVT_VS_SCAN_REQ_RX              0x04 | 
|  | struct bt_hci_evt_vs_scan_req_rx { | 
|  | bt_addr_le_t addr; | 
|  | s8_t         rssi; | 
|  | } __packed; | 
|  |  | 
|  | /* Event mask bits */ | 
|  |  | 
|  | #define BT_EVT_MASK_VS_FATAL_ERROR             BT_EVT_BIT(1) | 
|  | #define BT_EVT_MASK_VS_TRACE_INFO              BT_EVT_BIT(2) | 
|  | #define BT_EVT_MASK_VS_SCAN_REQ_RX             BT_EVT_BIT(3) | 
|  |  | 
|  | #ifdef __cplusplus | 
|  | } | 
|  | #endif | 
|  |  | 
|  | #endif /* __BT_HCI_VS_H */ |