340 lines
8.6 KiB
C
340 lines
8.6 KiB
C
/* hci_vs.h - Bluetooth Host Control Interface Vendor Specific definitions */
|
|
|
|
/*
|
|
* Copyright (c) 2017-2018 Nordic Semiconductor ASA
|
|
* Copyright (c) 2015-2016 Intel Corporation
|
|
*
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
#ifndef ZEPHYR_INCLUDE_BLUETOOTH_HCI_VS_H_
|
|
#define ZEPHYR_INCLUDE_BLUETOOTH_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_HW_VAR_NORDIC_NRF53X 0x0003
|
|
|
|
#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;
|
|
|
|
#define BT_HCI_VS_LL_HANDLE_TYPE_ADV 0x00
|
|
#define BT_HCI_VS_LL_HANDLE_TYPE_SCAN 0x01
|
|
#define BT_HCI_VS_LL_HANDLE_TYPE_CONN 0x02
|
|
#define BT_HCI_VS_LL_TX_POWER_LEVEL_NO_PREF 0x7F
|
|
#define BT_HCI_OP_VS_WRITE_TX_POWER_LEVEL BT_OP(BT_OGF_VS, 0x000e)
|
|
struct bt_hci_cp_vs_write_tx_power_level {
|
|
u8_t handle_type;
|
|
u16_t handle;
|
|
s8_t tx_power_level;
|
|
} __packed;
|
|
|
|
struct bt_hci_rp_vs_write_tx_power_level {
|
|
u8_t status;
|
|
u8_t handle_type;
|
|
u16_t handle;
|
|
s8_t selected_tx_power;
|
|
} __packed;
|
|
|
|
#define BT_HCI_OP_VS_READ_TX_POWER_LEVEL BT_OP(BT_OGF_VS, 0x000f)
|
|
struct bt_hci_cp_vs_read_tx_power_level {
|
|
u8_t handle_type;
|
|
u16_t handle;
|
|
} __packed;
|
|
|
|
struct bt_hci_rp_vs_read_tx_power_level {
|
|
u8_t status;
|
|
u8_t handle_type;
|
|
u16_t handle;
|
|
s8_t tx_power_level;
|
|
} __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)
|
|
|
|
/* Mesh HCI commands */
|
|
#define BT_HCI_MESH_REVISION 0x01
|
|
|
|
#define BT_HCI_OP_VS_MESH BT_OP(BT_OGF_VS, 0x0042)
|
|
#define BT_HCI_MESH_EVT_PREFIX 0xF0
|
|
|
|
struct bt_hci_cp_mesh {
|
|
u8_t opcode;
|
|
} __packed;
|
|
|
|
#define BT_HCI_OC_MESH_GET_OPTS 0x00
|
|
struct bt_hci_rp_mesh_get_opts {
|
|
u8_t status;
|
|
u8_t opcode;
|
|
u8_t revision;
|
|
u8_t ch_map;
|
|
s8_t min_tx_power;
|
|
s8_t max_tx_power;
|
|
u8_t max_scan_filter;
|
|
u8_t max_filter_pattern;
|
|
u8_t max_adv_slot;
|
|
u8_t max_tx_window;
|
|
u8_t evt_prefix_len;
|
|
u8_t evt_prefix;
|
|
} __packed;
|
|
|
|
#define BT_HCI_MESH_PATTERN_LEN_MAX 0x0f
|
|
|
|
#define BT_HCI_OC_MESH_SET_SCAN_FILTER 0x01
|
|
struct bt_hci_mesh_pattern {
|
|
u8_t pattern_len;
|
|
u8_t pattern[0];
|
|
} __packed;
|
|
|
|
struct bt_hci_cp_mesh_set_scan_filter {
|
|
u8_t scan_filter;
|
|
u8_t filter_dup;
|
|
u8_t num_patterns;
|
|
struct bt_hci_mesh_pattern patterns[0];
|
|
} __packed;
|
|
struct bt_hci_rp_mesh_set_scan_filter {
|
|
u8_t status;
|
|
u8_t opcode;
|
|
u8_t scan_filter;
|
|
} __packed;
|
|
|
|
#define BT_HCI_OC_MESH_ADVERTISE 0x02
|
|
struct bt_hci_cp_mesh_advertise {
|
|
u8_t adv_slot;
|
|
u8_t own_addr_type;
|
|
bt_addr_t random_addr;
|
|
u8_t ch_map;
|
|
s8_t tx_power;
|
|
u8_t min_tx_delay;
|
|
u8_t max_tx_delay;
|
|
u8_t retx_count;
|
|
u8_t retx_interval;
|
|
u8_t scan_delay;
|
|
u16_t scan_duration;
|
|
u8_t scan_filter;
|
|
u8_t data_len;
|
|
u8_t data[31];
|
|
} __packed;
|
|
struct bt_hci_rp_mesh_advertise {
|
|
u8_t status;
|
|
u8_t opcode;
|
|
u8_t adv_slot;
|
|
} __packed;
|
|
|
|
#define BT_HCI_OC_MESH_ADVERTISE_TIMED 0x03
|
|
struct bt_hci_cp_mesh_advertise_timed {
|
|
u8_t adv_slot;
|
|
u8_t own_addr_type;
|
|
bt_addr_t random_addr;
|
|
u8_t ch_map;
|
|
s8_t tx_power;
|
|
u8_t retx_count;
|
|
u8_t retx_interval;
|
|
u32_t instant;
|
|
u16_t tx_delay;
|
|
u16_t tx_window;
|
|
u8_t data_len;
|
|
u8_t data[31];
|
|
} __packed;
|
|
struct bt_hci_rp_mesh_advertise_timed {
|
|
u8_t status;
|
|
u8_t opcode;
|
|
u8_t adv_slot;
|
|
} __packed;
|
|
|
|
#define BT_HCI_OC_MESH_ADVERTISE_CANCEL 0x04
|
|
struct bt_hci_cp_mesh_advertise_cancel {
|
|
u8_t adv_slot;
|
|
} __packed;
|
|
struct bt_hci_rp_mesh_advertise_cancel {
|
|
u8_t status;
|
|
u8_t opcode;
|
|
u8_t adv_slot;
|
|
} __packed;
|
|
|
|
#define BT_HCI_OC_MESH_SET_SCANNING 0x05
|
|
struct bt_hci_cp_mesh_set_scanning {
|
|
u8_t enable;
|
|
u8_t ch_map;
|
|
u8_t scan_filter;
|
|
} __packed;
|
|
struct bt_hci_rp_mesh_set_scanning {
|
|
u8_t status;
|
|
u8_t opcode;
|
|
} __packed;
|
|
|
|
/* Events */
|
|
struct bt_hci_evt_mesh {
|
|
u8_t prefix;
|
|
u8_t subevent;
|
|
} __packed;
|
|
|
|
#define BT_HCI_EVT_MESH_ADV_COMPLETE 0x00
|
|
struct bt_hci_evt_mesh_adv_complete {
|
|
u8_t adv_slot;
|
|
} __packed;
|
|
|
|
#define BT_HCI_EVT_MESH_SCANNING_REPORT 0x01
|
|
struct bt_hci_evt_mesh_scan_report {
|
|
bt_addr_le_t addr;
|
|
u8_t chan;
|
|
s8_t rssi;
|
|
u32_t instant;
|
|
u8_t data_len;
|
|
u8_t data[0];
|
|
} __packed;
|
|
struct bt_hci_evt_mesh_scanning_report {
|
|
u8_t num_reports;
|
|
struct bt_hci_evt_mesh_scan_report reports[0];
|
|
} __packed;
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* ZEPHYR_INCLUDE_BLUETOOTH_HCI_VS_H_ */
|