blob: 644c97c984ded255d9d9e5e2dde7f4574e52c0ce [file] [log] [blame]
/* SPDX-License-Identifier: LGPL-2.1-or-later */
/*
*
* BlueZ - Bluetooth protocol stack for Linux
*
* Copyright (C) 2011-2014 Intel Corporation
* Copyright (C) 2002-2010 Marcel Holtmann <marcel@holtmann.org>
*
*
*/
#include <stdint.h>
#define BT_HCI_CMD_BIT(_byte, _bit) ((8 * _byte) + _bit)
struct bt_ll_hdr {
uint8_t preamble;
uint32_t access_addr;
} __attribute__ ((packed));
#define BT_LL_CONN_UPDATE_REQ 0x00
struct bt_ll_conn_update_req {
uint8_t win_size;
uint16_t win_offset;
uint16_t interval;
uint16_t latency;
uint16_t timeout;
uint16_t instant;
} __attribute__ ((packed));
#define BT_LL_CHANNEL_MAP_REQ 0x01
struct bt_ll_channel_map_req {
uint8_t map[5];
uint16_t instant;
} __attribute__ ((packed));
#define BT_LL_TERMINATE_IND 0x02
struct bt_ll_terminate_ind {
uint8_t error;
} __attribute__ ((packed));
#define BT_LL_ENC_REQ 0x03
struct bt_ll_enc_req {
uint64_t rand;
uint16_t ediv;
uint64_t skd;
uint32_t iv;
} __attribute__ ((packed));
#define BT_LL_ENC_RSP 0x04
struct bt_ll_enc_rsp {
uint64_t skd;
uint32_t iv;
} __attribute__ ((packed));
#define BT_LL_START_ENC_REQ 0x05
#define BT_LL_START_ENC_RSP 0x06
#define BT_LL_UNKNOWN_RSP 0x07
struct bt_ll_unknown_rsp {
uint8_t type;
} __attribute__ ((packed));
#define BT_LL_FEATURE_REQ 0x08
struct bt_ll_feature_req {
uint8_t features[8];
} __attribute__ ((packed));
#define BT_LL_FEATURE_RSP 0x09
struct bt_ll_feature_rsp {
uint8_t features[8];
} __attribute__ ((packed));
#define BT_LL_PAUSE_ENC_REQ 0x0a
#define BT_LL_PAUSE_ENC_RSP 0x0b
#define BT_LL_VERSION_IND 0x0c
struct bt_ll_version_ind {
uint8_t version;
uint16_t company;
uint16_t subversion;
} __attribute__ ((packed));
#define BT_LL_REJECT_IND 0x0d
struct bt_ll_reject_ind {
uint8_t error;
} __attribute__ ((packed));
#define BT_LL_PERIPHERAL_FEATURE_REQ 0x0e
struct bt_ll_peripheral_feature_req {
uint8_t features[8];
} __attribute__ ((packed));
#define BT_LL_CONN_PARAM_REQ 0x0f
#define BT_LL_CONN_PARAM_RSP 0x10
#define BT_LL_REJECT_IND_EXT 0x11
struct bt_ll_reject_ind_ext {
uint8_t opcode;
uint8_t error;
} __attribute__ ((packed));
#define BT_LL_PING_REQ 0x12
#define BT_LL_PING_RSP 0x13
#define BT_LL_LENGTH_REQ 0x14
struct bt_ll_length {
uint16_t rx_len;
uint16_t rx_time;
uint16_t tx_len;
uint16_t tx_time;
} __attribute__ ((packed));
#define BT_LL_LENGTH_RSP 0x15
#define BT_LL_PHY_REQ 0x16
struct bt_ll_phy {
uint8_t tx_phys;
uint8_t rx_phys;
} __attribute__ ((packed));
#define BT_LL_PHY_RSP 0x17
#define BT_LL_PHY_UPDATE_IND 0x18
struct bt_ll_phy_update_ind {
uint8_t c_phy;
uint8_t p_phy;
uint16_t instant;
} __attribute__ ((packed));
#define BT_LL_MIN_USED_CHANNELS 0x19
struct bt_ll_min_used_channels {
uint8_t phys;
uint8_t min_channels;
} __attribute__ ((packed));
#define BT_LL_CTE_REQ 0x1a
struct bt_ll_cte_req {
uint8_t cte;
} __attribute__ ((packed));
#define BT_LL_CTE_RSP 0x1b
#define BT_LL_PERIODIC_SYNC_IND 0x1c
struct bt_ll_periodic_sync_ind {
uint16_t id;
uint8_t info[18];
uint16_t event_count;
uint16_t last_counter;
uint8_t adv_info;
uint8_t phy;
uint8_t adv_addr[6];
uint16_t sync_counter;
} __attribute__ ((packed));
#define BT_LL_CLOCK_ACCURACY_REQ 0x1d
struct bt_ll_clock_acc {
uint8_t sca;
} __attribute__ ((packed));
#define BT_LL_CLOCK_ACCURACY_RSP 0x1e
#define BT_LL_CIS_REQ 0x1f
struct bt_ll_cis_req {
uint8_t cig;
uint8_t cis;
uint8_t c_phy;
uint8_t p_phy;
uint16_t c_sdu;
uint16_t p_sdu;
uint8_t c_interval[3];
uint8_t p_interval[3];
uint8_t c_pdu;
uint8_t p_pdu;
uint8_t nse;
uint8_t sub_interval[3];
uint8_t bn;
uint8_t c_ft;
uint8_t p_ft;
uint16_t iso_interval;
uint8_t offset_min[3];
uint8_t offset_max[3];
uint16_t conn_event_count;
} __attribute__ ((packed));
#define BT_LL_CIS_RSP 0x20
struct bt_ll_cis_rsp {
uint8_t offset_min[3];
uint8_t offset_max[3];
uint16_t conn_event_count;
} __attribute__ ((packed));
#define BT_LL_CIS_IND 0x21
struct bt_ll_cis_ind {
uint32_t addr;
uint8_t cis_offset[3];
uint8_t cig_sync_delay[3];
uint8_t cis_sync_delay[3];
uint16_t conn_event_count;
} __attribute__ ((packed));
#define BT_LL_CIS_TERMINATE_IND 0x22
struct bt_ll_cis_term_ind {
uint8_t cig;
uint8_t cis;
uint8_t reason;
} __attribute__ ((packed));
#define LMP_ESC4(x) ((127 << 8) | (x))
#define BT_LMP_NAME_REQ 1
struct bt_lmp_name_req {
uint8_t offset;
} __attribute__ ((packed));
#define BT_LMP_NAME_RSP 2
struct bt_lmp_name_rsp {
uint8_t offset;
uint8_t length;
uint8_t fragment[14];
} __attribute__ ((packed));
#define BT_LMP_ACCEPTED 3
struct bt_lmp_accepted {
uint8_t opcode;
} __attribute__ ((packed));
#define BT_LMP_NOT_ACCEPTED 4
struct bt_lmp_not_accepted {
uint8_t opcode;
uint8_t error;
} __attribute__ ((packed));
#define BT_LMP_CLKOFFSET_REQ 5
#define BT_LMP_CLKOFFSET_RSP 6
struct bt_lmp_clkoffset_rsp {
uint16_t offset;
} __attribute__ ((packed));
#define BT_LMP_DETACH 7
struct bt_lmp_detach {
uint8_t error;
} __attribute__ ((packed));
#define BT_LMP_AU_RAND 11
struct bt_lmp_au_rand {
uint8_t number[16];
} __attribute__ ((packed));
#define BT_LMP_SRES 12
struct bt_lmp_sres {
uint8_t response[4];
} __attribute__ ((packed));
#define BT_LMP_ENCRYPTION_MODE_REQ 15
struct bt_lmp_encryption_mode_req {
uint8_t mode;
} __attribute__ ((packed));
#define BT_LMP_ENCRYPTION_KEY_SIZE_REQ 16
struct bt_lmp_encryption_key_size_req {
uint8_t key_size;
} __attribute__ ((packed));
#define BT_LMP_START_ENCRYPTION_REQ 17
struct bt_lmp_start_encryption_req {
uint8_t number[16];
} __attribute__ ((packed));
#define BT_LMP_STOP_ENCRYPTION_REQ 18
#define BT_LMP_SWITCH_REQ 19
struct bt_lmp_switch_req {
uint32_t instant;
} __attribute__ ((packed));
#define BT_LMP_UNSNIFF_REQ 24
#define BT_LMP_MAX_POWER 33
#define BT_LMP_MIN_POWER 34
#define BT_LMP_AUTO_RATE 35
#define BT_LMP_PREFERRED_RATE 36
struct bt_lmp_preferred_rate {
uint8_t rate;
} __attribute__ ((packed));
#define BT_LMP_VERSION_REQ 37
struct bt_lmp_version_req {
uint8_t version;
uint16_t company;
uint16_t subversion;
} __attribute__ ((packed));
#define BT_LMP_VERSION_RES 38
struct bt_lmp_version_res {
uint8_t version;
uint16_t company;
uint16_t subversion;
} __attribute__ ((packed));
#define BT_LMP_FEATURES_REQ 39
struct bt_lmp_features_req {
uint8_t features[8];
} __attribute__ ((packed));
#define BT_LMP_FEATURES_RES 40
struct bt_lmp_features_res {
uint8_t features[8];
} __attribute__ ((packed));
#define BT_LMP_MAX_SLOT 45
struct bt_lmp_max_slot {
uint8_t slots;
} __attribute__ ((packed));
#define BT_LMP_MAX_SLOT_REQ 46
struct bt_lmp_max_slot_req {
uint8_t slots;
} __attribute__ ((packed));
#define BT_LMP_TIMING_ACCURACY_REQ 47
#define BT_LMP_TIMING_ACCURACY_RES 48
struct bt_lmp_timing_accuracy_res {
uint8_t drift;
uint8_t jitter;
} __attribute__ ((packed));
#define BT_LMP_SETUP_COMPLETE 49
#define BT_LMP_USE_SEMI_PERMANENT_KEY 50
#define BT_LMP_HOST_CONNECTION_REQ 51
#define BT_LMP_SLOT_OFFSET 52
struct bt_lmp_slot_offset {
uint16_t offset;
uint8_t bdaddr[6];
} __attribute__ ((packed));
#define BT_LMP_PAGE_SCAN_MODE_REQ 54
struct bt_lmp_page_scan_mode_req {
uint8_t scheme;
uint8_t settings;
} __attribute__ ((packed));
#define BT_LMP_TEST_ACTIVATE 56
#define BT_LMP_ENCRYPTION_KEY_SIZE_MASK_REQ 58
#define BT_LMP_SET_AFH 60
struct bt_lmp_set_afh {
uint32_t instant;
uint8_t mode;
uint8_t map[10];
} __attribute__ ((packed));
#define BT_LMP_ENCAPSULATED_HEADER 61
struct bt_lmp_encapsulated_header {
uint8_t major;
uint8_t minor;
uint8_t length;
} __attribute__ ((packed));
#define BT_LMP_ENCAPSULATED_PAYLOAD 62
struct bt_lmp_encapsulated_payload {
uint8_t data[16];
} __attribute__ ((packed));
#define BT_LMP_SIMPLE_PAIRING_CONFIRM 63
struct bt_lmp_simple_pairing_confirm {
uint8_t value[16];
} __attribute__ ((packed));
#define BT_LMP_SIMPLE_PAIRING_NUMBER 64
struct bt_lmp_simple_pairing_number {
uint8_t value[16];
} __attribute__ ((packed));
#define BT_LMP_DHKEY_CHECK 65
struct bt_lmp_dhkey_check {
uint8_t value[16];
} __attribute__ ((packed));
#define BT_LMP_PAUSE_ENCRYPTION_AES_REQ 66
#define BT_LMP_ACCEPTED_EXT LMP_ESC4(1)
struct bt_lmp_accepted_ext {
uint8_t escape;
uint8_t opcode;
} __attribute__ ((packed));
#define BT_LMP_NOT_ACCEPTED_EXT LMP_ESC4(2)
struct bt_lmp_not_accepted_ext {
uint8_t escape;
uint8_t opcode;
uint8_t error;
} __attribute__ ((packed));
#define BT_LMP_FEATURES_REQ_EXT LMP_ESC4(3)
struct bt_lmp_features_req_ext {
uint8_t page;
uint8_t max_page;
uint8_t features[8];
} __attribute__ ((packed));
#define BT_LMP_FEATURES_RES_EXT LMP_ESC4(4)
struct bt_lmp_features_res_ext {
uint8_t page;
uint8_t max_page;
uint8_t features[8];
} __attribute__ ((packed));
#define BT_LMP_PACKET_TYPE_TABLE_REQ LMP_ESC4(11)
struct bt_lmp_packet_type_table_req {
uint8_t table;
} __attribute__ ((packed));
#define BT_LMP_CHANNEL_CLASSIFICATION_REQ LMP_ESC4(16)
struct bt_lmp_channel_classification_req {
uint8_t mode;
uint16_t min_interval;
uint16_t max_interval;
} __attribute__ ((packed));
#define BT_LMP_CHANNEL_CLASSIFICATION LMP_ESC4(17)
struct bt_lmp_channel_classification {
uint8_t classification[10];
} __attribute__ ((packed));
#define BT_LMP_PAUSE_ENCRYPTION_REQ LMP_ESC4(23)
#define BT_LMP_RESUME_ENCRYPTION_REQ LMP_ESC4(24)
#define BT_LMP_IO_CAPABILITY_REQ LMP_ESC4(25)
struct bt_lmp_io_capability_req {
uint8_t capability;
uint8_t oob_data;
uint8_t authentication;
} __attribute__ ((packed));
#define BT_LMP_IO_CAPABILITY_RES LMP_ESC4(26)
struct bt_lmp_io_capability_res {
uint8_t capability;
uint8_t oob_data;
uint8_t authentication;
} __attribute__ ((packed));
#define BT_LMP_NUMERIC_COMPARISON_FAILED LMP_ESC(27)
#define BT_LMP_PASSKEY_FAILED LMP_ESC4(28)
#define BT_LMP_OOB_FAILED LMP_ESC(29)
#define BT_LMP_POWER_CONTROL_REQ LMP_ESC4(31)
struct bt_lmp_power_control_req {
uint8_t request;
} __attribute__ ((packed));
#define BT_LMP_POWER_CONTROL_RES LMP_ESC4(32)
struct bt_lmp_power_control_res {
uint8_t response;
} __attribute__ ((packed));
#define BT_LMP_PING_REQ LMP_ESC4(33)
#define BT_LMP_PING_RES LMP_ESC4(34)
#define BT_H4_CMD_PKT 0x01
#define BT_H4_ACL_PKT 0x02
#define BT_H4_SCO_PKT 0x03
#define BT_H4_EVT_PKT 0x04
#define BT_H4_ISO_PKT 0x05
struct bt_hci_cmd_hdr {
uint16_t opcode;
uint8_t plen;
} __attribute__ ((packed));
struct bt_hci_acl_hdr {
uint16_t handle;
uint16_t dlen;
uint8_t data[];
} __attribute__ ((packed));
struct bt_hci_sco_hdr {
uint16_t handle;
uint8_t dlen;
} __attribute__ ((packed));
struct bt_hci_iso_hdr {
uint16_t handle;
uint16_t dlen;
uint8_t data[];
} __attribute__ ((packed));
struct bt_hci_iso_data_start {
uint16_t sn;
uint16_t slen;
uint8_t data[];
} __attribute__ ((packed));
struct bt_hci_evt_hdr {
uint8_t evt;
uint8_t plen;
} __attribute__ ((packed));
#define BT_HCI_CMD_NOP 0x0000
#define BT_HCI_CMD_INQUIRY 0x0401
struct bt_hci_cmd_inquiry {
uint8_t lap[3];
uint8_t length;
uint8_t num_resp;
} __attribute__ ((packed));
#define BT_HCI_CMD_INQUIRY_CANCEL 0x0402
#define BT_HCI_CMD_PERIODIC_INQUIRY 0x0403
struct bt_hci_cmd_periodic_inquiry {
uint16_t max_period;
uint16_t min_period;
uint8_t lap[3];
uint8_t length;
uint8_t num_resp;
} __attribute__ ((packed));
#define BT_HCI_CMD_EXIT_PERIODIC_INQUIRY 0x0404
#define BT_HCI_CMD_CREATE_CONN 0x0405
struct bt_hci_cmd_create_conn {
uint8_t bdaddr[6];
uint16_t pkt_type;
uint8_t pscan_rep_mode;
uint8_t pscan_mode;
uint16_t clock_offset;
uint8_t role_switch;
} __attribute__ ((packed));
#define BT_HCI_CMD_DISCONNECT 0x0406
struct bt_hci_cmd_disconnect {
uint16_t handle;
uint8_t reason;
} __attribute__ ((packed));
#define BT_HCI_CMD_ADD_SCO_CONN 0x0407
struct bt_hci_cmd_add_sco_conn {
uint16_t handle;
uint16_t pkt_type;
} __attribute__ ((packed));
#define BT_HCI_CMD_CREATE_CONN_CANCEL 0x0408
struct bt_hci_cmd_create_conn_cancel {
uint8_t bdaddr[6];
} __attribute__ ((packed));
#define BT_HCI_CMD_ACCEPT_CONN_REQUEST 0x0409
struct bt_hci_cmd_accept_conn_request {
uint8_t bdaddr[6];
uint8_t role;
} __attribute__ ((packed));
#define BT_HCI_CMD_REJECT_CONN_REQUEST 0x040a
struct bt_hci_cmd_reject_conn_request {
uint8_t bdaddr[6];
uint8_t reason;
} __attribute__ ((packed));
#define BT_HCI_CMD_LINK_KEY_REQUEST_REPLY 0x040b
struct bt_hci_cmd_link_key_request_reply {
uint8_t bdaddr[6];
uint8_t link_key[16];
} __attribute__ ((packed));
struct bt_hci_rsp_link_key_request_reply {
uint8_t status;
uint8_t bdaddr[6];
} __attribute__ ((packed));
#define BT_HCI_CMD_LINK_KEY_REQUEST_NEG_REPLY 0x040c
struct bt_hci_cmd_link_key_request_neg_reply {
uint8_t bdaddr[6];
} __attribute__ ((packed));
struct bt_hci_rsp_link_key_request_neg_reply {
uint8_t status;
uint8_t bdaddr[6];
} __attribute__ ((packed));
#define BT_HCI_CMD_PIN_CODE_REQUEST_REPLY 0x040d
struct bt_hci_cmd_pin_code_request_reply {
uint8_t bdaddr[6];
uint8_t pin_len;
uint8_t pin_code[16];
} __attribute__ ((packed));
#define BT_HCI_CMD_PIN_CODE_REQUEST_NEG_REPLY 0x040e
struct bt_hci_cmd_pin_code_request_neg_reply {
uint8_t bdaddr[6];
} __attribute__ ((packed));
struct bt_hci_rsp_pin_code_request_neg_reply {
uint8_t status;
uint8_t bdaddr[6];
} __attribute__ ((packed));
#define BT_HCI_CMD_CHANGE_CONN_PKT_TYPE 0x040f
struct bt_hci_cmd_change_conn_pkt_type {
uint16_t handle;
uint16_t pkt_type;
} __attribute__ ((packed));
#define BT_HCI_CMD_AUTH_REQUESTED 0x0411
struct bt_hci_cmd_auth_requested {
uint16_t handle;
} __attribute__ ((packed));
#define BT_HCI_CMD_SET_CONN_ENCRYPT 0x0413
struct bt_hci_cmd_set_conn_encrypt {
uint16_t handle;
uint8_t encr_mode;
} __attribute__ ((packed));
#define BT_HCI_CMD_CHANGE_CONN_LINK_KEY 0x0415
struct bt_hci_cmd_change_conn_link_key {
uint16_t handle;
} __attribute__ ((packed));
#define BT_HCI_CMD_LINK_KEY_SELECTION 0x0417
struct bt_hci_cmd_link_key_selection {
uint8_t key_flag;
} __attribute__ ((packed));
#define BT_HCI_CMD_REMOTE_NAME_REQUEST 0x0419
struct bt_hci_cmd_remote_name_request {
uint8_t bdaddr[6];
uint8_t pscan_rep_mode;
uint8_t pscan_mode;
uint16_t clock_offset;
} __attribute__ ((packed));
#define BT_HCI_CMD_REMOTE_NAME_REQUEST_CANCEL 0x041a
struct bt_hci_cmd_remote_name_request_cancel {
uint8_t bdaddr[6];
} __attribute__ ((packed));
struct bt_hci_rsp_remote_name_request_cancel {
uint8_t status;
uint8_t bdaddr[6];
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_REMOTE_FEATURES 0x041b
struct bt_hci_cmd_read_remote_features {
uint16_t handle;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_REMOTE_EXT_FEATURES 0x041c
struct bt_hci_cmd_read_remote_ext_features {
uint16_t handle;
uint8_t page;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_REMOTE_VERSION 0x041d
struct bt_hci_cmd_read_remote_version {
uint16_t handle;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_CLOCK_OFFSET 0x041f
struct bt_hci_cmd_read_clock_offset {
uint16_t handle;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_LMP_HANDLE 0x0420
struct bt_hci_cmd_read_lmp_handle {
uint16_t handle;
} __attribute__ ((packed));
struct bt_hci_rsp_read_lmp_handle {
uint8_t status;
uint16_t handle;
uint8_t lmp_handle;
uint32_t reserved;
} __attribute__ ((packed));
#define BT_HCI_CMD_SETUP_SYNC_CONN 0x0428
struct bt_hci_cmd_setup_sync_conn {
uint16_t handle;
uint32_t tx_bandwidth;
uint32_t rx_bandwidth;
uint16_t max_latency;
uint16_t voice_setting;
uint8_t retrans_effort;
uint16_t pkt_type;
} __attribute__ ((packed));
#define BT_HCI_CMD_ACCEPT_SYNC_CONN_REQUEST 0x0429
struct bt_hci_cmd_accept_sync_conn_request {
uint8_t bdaddr[6];
uint32_t tx_bandwidth;
uint32_t rx_bandwidth;
uint16_t max_latency;
uint16_t voice_setting;
uint8_t retrans_effort;
uint16_t pkt_type;
} __attribute__ ((packed));
#define BT_HCI_CMD_REJECT_SYNC_CONN_REQUEST 0x042a
struct bt_hci_cmd_reject_sync_conn_request {
uint8_t bdaddr[6];
uint8_t reason;
} __attribute__ ((packed));
#define BT_HCI_CMD_IO_CAPABILITY_REQUEST_REPLY 0x042b
struct bt_hci_cmd_io_capability_request_reply {
uint8_t bdaddr[6];
uint8_t capability;
uint8_t oob_data;
uint8_t authentication;
} __attribute__ ((packed));
struct bt_hci_rsp_io_capability_request_reply {
uint8_t status;
uint8_t bdaddr[6];
} __attribute__ ((packed));
#define BT_HCI_CMD_USER_CONFIRM_REQUEST_REPLY 0x042c
struct bt_hci_cmd_user_confirm_request_reply {
uint8_t bdaddr[6];
} __attribute__ ((packed));
struct bt_hci_rsp_user_confirm_request_reply {
uint8_t status;
uint8_t bdaddr[6];
} __attribute__ ((packed));
#define BT_HCI_CMD_USER_CONFIRM_REQUEST_NEG_REPLY 0x042d
struct bt_hci_cmd_user_confirm_request_neg_reply {
uint8_t bdaddr[6];
} __attribute__ ((packed));
struct bt_hci_rsp_user_confirm_request_neg_reply {
uint8_t status;
uint8_t bdaddr[6];
} __attribute__ ((packed));
#define BT_HCI_CMD_USER_PASSKEY_REQUEST_REPLY 0x042e
struct bt_hci_cmd_user_passkey_request_reply {
uint8_t bdaddr[6];
uint32_t passkey;
} __attribute__ ((packed));
#define BT_HCI_CMD_USER_PASSKEY_REQUEST_NEG_REPLY 0x042f
struct bt_hci_cmd_user_passkey_request_neg_reply {
uint8_t bdaddr[6];
} __attribute__ ((packed));
#define BT_HCI_CMD_REMOTE_OOB_DATA_REQUEST_REPLY 0x0430
struct bt_hci_cmd_remote_oob_data_request_reply {
uint8_t bdaddr[6];
uint8_t hash[16];
uint8_t randomizer[16];
} __attribute__ ((packed));
#define BT_HCI_CMD_REMOTE_OOB_DATA_REQUEST_NEG_REPLY 0x0433
struct bt_hci_cmd_remote_oob_data_request_neg_reply {
uint8_t bdaddr[6];
} __attribute__ ((packed));
#define BT_HCI_CMD_IO_CAPABILITY_REQUEST_NEG_REPLY 0x0434
struct bt_hci_cmd_io_capability_request_neg_reply {
uint8_t bdaddr[6];
uint8_t reason;
} __attribute__ ((packed));
struct bt_hci_rsp_io_capability_request_neg_reply {
uint8_t status;
uint8_t bdaddr[6];
} __attribute__ ((packed));
#define BT_HCI_CMD_CREATE_PHY_LINK 0x0435
struct bt_hci_cmd_create_phy_link {
uint8_t phy_handle;
uint8_t key_len;
uint8_t key_type;
} __attribute__ ((packed));
#define BT_HCI_CMD_ACCEPT_PHY_LINK 0x0436
struct bt_hci_cmd_accept_phy_link {
uint8_t phy_handle;
uint8_t key_len;
uint8_t key_type;
} __attribute__ ((packed));
#define BT_HCI_CMD_DISCONN_PHY_LINK 0x0437
struct bt_hci_cmd_disconn_phy_link {
uint8_t phy_handle;
uint8_t reason;
} __attribute__ ((packed));
#define BT_HCI_CMD_CREATE_LOGIC_LINK 0x0438
struct bt_hci_cmd_create_logic_link {
uint8_t phy_handle;
uint8_t tx_flow_spec[16];
uint8_t rx_flow_spec[16];
} __attribute__ ((packed));
#define BT_HCI_CMD_ACCEPT_LOGIC_LINK 0x0439
struct bt_hci_cmd_accept_logic_link {
uint8_t phy_handle;
uint8_t tx_flow_spec[16];
uint8_t rx_flow_spec[16];
} __attribute__ ((packed));
#define BT_HCI_CMD_DISCONN_LOGIC_LINK 0x043a
struct bt_hci_cmd_disconn_logic_link {
uint16_t handle;
} __attribute__ ((packed));
#define BT_HCI_CMD_LOGIC_LINK_CANCEL 0x043b
struct bt_hci_cmd_logic_link_cancel {
uint8_t phy_handle;
uint8_t flow_spec;
} __attribute__ ((packed));
struct bt_hci_rsp_logic_link_cancel {
uint8_t status;
uint8_t phy_handle;
uint8_t flow_spec;
} __attribute__ ((packed));
#define BT_HCI_CMD_FLOW_SPEC_MODIFY 0x043c
struct bt_hci_cmd_flow_spec_modify {
uint16_t handle;
uint8_t tx_flow_spec[16];
uint8_t rx_flow_spec[16];
} __attribute__ ((packed));
#define BT_HCI_CMD_ENHANCED_SETUP_SYNC_CONN 0x043d
struct bt_hci_cmd_enhanced_setup_sync_conn {
uint16_t handle;
uint32_t tx_bandwidth;
uint32_t rx_bandwidth;
uint8_t tx_coding_format[5];
uint8_t rx_coding_format[5];
uint16_t tx_codec_frame_size;
uint16_t rx_codec_frame_size;
uint32_t input_bandwidth;
uint32_t output_bandwidth;
uint8_t input_coding_format[5];
uint8_t output_coding_format[5];
uint16_t input_coded_data_size;
uint16_t output_coded_data_size;
uint8_t input_pcm_data_format;
uint8_t output_pcm_data_format;
uint8_t input_pcm_msb_position;
uint8_t output_pcm_msb_position;
uint8_t input_data_path;
uint8_t output_data_path;
uint8_t input_unit_size;
uint8_t output_unit_size;
uint16_t max_latency;
uint16_t pkt_type;
uint8_t retrans_effort;
} __attribute__ ((packed));
#define BT_HCI_CMD_ENHANCED_ACCEPT_SYNC_CONN_REQUEST 0x043e
struct bt_hci_cmd_enhanced_accept_sync_conn_request {
uint8_t bdaddr[6];
uint32_t tx_bandwidth;
uint32_t rx_bandwidth;
uint8_t tx_coding_format[5];
uint8_t rx_coding_format[5];
uint16_t tx_codec_frame_size;
uint16_t rx_codec_frame_size;
uint32_t input_bandwidth;
uint32_t output_bandwidth;
uint8_t input_coding_format[5];
uint8_t output_coding_format[5];
uint16_t input_coded_data_size;
uint16_t output_coded_data_size;
uint8_t input_pcm_data_format;
uint8_t output_pcm_data_format;
uint8_t input_pcm_msb_position;
uint8_t output_pcm_msb_position;
uint8_t input_data_path;
uint8_t output_data_path;
uint8_t input_unit_size;
uint8_t output_unit_size;
uint16_t max_latency;
uint16_t pkt_type;
uint8_t retrans_effort;
} __attribute__ ((packed));
#define BT_HCI_CMD_TRUNCATED_PAGE 0x043f
struct bt_hci_cmd_truncated_page {
uint8_t bdaddr[6];
uint8_t pscan_rep_mode;
uint16_t clock_offset;
} __attribute__ ((packed));
#define BT_HCI_CMD_TRUNCATED_PAGE_CANCEL 0x0440
struct bt_hci_cmd_truncated_page_cancel {
uint8_t bdaddr[6];
} __attribute__ ((packed));
#define BT_HCI_CMD_SET_PERIPHERAL_BROADCAST 0x0441
struct bt_hci_cmd_set_peripheral_broadcast {
uint8_t enable;
uint8_t lt_addr;
uint8_t lpo_allowed;
uint16_t pkt_type;
uint16_t min_interval;
uint16_t max_interval;
uint16_t timeout;
} __attribute__ ((packed));
struct bt_hci_rsp_set_peripheral_broadcast {
uint8_t status;
uint8_t lt_addr;
uint16_t interval;
} __attribute__ ((packed));
#define BT_HCI_CMD_SET_PERIPHERAL_BROADCAST_RECEIVE 0x0442
struct bt_hci_cmd_set_peripheral_broadcast_receive {
uint8_t enable;
uint8_t bdaddr[6];
uint8_t lt_addr;
uint16_t interval;
uint32_t offset;
uint32_t instant;
uint16_t timeout;
uint8_t accuracy;
uint8_t skip;
uint16_t pkt_type;
uint8_t map[10];
} __attribute__ ((packed));
struct bt_hci_rsp_set_peripheral_broadcast_receive {
uint8_t status;
uint8_t bdaddr[6];
uint8_t lt_addr;
} __attribute__ ((packed));
#define BT_HCI_CMD_START_SYNC_TRAIN 0x0443
#define BT_HCI_CMD_RECEIVE_SYNC_TRAIN 0x0444
struct bt_hci_cmd_receive_sync_train {
uint8_t bdaddr[6];
uint16_t timeout;
uint16_t window;
uint16_t interval;
} __attribute__ ((packed));
#define BT_HCI_CMD_REMOTE_OOB_EXT_DATA_REQUEST_REPLY 0x0445
struct bt_hci_cmd_remote_oob_ext_data_request_reply {
uint8_t bdaddr[6];
uint8_t hash192[16];
uint8_t randomizer192[16];
uint8_t hash256[16];
uint8_t randomizer256[16];
} __attribute__ ((packed));
#define BT_HCI_CMD_HOLD_MODE 0x0801
struct bt_hci_cmd_hold_mode {
uint16_t handle;
uint16_t max_interval;
uint16_t min_interval;
} __attribute__ ((packed));
#define BT_HCI_CMD_SNIFF_MODE 0x0803
struct bt_hci_cmd_sniff_mode {
uint16_t handle;
uint16_t max_interval;
uint16_t min_interval;
uint16_t attempt;
uint16_t timeout;
} __attribute__ ((packed));
#define BT_HCI_CMD_EXIT_SNIFF_MODE 0x0804
struct bt_hci_cmd_exit_sniff_mode {
uint16_t handle;
} __attribute__ ((packed));
#define BT_HCI_CMD_PARK_STATE 0x0805
struct bt_hci_cmd_park_state {
uint16_t handle;
uint16_t max_interval;
uint16_t min_interval;
} __attribute__ ((packed));
#define BT_HCI_CMD_EXIT_PARK_STATE 0x0806
struct bt_hci_cmd_exit_park_state {
uint16_t handle;
} __attribute__ ((packed));
#define BT_HCI_CMD_QOS_SETUP 0x0807
struct bt_hci_cmd_qos_setup {
uint16_t handle;
uint8_t flags;
uint8_t service_type;
uint32_t token_rate;
uint32_t peak_bandwidth;
uint32_t latency;
uint32_t delay_variation;
} __attribute__ ((packed));
#define BT_HCI_CMD_ROLE_DISCOVERY 0x0809
struct bt_hci_cmd_role_discovery {
uint16_t handle;
} __attribute__ ((packed));
struct bt_hci_rsp_role_discovery {
uint8_t status;
uint16_t handle;
uint8_t role;
} __attribute__ ((packed));
#define BT_HCI_CMD_SWITCH_ROLE 0x080b
struct bt_hci_cmd_switch_role {
uint8_t bdaddr[6];
uint8_t role;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_LINK_POLICY 0x080c
struct bt_hci_cmd_read_link_policy {
uint16_t handle;
} __attribute__ ((packed));
struct bt_hci_rsp_read_link_policy {
uint8_t status;
uint16_t handle;
uint16_t policy;
} __attribute__ ((packed));
#define BT_HCI_CMD_WRITE_LINK_POLICY 0x080d
struct bt_hci_cmd_write_link_policy {
uint16_t handle;
uint16_t policy;
} __attribute__ ((packed));
struct bt_hci_rsp_write_link_policy {
uint8_t status;
uint16_t handle;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_DEFAULT_LINK_POLICY 0x080e
struct bt_hci_rsp_read_default_link_policy {
uint8_t status;
uint16_t policy;
} __attribute__ ((packed));
#define BT_HCI_CMD_WRITE_DEFAULT_LINK_POLICY 0x080f
struct bt_hci_cmd_write_default_link_policy {
uint16_t policy;
} __attribute__ ((packed));
#define BT_HCI_CMD_FLOW_SPEC 0x0810
struct bt_hci_cmd_flow_spec {
uint16_t handle;
uint8_t flags;
uint8_t direction;
uint8_t service_type;
uint32_t token_rate;
uint32_t token_bucket_size;
uint32_t peak_bandwidth;
uint32_t access_latency;
} __attribute__ ((packed));
#define BT_HCI_CMD_SNIFF_SUBRATING 0x0811
struct bt_hci_cmd_sniff_subrating {
uint16_t handle;
uint16_t max_latency;
uint16_t min_remote_timeout;
uint16_t min_local_timeout;
} __attribute__ ((packed));
struct bt_hci_rsp_sniff_subrating {
uint8_t status;
uint16_t handle;
} __attribute__ ((packed));
#define BT_HCI_CMD_SET_EVENT_MASK 0x0c01
struct bt_hci_cmd_set_event_mask {
uint8_t mask[8];
} __attribute__ ((packed));
#define BT_HCI_CMD_RESET 0x0c03
#define BT_HCI_CMD_SET_EVENT_FILTER 0x0c05
struct bt_hci_cmd_set_event_filter {
uint8_t type;
uint8_t cond_type;
uint8_t cond[0];
} __attribute__ ((packed));
#define BT_HCI_CMD_FLUSH 0x0c08
struct bt_hci_cmd_flush {
uint16_t handle;
} __attribute__ ((packed));
struct bt_hci_rsp_flush {
uint8_t status;
uint16_t handle;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_PIN_TYPE 0x0c09
struct bt_hci_rsp_read_pin_type {
uint8_t status;
uint8_t pin_type;
} __attribute__ ((packed));
#define BT_HCI_CMD_WRITE_PIN_TYPE 0x0c0a
struct bt_hci_cmd_write_pin_type {
uint8_t pin_type;
} __attribute__ ((packed));
#define BT_HCI_CMD_CREATE_NEW_UNIT_KEY 0x0c0b
#define BT_HCI_CMD_READ_STORED_LINK_KEY 0x0c0d
struct bt_hci_cmd_read_stored_link_key {
uint8_t bdaddr[6];
uint8_t read_all;
} __attribute__ ((packed));
struct bt_hci_rsp_read_stored_link_key {
uint8_t status;
uint16_t max_num_keys;
uint16_t num_keys;
} __attribute__ ((packed));
#define BT_HCI_CMD_WRITE_STORED_LINK_KEY 0x0c11
struct bt_hci_cmd_write_stored_link_key {
uint8_t num_keys;
} __attribute__ ((packed));
struct bt_hci_rsp_write_stored_link_key {
uint8_t status;
uint8_t num_keys;
} __attribute__ ((packed));
#define BT_HCI_CMD_DELETE_STORED_LINK_KEY 0x0c12
struct bt_hci_cmd_delete_stored_link_key {
uint8_t bdaddr[6];
uint8_t delete_all;
} __attribute__ ((packed));
struct bt_hci_rsp_delete_stored_link_key {
uint8_t status;
uint16_t num_keys;
} __attribute__ ((packed));
#define BT_HCI_CMD_WRITE_LOCAL_NAME 0x0c13
struct bt_hci_cmd_write_local_name {
uint8_t name[248];
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_LOCAL_NAME 0x0c14
struct bt_hci_rsp_read_local_name {
uint8_t status;
uint8_t name[248];
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_CONN_ACCEPT_TIMEOUT 0x0c15
struct bt_hci_rsp_read_conn_accept_timeout {
uint8_t status;
uint16_t timeout;
} __attribute__ ((packed));
#define BT_HCI_CMD_WRITE_CONN_ACCEPT_TIMEOUT 0x0c16
struct bt_hci_cmd_write_conn_accept_timeout {
uint16_t timeout;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_PAGE_TIMEOUT 0x0c17
struct bt_hci_rsp_read_page_timeout {
uint8_t status;
uint16_t timeout;
} __attribute__ ((packed));
#define BT_HCI_CMD_WRITE_PAGE_TIMEOUT 0x0c18
struct bt_hci_cmd_write_page_timeout {
uint16_t timeout;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_SCAN_ENABLE 0x0c19
struct bt_hci_rsp_read_scan_enable {
uint8_t status;
uint8_t enable;
} __attribute__ ((packed));
#define BT_HCI_CMD_WRITE_SCAN_ENABLE 0x0c1a
struct bt_hci_cmd_write_scan_enable {
uint8_t enable;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_PAGE_SCAN_ACTIVITY 0x0c1b
struct bt_hci_rsp_read_page_scan_activity {
uint8_t status;
uint16_t interval;
uint16_t window;
} __attribute__ ((packed));
#define BT_HCI_CMD_WRITE_PAGE_SCAN_ACTIVITY 0x0c1c
struct bt_hci_cmd_write_page_scan_activity {
uint16_t interval;
uint16_t window;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_INQUIRY_SCAN_ACTIVITY 0x0c1d
struct bt_hci_rsp_read_inquiry_scan_activity {
uint8_t status;
uint16_t interval;
uint16_t window;
} __attribute__ ((packed));
#define BT_HCI_CMD_WRITE_INQUIRY_SCAN_ACTIVITY 0x0c1e
struct bt_hci_cmd_write_inquiry_scan_activity {
uint16_t interval;
uint16_t window;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_AUTH_ENABLE 0x0c1f
struct bt_hci_rsp_read_auth_enable {
uint8_t status;
uint8_t enable;
} __attribute__ ((packed));
#define BT_HCI_CMD_WRITE_AUTH_ENABLE 0x0c20
struct bt_hci_cmd_write_auth_enable {
uint8_t enable;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_ENCRYPT_MODE 0x0c21
struct bt_hci_rsp_read_encrypt_mode {
uint8_t status;
uint8_t mode;
} __attribute__ ((packed));
#define BT_HCI_CMD_WRITE_ENCRYPT_MODE 0x0c22
struct bt_hci_cmd_write_encrypt_mode {
uint8_t mode;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_CLASS_OF_DEV 0x0c23
struct bt_hci_rsp_read_class_of_dev {
uint8_t status;
uint8_t dev_class[3];
} __attribute__ ((packed));
#define BT_HCI_CMD_WRITE_CLASS_OF_DEV 0x0c24
struct bt_hci_cmd_write_class_of_dev {
uint8_t dev_class[3];
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_VOICE_SETTING 0x0c25
struct bt_hci_rsp_read_voice_setting {
uint8_t status;
uint16_t setting;
} __attribute__ ((packed));
#define BT_HCI_CMD_WRITE_VOICE_SETTING 0x0c26
struct bt_hci_cmd_write_voice_setting {
uint16_t setting;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_AUTO_FLUSH_TIMEOUT 0x0c27
struct bt_hci_cmd_read_auto_flush_timeout {
uint16_t handle;
} __attribute__ ((packed));
struct bt_hci_rsp_read_auto_flush_timeout {
uint8_t status;
uint16_t handle;
uint16_t timeout;
} __attribute__ ((packed));
#define BT_HCI_CMD_WRITE_AUTO_FLUSH_TIMEOUT 0x0c28
struct bt_hci_cmd_write_auto_flush_timeout {
uint16_t handle;
uint16_t timeout;
} __attribute__ ((packed));
struct bt_hci_rsp_write_auto_flush_timeout {
uint8_t status;
uint16_t handle;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_NUM_BROADCAST_RETRANS 0x0c29
struct bt_hci_rsp_read_num_broadcast_retrans {
uint8_t status;
uint8_t num_retrans;
} __attribute__ ((packed));
#define BT_HCI_CMD_WRITE_NUM_BROADCAST_RETRANS 0x0c2a
struct bt_hci_cmd_write_num_broadcast_retrans {
uint8_t num_retrans;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_HOLD_MODE_ACTIVITY 0x0c2b
struct bt_hci_rsp_read_hold_mode_activity {
uint8_t status;
uint8_t activity;
} __attribute__ ((packed));
#define BT_HCI_CMD_WRITE_HOLD_MODE_ACTIVITY 0x0c2c
struct bt_hci_cmd_write_hold_mode_activity {
uint8_t activity;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_TX_POWER 0x0c2d
struct bt_hci_cmd_read_tx_power {
uint16_t handle;
uint8_t type;
} __attribute__ ((packed));
struct bt_hci_rsp_read_tx_power {
uint8_t status;
uint16_t handle;
int8_t level;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_SYNC_FLOW_CONTROL 0x0c2e
struct bt_hci_rsp_read_sync_flow_control {
uint8_t status;
uint8_t enable;
} __attribute__ ((packed));
#define BT_HCI_CMD_WRITE_SYNC_FLOW_CONTROL 0x0c2f
struct bt_hci_cmd_write_sync_flow_control {
uint8_t enable;
} __attribute__ ((packed));
#define BT_HCI_CMD_SET_HOST_FLOW_CONTROL 0x0c31
struct bt_hci_cmd_set_host_flow_control {
uint8_t enable;
} __attribute__ ((packed));
#define BT_HCI_CMD_HOST_BUFFER_SIZE 0x0c33
struct bt_hci_cmd_host_buffer_size {
uint16_t acl_mtu;
uint8_t sco_mtu;
uint16_t acl_max_pkt;
uint16_t sco_max_pkt;
} __attribute__ ((packed));
#define BT_HCI_CMD_HOST_NUM_COMPLETED_PACKETS 0x0c35
struct bt_hci_cmd_host_num_completed_packets {
uint8_t num_handles;
uint16_t handle;
uint16_t count;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_LINK_SUPV_TIMEOUT 0x0c36
struct bt_hci_cmd_read_link_supv_timeout {
uint16_t handle;
} __attribute__ ((packed));
struct bt_hci_rsp_read_link_supv_timeout {
uint8_t status;
uint16_t handle;
uint16_t timeout;
} __attribute__ ((packed));
#define BT_HCI_CMD_WRITE_LINK_SUPV_TIMEOUT 0x0c37
struct bt_hci_cmd_write_link_supv_timeout {
uint16_t handle;
uint16_t timeout;
} __attribute__ ((packed));
struct bt_hci_rsp_write_link_supv_timeout {
uint8_t status;
uint16_t handle;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_NUM_SUPPORTED_IAC 0x0c38
struct bt_hci_rsp_read_num_supported_iac {
uint8_t status;
uint8_t num_iac;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_CURRENT_IAC_LAP 0x0c39
struct bt_hci_rsp_read_current_iac_lap {
uint8_t status;
uint8_t num_iac;
uint8_t iac_lap[0];
} __attribute__ ((packed));
#define BT_HCI_CMD_WRITE_CURRENT_IAC_LAP 0x0c3a
struct bt_hci_cmd_write_current_iac_lap {
uint8_t num_iac;
uint8_t iac_lap[0];
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_PAGE_SCAN_PERIOD_MODE 0x0c3b
struct bt_hci_rsp_read_page_scan_period_mode {
uint8_t status;
uint8_t mode;
} __attribute__ ((packed));
#define BT_HCI_CMD_WRITE_PAGE_SCAN_PERIOD_MODE 0x0c3c
struct bt_hci_cmd_write_page_scan_period_mode {
uint8_t mode;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_PAGE_SCAN_MODE 0x0c3d
struct bt_hci_rsp_read_page_scan_mode {
uint8_t status;
uint8_t mode;
} __attribute__ ((packed));
#define BT_HCI_CMD_WRITE_PAGE_SCAN_MODE 0x0c3e
struct bt_hci_cmd_write_page_scan_mode {
uint8_t mode;
} __attribute__ ((packed));
#define BT_HCI_CMD_SET_AFH_HOST_CLASSIFICATION 0x0c3f
struct bt_hci_cmd_set_afh_host_classification {
uint8_t map[10];
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_INQUIRY_SCAN_TYPE 0x0c42
struct bt_hci_rsp_read_inquiry_scan_type {
uint8_t status;
uint8_t type;
} __attribute__ ((packed));
#define BT_HCI_CMD_WRITE_INQUIRY_SCAN_TYPE 0x0c43
struct bt_hci_cmd_write_inquiry_scan_type {
uint8_t type;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_INQUIRY_MODE 0x0c44
struct bt_hci_rsp_read_inquiry_mode {
uint8_t status;
uint8_t mode;
} __attribute__ ((packed));
#define BT_HCI_CMD_WRITE_INQUIRY_MODE 0x0c45
struct bt_hci_cmd_write_inquiry_mode {
uint8_t mode;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_PAGE_SCAN_TYPE 0x0c46
struct bt_hci_rsp_read_page_scan_type {
uint8_t status;
uint8_t type;
} __attribute__ ((packed));
#define BT_HCI_CMD_WRITE_PAGE_SCAN_TYPE 0x0c47
struct bt_hci_cmd_write_page_scan_type {
uint8_t type;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_AFH_ASSESSMENT_MODE 0x0c48
struct bt_hci_rsp_read_afh_assessment_mode {
uint8_t status;
uint8_t mode;
} __attribute__ ((packed));
#define BT_HCI_CMD_WRITE_AFH_ASSESSMENT_MODE 0x0c49
struct bt_hci_cmd_write_afh_assessment_mode {
uint8_t mode;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_EXT_INQUIRY_RESPONSE 0x0c51
struct bt_hci_rsp_read_ext_inquiry_response {
uint8_t status;
uint8_t fec;
uint8_t data[240];
} __attribute__ ((packed));
#define BT_HCI_CMD_WRITE_EXT_INQUIRY_RESPONSE 0x0c52
struct bt_hci_cmd_write_ext_inquiry_response {
uint8_t fec;
uint8_t data[240];
} __attribute__ ((packed));
#define BT_HCI_CMD_REFRESH_ENCRYPT_KEY 0x0c53
struct bt_hci_cmd_refresh_encrypt_key {
uint16_t handle;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_SIMPLE_PAIRING_MODE 0x0c55
struct bt_hci_rsp_read_simple_pairing_mode {
uint8_t status;
uint8_t mode;
} __attribute__ ((packed));
#define BT_HCI_CMD_WRITE_SIMPLE_PAIRING_MODE 0x0c56
struct bt_hci_cmd_write_simple_pairing_mode {
uint8_t mode;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_LOCAL_OOB_DATA 0x0c57
struct bt_hci_rsp_read_local_oob_data {
uint8_t status;
uint8_t hash[16];
uint8_t randomizer[16];
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_INQUIRY_RESP_TX_POWER 0x0c58
struct bt_hci_rsp_read_inquiry_resp_tx_power {
uint8_t status;
int8_t level;
} __attribute__ ((packed));
#define BT_HCI_CMD_WRITE_INQUIRY_TX_POWER 0x0c59
struct bt_hci_cmd_write_inquiry_tx_power {
int8_t level;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_ERRONEOUS_REPORTING 0x0c5a
struct bt_hci_rsp_read_erroneous_reporting {
uint8_t status;
uint8_t mode;
} __attribute__ ((packed));
#define BT_HCI_CMD_WRITE_ERRONEOUS_REPORTING 0x0c5b
struct bt_hci_cmd_write_erroneous_reporting {
uint8_t mode;
} __attribute__ ((packed));
#define BT_HCI_CMD_ENHANCED_FLUSH 0x0c5f
struct bt_hci_cmd_enhanced_flush {
uint16_t handle;
uint8_t type;
} __attribute__ ((packed));
#define BT_HCI_CMD_SEND_KEYPRESS_NOTIFY 0x0c60
struct bt_hci_cmd_send_keypress_notify {
uint8_t bdaddr[6];
uint8_t type;
} __attribute__ ((packed));
struct bt_hci_rsp_send_keypress_notify {
uint8_t status;
uint8_t bdaddr[6];
} __attribute__ ((packed));
#define BT_HCI_CMD_SET_EVENT_MASK_PAGE2 0x0c63
struct bt_hci_cmd_set_event_mask_page2 {
uint8_t mask[8];
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_LOCATION_DATA 0x0c64
struct bt_hci_rsp_read_location_data {
uint8_t status;
uint8_t domain_aware;
uint8_t domain[2];
uint8_t domain_options;
uint8_t options;
} __attribute__ ((packed));
#define BT_HCI_CMD_WRITE_LOCATION_DATA 0x0c65
struct bt_hci_cmd_write_location_data {
uint8_t domain_aware;
uint8_t domain[2];
uint8_t domain_options;
uint8_t options;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_FLOW_CONTROL_MODE 0x0c66
struct bt_hci_rsp_read_flow_control_mode {
uint8_t status;
uint8_t mode;
} __attribute__ ((packed));
#define BT_HCI_CMD_WRITE_FLOW_CONTROL_MODE 0x0c67
struct bt_hci_cmd_write_flow_control_mode {
uint8_t mode;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_ENHANCED_TX_POWER 0x0c68
struct bt_hci_cmd_read_enhanced_tx_power {
uint16_t handle;
uint8_t type;
} __attribute__ ((packed));
struct bt_hci_rsp_read_enhanced_tx_power {
uint8_t status;
uint16_t handle;
int8_t level_gfsk;
int8_t level_dqpsk;
int8_t level_8dpsk;
} __attribute__ ((packed));
#define BT_HCI_CMD_SHORT_RANGE_MODE 0x0c6b
struct bt_hci_cmd_short_range_mode {
uint8_t phy_handle;
uint8_t mode;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_LE_HOST_SUPPORTED 0x0c6c
struct bt_hci_rsp_read_le_host_supported {
uint8_t status;
uint8_t supported;
uint8_t simultaneous;
} __attribute__ ((packed));
#define BT_HCI_CMD_WRITE_LE_HOST_SUPPORTED 0x0c6d
struct bt_hci_cmd_write_le_host_supported {
uint8_t supported;
uint8_t simultaneous;
} __attribute__ ((packed));
#define BT_HCI_CMD_SET_RESERVED_LT_ADDR 0x0c74
struct bt_hci_cmd_set_reserved_lt_addr {
uint8_t lt_addr;
} __attribute__ ((packed));
struct bt_hci_rsp_set_reserved_lt_addr {
uint8_t status;
uint8_t lt_addr;
} __attribute__ ((packed));
#define BT_HCI_CMD_DELETE_RESERVED_LT_ADDR 0x0c75
struct bt_hci_cmd_delete_reserved_lt_addr {
uint8_t lt_addr;
} __attribute__ ((packed));
struct bt_hci_rsp_delete_reserved_lt_addr {
uint8_t status;
uint8_t lt_addr;
} __attribute__ ((packed));
#define BT_HCI_CMD_SET_PERIPHERAL_BROADCAST_DATA 0x0c76
struct bt_hci_cmd_set_peripheral_broadcast_data {
uint8_t lt_addr;
uint8_t fragment;
uint8_t length;
} __attribute__ ((packed));
struct bt_hci_rsp_set_peripheral_broadcast_data {
uint8_t status;
uint8_t lt_addr;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_SYNC_TRAIN_PARAMS 0x0c77
struct bt_hci_rsp_read_sync_train_params {
uint8_t status;
uint16_t interval;
uint32_t timeout;
uint8_t service_data;
} __attribute__ ((packed));
#define BT_HCI_CMD_WRITE_SYNC_TRAIN_PARAMS 0x0c78
struct bt_hci_cmd_write_sync_train_params {
uint16_t min_interval;
uint16_t max_interval;
uint32_t timeout;
uint8_t service_data;
} __attribute__ ((packed));
struct bt_hci_rsp_write_sync_train_params {
uint8_t status;
uint16_t interval;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_SECURE_CONN_SUPPORT 0x0c79
struct bt_hci_rsp_read_secure_conn_support {
uint8_t status;
uint8_t support;
} __attribute__ ((packed));
#define BT_HCI_CMD_WRITE_SECURE_CONN_SUPPORT 0x0c7a
struct bt_hci_cmd_write_secure_conn_support {
uint8_t support;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_AUTH_PAYLOAD_TIMEOUT 0x0c7b
struct bt_hci_cmd_read_auth_payload_timeout {
uint16_t handle;
} __attribute__ ((packed));
struct bt_hci_rsp_read_auth_payload_timeout {
uint8_t status;
uint16_t handle;
uint16_t timeout;
} __attribute__ ((packed));
#define BT_HCI_CMD_WRITE_AUTH_PAYLOAD_TIMEOUT 0x0c7c
struct bt_hci_cmd_write_auth_payload_timeout {
uint16_t handle;
uint16_t timeout;
} __attribute__ ((packed));
struct bt_hci_rsp_write_auth_payload_timeout {
uint8_t status;
uint16_t handle;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_LOCAL_OOB_EXT_DATA 0x0c7d
struct bt_hci_rsp_read_local_oob_ext_data {
uint8_t status;
uint8_t hash192[16];
uint8_t randomizer192[16];
uint8_t hash256[16];
uint8_t randomizer256[16];
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_EXT_PAGE_TIMEOUT 0x0c7e
struct bt_hci_rsp_read_ext_page_timeout {
uint8_t status;
uint16_t timeout;
} __attribute__ ((packed));
#define BT_HCI_CMD_WRITE_EXT_PAGE_TIMEOUT 0x0c7f
struct bt_hci_cmd_write_ext_page_timeout {
uint16_t timeout;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_EXT_INQUIRY_LENGTH 0x0c80
struct bt_hci_rsp_read_ext_inquiry_length {
uint8_t status;
uint16_t interval;
} __attribute__ ((packed));
#define BT_HCI_CMD_WRITE_EXT_INQUIRY_LENGTH 0x0c81
struct bt_hci_cmd_write_ext_inquiry_length {
uint16_t interval;
} __attribute__ ((packed));
#define BT_HCI_CMD_CONFIG_DATA_PATH 0x0c83
#define BT_HCI_BIT_CONFIG_DATA_PATH BT_HCI_CMD_BIT(45, 5)
struct bt_hci_cmd_config_data_path {
uint8_t dir;
uint8_t id;
uint8_t vnd_config_len;
uint8_t vnd_config[0];
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_LOCAL_VERSION 0x1001
struct bt_hci_rsp_read_local_version {
uint8_t status;
uint8_t hci_ver;
uint16_t hci_rev;
uint8_t lmp_ver;
uint16_t manufacturer;
uint16_t lmp_subver;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_LOCAL_COMMANDS 0x1002
struct bt_hci_rsp_read_local_commands {
uint8_t status;
uint8_t commands[64];
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_LOCAL_FEATURES 0x1003
struct bt_hci_rsp_read_local_features {
uint8_t status;
uint8_t features[8];
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_LOCAL_EXT_FEATURES 0x1004
struct bt_hci_cmd_read_local_ext_features {
uint8_t page;
} __attribute__ ((packed));
struct bt_hci_rsp_read_local_ext_features {
uint8_t status;
uint8_t page;
uint8_t max_page;
uint8_t features[8];
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_BUFFER_SIZE 0x1005
struct bt_hci_rsp_read_buffer_size {
uint8_t status;
uint16_t acl_mtu;
uint8_t sco_mtu;
uint16_t acl_max_pkt;
uint16_t sco_max_pkt;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_COUNTRY_CODE 0x1007
struct bt_hci_rsp_read_country_code {
uint8_t status;
uint8_t code;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_BD_ADDR 0x1009
struct bt_hci_rsp_read_bd_addr {
uint8_t status;
uint8_t bdaddr[6];
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_DATA_BLOCK_SIZE 0x100a
struct bt_hci_rsp_read_data_block_size {
uint8_t status;
uint16_t max_acl_len;
uint16_t block_len;
uint16_t num_blocks;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_LOCAL_CODECS 0x100b
struct bt_hci_rsp_read_local_codecs {
uint8_t status;
uint8_t num_codecs;
uint8_t codec[0];
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_LOCAL_PAIRING_OPTIONS 0x100c
struct bt_hci_rsp_read_local_pairing_options {
uint8_t status;
uint8_t pairing_options;
uint8_t max_key_size;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_LOCAL_CODECS_V2 0x100d
#define BT_HCI_BIT_READ_LOCAL_CODECS_V2 BT_HCI_CMD_BIT(45, 2)
#define BT_HCI_LOCAL_CODEC_BREDR_ACL BIT(0)
#define BT_HCI_LOCAL_CODEC_BREDR_SCO BIT(1)
#define BT_HCI_LOCAL_CODEC_LE_CIS BIT(2)
#define BT_HCI_LOCAL_CODEC_LE_BIS BIT(3)
struct bt_hci_vnd_codec {
uint8_t id;
uint16_t cid;
uint16_t vid;
uint8_t transport;
} __attribute__ ((packed));
struct bt_hci_codec {
uint8_t id;
uint8_t transport;
} __attribute__ ((packed));
struct bt_hci_rsp_read_local_codecs_v2 {
uint8_t status;
uint8_t num_codecs;
struct bt_hci_codec codec[0];
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_LOCAL_CODEC_CAPS 0x100e
#define BT_HCI_BIT_READ_LOCAL_CODEC_CAPS BT_HCI_CMD_BIT(45, 3)
struct bt_hci_cmd_read_local_codec_caps {
struct bt_hci_vnd_codec codec;
uint8_t dir;
} __attribute__ ((packed));
struct bt_hci_codec_caps {
uint8_t len;
uint8_t data[0];
} __attribute__ ((packed));
struct bt_hci_rsp_read_local_codec_caps {
uint8_t status;
uint8_t num;
struct bt_hci_codec_caps caps[0];
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_LOCAL_CTRL_DELAY 0x100f
#define BT_HCI_BIT_READ_LOCAL_CTRL_DELAY BT_HCI_CMD_BIT(45, 4)
struct bt_hci_cmd_read_local_ctrl_delay {
struct bt_hci_vnd_codec codec;
uint8_t dir;
uint8_t codec_cfg_len;
uint8_t codec_cfg[0];
} __attribute__ ((packed));
struct bt_hci_rsp_read_local_ctrl_delay {
uint8_t status;
uint8_t min_delay[3];
uint8_t max_delay[3];
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_FAILED_CONTACT_COUNTER 0x1401
struct bt_hci_cmd_read_failed_contact_counter {
uint16_t handle;
} __attribute__ ((packed));
struct bt_hci_rsp_read_failed_contact_counter {
uint8_t status;
uint16_t handle;
uint16_t counter;
} __attribute__ ((packed));
#define BT_HCI_CMD_RESET_FAILED_CONTACT_COUNTER 0x1402
struct bt_hci_cmd_reset_failed_contact_counter {
uint16_t handle;
} __attribute__ ((packed));
struct bt_hci_rsp_reset_failed_contact_counter {
uint8_t status;
uint16_t handle;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_LINK_QUALITY 0x1403
struct bt_hci_cmd_read_link_quality {
uint16_t handle;
} __attribute__ ((packed));
struct bt_hci_rsp_read_link_quality {
uint8_t status;
uint16_t handle;
uint8_t link_quality;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_RSSI 0x1405
struct bt_hci_cmd_read_rssi {
uint16_t handle;
} __attribute__ ((packed));
struct bt_hci_rsp_read_rssi {
uint8_t status;
uint16_t handle;
int8_t rssi;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_AFH_CHANNEL_MAP 0x1406
struct bt_hci_cmd_read_afh_channel_map {
uint16_t handle;
} __attribute__ ((packed));
struct bt_hci_rsp_read_afh_channel_map {
uint8_t status;
uint16_t handle;
uint8_t mode;
uint8_t map[10];
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_CLOCK 0x1407
struct bt_hci_cmd_read_clock {
uint16_t handle;
uint8_t type;
} __attribute__ ((packed));
struct bt_hci_rsp_read_clock {
uint8_t status;
uint16_t handle;
uint32_t clock;
uint16_t accuracy;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_ENCRYPT_KEY_SIZE 0x1408
struct bt_hci_cmd_read_encrypt_key_size {
uint16_t handle;
} __attribute__ ((packed));
struct bt_hci_rsp_read_encrypt_key_size {
uint8_t status;
uint16_t handle;
uint8_t key_size;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_LOCAL_AMP_INFO 0x1409
struct bt_hci_rsp_read_local_amp_info {
uint8_t status;
uint8_t amp_status;
uint32_t total_bw;
uint32_t max_bw;
uint32_t min_latency;
uint32_t max_pdu;
uint8_t amp_type;
uint16_t pal_cap;
uint16_t max_assoc_len;
uint32_t max_flush_to;
uint32_t be_flush_to;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_LOCAL_AMP_ASSOC 0x140a
struct bt_hci_cmd_read_local_amp_assoc {
uint8_t phy_handle;
uint16_t len_so_far;
uint16_t max_assoc_len;
} __attribute__ ((packed));
struct bt_hci_rsp_read_local_amp_assoc {
uint8_t status;
uint8_t phy_handle;
uint16_t remain_assoc_len;
uint8_t assoc_fragment[248];
} __attribute__ ((packed));
#define BT_HCI_CMD_WRITE_REMOTE_AMP_ASSOC 0x140b
struct bt_hci_cmd_write_remote_amp_assoc {
uint8_t phy_handle;
uint16_t len_so_far;
uint16_t remain_assoc_len;
uint8_t assoc_fragment[248];
} __attribute__ ((packed));
struct bt_hci_rsp_write_remote_amp_assoc {
uint8_t status;
uint8_t phy_handle;
} __attribute__ ((packed));
#define BT_HCI_CMD_GET_MWS_TRANSPORT_CONFIG 0x140c
struct bt_hci_rsp_get_mws_transport_config {
uint8_t status;
uint8_t num_transports;
uint8_t transport[0];
} __attribute__ ((packed));
#define BT_HCI_CMD_SET_TRIGGERED_CLOCK_CAPTURE 0x140d
struct bt_hci_cmd_set_triggered_clock_capture {
uint16_t handle;
uint8_t enable;
uint8_t type;
uint8_t lpo_allowed;
uint8_t num_filter;
} __attribute__ ((packed));
#define BT_HCI_CMD_READ_LOOPBACK_MODE 0x1801
struct bt_hci_rsp_read_loopback_mode {
uint8_t status;
uint8_t mode;
} __attribute__ ((packed));
#define BT_HCI_CMD_WRITE_LOOPBACK_MODE 0x1802
struct bt_hci_cmd_write_loopback_mode {
uint8_t mode;
} __attribute__ ((packed));
#define BT_HCI_CMD_ENABLE_DUT_MODE 0x1803
#define BT_HCI_CMD_WRITE_SSP_DEBUG_MODE 0x1804
struct bt_hci_cmd_write_ssp_debug_mode {
uint8_t mode;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_SET_EVENT_MASK 0x2001
struct bt_hci_cmd_le_set_event_mask {
uint8_t mask[8];
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_READ_BUFFER_SIZE 0x2002
struct bt_hci_rsp_le_read_buffer_size {
uint8_t status;
uint16_t le_mtu;
uint8_t le_max_pkt;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_READ_LOCAL_FEATURES 0x2003
struct bt_hci_rsp_le_read_local_features {
uint8_t status;
uint8_t features[8];
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_SET_RANDOM_ADDRESS 0x2005
struct bt_hci_cmd_le_set_random_address {
uint8_t addr[6];
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_SET_ADV_PARAMETERS 0x2006
struct bt_hci_cmd_le_set_adv_parameters {
uint16_t min_interval;
uint16_t max_interval;
uint8_t type;
uint8_t own_addr_type;
uint8_t direct_addr_type;
uint8_t direct_addr[6];
uint8_t channel_map;
uint8_t filter_policy;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_READ_ADV_TX_POWER 0x2007
struct bt_hci_rsp_le_read_adv_tx_power {
uint8_t status;
int8_t level;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_SET_ADV_DATA 0x2008
struct bt_hci_cmd_le_set_adv_data {
uint8_t len;
uint8_t data[31];
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_SET_SCAN_RSP_DATA 0x2009
struct bt_hci_cmd_le_set_scan_rsp_data {
uint8_t len;
uint8_t data[31];
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_SET_ADV_ENABLE 0x200a
struct bt_hci_cmd_le_set_adv_enable {
uint8_t enable;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_SET_SCAN_PARAMETERS 0x200b
struct bt_hci_cmd_le_set_scan_parameters {
uint8_t type;
uint16_t interval;
uint16_t window;
uint8_t own_addr_type;
uint8_t filter_policy;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_SET_SCAN_ENABLE 0x200c
struct bt_hci_cmd_le_set_scan_enable {
uint8_t enable;
uint8_t filter_dup;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_CREATE_CONN 0x200d
struct bt_hci_cmd_le_create_conn {
uint16_t scan_interval;
uint16_t scan_window;
uint8_t filter_policy;
uint8_t peer_addr_type;
uint8_t peer_addr[6];
uint8_t own_addr_type;
uint16_t min_interval;
uint16_t max_interval;
uint16_t latency;
uint16_t supv_timeout;
uint16_t min_length;
uint16_t max_length;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_CREATE_CONN_CANCEL 0x200e
#define BT_HCI_CMD_LE_READ_ACCEPT_LIST_SIZE 0x200f
struct bt_hci_rsp_le_read_accept_list_size {
uint8_t status;
uint8_t size;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_CLEAR_ACCEPT_LIST 0x2010
#define BT_HCI_CMD_LE_ADD_TO_ACCEPT_LIST 0x2011
struct bt_hci_cmd_le_add_to_accept_list {
uint8_t addr_type;
uint8_t addr[6];
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_REMOVE_FROM_ACCEPT_LIST 0x2012
struct bt_hci_cmd_le_remove_from_accept_list {
uint8_t addr_type;
uint8_t addr[6];
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_CONN_UPDATE 0x2013
struct bt_hci_cmd_le_conn_update {
uint16_t handle;
uint16_t min_interval;
uint16_t max_interval;
uint16_t latency;
uint16_t supv_timeout;
uint16_t min_length;
uint16_t max_length;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_SET_HOST_CLASSIFICATION 0x2014
struct bt_hci_cmd_le_set_host_classification {
uint8_t map[5];
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_READ_CHANNEL_MAP 0x2015
struct bt_hci_cmd_le_read_channel_map {
uint16_t handle;
} __attribute__ ((packed));
struct bt_hci_rsp_le_read_channel_map {
uint8_t status;
uint16_t handle;
uint8_t map[5];
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_READ_REMOTE_FEATURES 0x2016
struct bt_hci_cmd_le_read_remote_features {
uint16_t handle;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_ENCRYPT 0x2017
struct bt_hci_cmd_le_encrypt {
uint8_t key[16];
uint8_t plaintext[16];
} __attribute__ ((packed));
struct bt_hci_rsp_le_encrypt {
uint8_t status;
uint8_t data[16];
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_RAND 0x2018
struct bt_hci_rsp_le_rand {
uint8_t status;
uint64_t number;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_START_ENCRYPT 0x2019
struct bt_hci_cmd_le_start_encrypt {
uint16_t handle;
uint64_t rand;
uint16_t ediv;
uint8_t ltk[16];
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_LTK_REQ_REPLY 0x201a
struct bt_hci_cmd_le_ltk_req_reply {
uint16_t handle;
uint8_t ltk[16];
} __attribute__ ((packed));
struct bt_hci_rsp_le_ltk_req_reply {
uint8_t status;
uint16_t handle;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_LTK_REQ_NEG_REPLY 0x201b
struct bt_hci_cmd_le_ltk_req_neg_reply {
uint16_t handle;
} __attribute__ ((packed));
struct bt_hci_rsp_le_ltk_req_neg_reply {
uint8_t status;
uint16_t handle;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_READ_SUPPORTED_STATES 0x201c
struct bt_hci_rsp_le_read_supported_states {
uint8_t status;
uint8_t states[8];
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_RECEIVER_TEST 0x201d
struct bt_hci_cmd_le_receiver_test {
uint8_t frequency;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_TRANSMITTER_TEST 0x201e
struct bt_hci_cmd_le_transmitter_test {
uint8_t frequency;
uint8_t data_len;
uint8_t payload;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_TEST_END 0x201f
struct bt_hci_rsp_le_test_end {
uint8_t status;
uint16_t num_packets;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_CONN_PARAM_REQ_REPLY 0x2020
struct bt_hci_cmd_le_conn_param_req_reply {
uint16_t handle;
uint16_t min_interval;
uint16_t max_interval;
uint16_t latency;
uint16_t supv_timeout;
uint16_t min_length;
uint16_t max_length;
} __attribute__ ((packed));
struct bt_hci_rsp_le_conn_param_req_reply {
uint8_t status;
uint16_t handle;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_CONN_PARAM_REQ_NEG_REPLY 0x2021
struct bt_hci_cmd_le_conn_param_req_neg_reply {
uint16_t handle;
uint8_t reason;
} __attribute__ ((packed));
struct bt_hci_rsp_le_conn_param_req_neg_reply {
uint8_t status;
uint16_t handle;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_SET_DATA_LENGTH 0x2022
struct bt_hci_cmd_le_set_data_length {
uint16_t handle;
uint16_t tx_len;
uint16_t tx_time;
} __attribute__ ((packed));
struct bt_hci_rsp_le_set_data_length {
uint8_t status;
uint16_t handle;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_READ_DEFAULT_DATA_LENGTH 0x2023
struct bt_hci_rsp_le_read_default_data_length {
uint8_t status;
uint16_t tx_len;
uint16_t tx_time;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_WRITE_DEFAULT_DATA_LENGTH 0x2024
struct bt_hci_cmd_le_write_default_data_length {
uint16_t tx_len;
uint16_t tx_time;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_READ_LOCAL_PK256 0x2025
#define BT_HCI_CMD_LE_GENERATE_DHKEY 0x2026
struct bt_hci_cmd_le_generate_dhkey {
uint8_t remote_pk256[64];
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_ADD_TO_RESOLV_LIST 0x2027
struct bt_hci_cmd_le_add_to_resolv_list {
uint8_t addr_type;
uint8_t addr[6];
uint8_t peer_irk[16];
uint8_t local_irk[16];
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_REMOVE_FROM_RESOLV_LIST 0x2028
struct bt_hci_cmd_le_remove_from_resolv_list {
uint8_t addr_type;
uint8_t addr[6];
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_CLEAR_RESOLV_LIST 0x2029
#define BT_HCI_CMD_LE_READ_RESOLV_LIST_SIZE 0x202a
struct bt_hci_rsp_le_read_resolv_list_size {
uint8_t status;
uint8_t size;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_READ_PEER_RESOLV_ADDR 0x202b
struct bt_hci_cmd_le_read_peer_resolv_addr {
uint8_t addr_type;
uint8_t addr[6];
} __attribute__ ((packed));
struct bt_hci_rsp_le_read_peer_resolv_addr {
uint8_t status;
uint8_t addr[6];
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_READ_LOCAL_RESOLV_ADDR 0x202c
struct bt_hci_cmd_le_read_local_resolv_addr {
uint8_t addr_type;
uint8_t addr[6];
} __attribute__ ((packed));
struct bt_hci_rsp_le_read_local_resolv_addr {
uint8_t status;
uint8_t addr[6];
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_SET_RESOLV_ENABLE 0x202d
struct bt_hci_cmd_le_set_resolv_enable {
uint8_t enable;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_SET_RESOLV_TIMEOUT 0x202e
struct bt_hci_cmd_le_set_resolv_timeout {
uint16_t timeout;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_READ_MAX_DATA_LENGTH 0x202f
struct bt_hci_rsp_le_read_max_data_length {
uint8_t status;
uint16_t max_tx_len;
uint16_t max_tx_time;
uint16_t max_rx_len;
uint16_t max_rx_time;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_READ_PHY 0x2030
struct bt_hci_cmd_le_read_phy {
uint16_t handle;
} __attribute__((packed));
struct bt_hci_rsp_le_read_phy {
uint8_t status;
uint16_t handle;
uint8_t tx_phy;
uint8_t rx_phy;
} __attribute__((packed));
#define BT_HCI_CMD_LE_SET_DEFAULT_PHY 0x2031
struct bt_hci_cmd_le_set_default_phy {
uint8_t all_phys;
uint8_t tx_phys;
uint8_t rx_phys;
} __attribute__((packed));
#define BT_HCI_CMD_LE_SET_PHY 0x2032
struct bt_hci_cmd_le_set_phy {
uint16_t handle;
uint8_t all_phys;
uint8_t tx_phys;
uint8_t rx_phys;
uint16_t phy_opts;
} __attribute__((packed));
#define BT_HCI_CMD_LE_ENHANCED_RECEIVER_TEST 0x2033
struct bt_hci_cmd_le_enhanced_receiver_test {
uint8_t rx_channel;
uint8_t phy;
uint8_t modulation_index;
} __attribute__((packed));
#define BT_HCI_CMD_LE_ENHANCED_TRANSMITTER_TEST 0x2034
struct bt_hci_cmd_le_enhanced_transmitter_test {
uint8_t tx_channel;
uint8_t data_len;
uint8_t payload;
uint8_t phy;
} __attribute__((packed));
#define BT_HCI_CMD_LE_SET_ADV_SET_RAND_ADDR 0x2035
struct bt_hci_cmd_le_set_adv_set_rand_addr {
uint8_t handle;
uint8_t bdaddr[6];
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_SET_EXT_ADV_PARAMS 0x2036
struct bt_hci_cmd_le_set_ext_adv_params {
uint8_t handle;
uint16_t evt_properties;
uint8_t min_interval[3];
uint8_t max_interval[3];
uint8_t channel_map;
uint8_t own_addr_type;
uint8_t peer_addr_type;
uint8_t peer_addr[6];
uint8_t filter_policy;
uint8_t tx_power;
uint8_t primary_phy;
uint8_t secondary_max_skip;
uint8_t secondary_phy;
uint8_t sid;
uint8_t notif_enable;
} __attribute__ ((packed));
struct bt_hci_rsp_le_set_ext_adv_params {
uint8_t status;
uint8_t tx_power;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_SET_EXT_ADV_DATA 0x2037
struct bt_hci_cmd_le_set_ext_adv_data {
uint8_t handle;
uint8_t operation;
uint8_t fragment_preference;
uint8_t data_len;
uint8_t data[0];
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_SET_EXT_SCAN_RSP_DATA 0x2038
struct bt_hci_cmd_le_set_ext_scan_rsp_data {
uint8_t handle;
uint8_t operation;
uint8_t fragment_preference;
uint8_t data_len;
uint8_t data[0];
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_SET_EXT_ADV_ENABLE 0x2039
struct bt_hci_cmd_le_set_ext_adv_enable {
uint8_t enable;
uint8_t num_of_sets;
} __attribute__ ((packed));
struct bt_hci_cmd_ext_adv_set {
uint8_t handle;
uint16_t duration;
uint8_t max_events;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_READ_MAX_ADV_DATA_LEN 0x203a
struct bt_hci_rsp_le_read_max_adv_data_len {
uint8_t status;
uint16_t max_len;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_READ_NUM_SUPPORTED_ADV_SETS 0x203b
struct bt_hci_rsp_le_read_num_supported_adv_sets {
uint8_t status;
uint8_t num_of_sets;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_REMOVE_ADV_SET 0x203c
struct bt_hci_cmd_le_remove_adv_set {
uint8_t handle;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_CLEAR_ADV_SETS 0x203d
#define BT_HCI_CMD_LE_SET_PA_PARAMS 0x203e
struct bt_hci_cmd_le_set_pa_params {
uint8_t handle;
uint16_t min_interval;
uint16_t max_interval;
uint16_t properties;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_SET_PA_DATA 0x203f
struct bt_hci_cmd_le_set_pa_data {
uint8_t handle;
uint8_t operation;
uint8_t data_len;
uint8_t data[0];
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_SET_PA_ENABLE 0x2040
struct bt_hci_cmd_le_set_pa_enable {
uint8_t enable;
uint8_t handle;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_SET_EXT_SCAN_PARAMS 0x2041
struct bt_hci_cmd_le_set_ext_scan_params {
uint8_t own_addr_type;
uint8_t filter_policy;
uint8_t num_phys;
uint8_t data[0];
} __attribute__ ((packed));
struct bt_hci_le_scan_phy {
uint8_t type;
uint16_t interval;
uint16_t window;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_SET_EXT_SCAN_ENABLE 0x2042
struct bt_hci_cmd_le_set_ext_scan_enable {
uint8_t enable;
uint8_t filter_dup;
uint16_t duration;
uint16_t period;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_EXT_CREATE_CONN 0x2043
struct bt_hci_cmd_le_ext_create_conn {
uint8_t filter_policy;
uint8_t own_addr_type;
uint8_t peer_addr_type;
uint8_t peer_addr[6];
uint8_t phys;
uint8_t data[0];
} __attribute__ ((packed));
struct bt_hci_le_ext_create_conn {
uint16_t scan_interval;
uint16_t scan_window;
uint16_t min_interval;
uint16_t max_interval;
uint16_t latency;
uint16_t supv_timeout;
uint16_t min_length;
uint16_t max_length;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_PA_CREATE_SYNC 0x2044
struct bt_hci_cmd_le_pa_create_sync {
uint8_t options;
uint8_t sid;
uint8_t addr_type;
uint8_t addr[6];
uint16_t skip;
uint16_t sync_timeout;
uint8_t sync_cte_type;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_PA_CREATE_SYNC_CANCEL 0x2045
#define BT_HCI_CMD_LE_PA_TERM_SYNC 0x2046
struct bt_hci_cmd_le_pa_term_sync {
uint16_t sync_handle;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_ADD_DEV_PA_LIST 0x2047
struct bt_hci_cmd_le_add_dev_pa_list {
uint8_t addr_type;
uint8_t addr[6];
uint8_t sid;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_REMOVE_DEV_PA_LIST 0x2048
struct bt_hci_cmd_le_remove_dev_pa_list {
uint8_t addr_type;
uint8_t addr[6];
uint8_t sid;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_CLEAR_PA_LIST 0x2049
#define BT_HCI_CMD_LE_READ_PA_LIST_SIZE 0x204a
struct bt_hci_rsp_le_read_dev_pa_list_size {
uint8_t status;
uint8_t list_size;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_READ_TX_POWER 0x204b
struct bt_hci_rsp_le_read_tx_power {
uint8_t status;
int8_t min_tx_power;
int8_t max_tx_power;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_READ_RF_PATH_COMPENSATION 0x204c
struct bt_hci_rsp_le_read_rf_path_comp {
uint8_t status;
uint16_t rf_tx_path_comp;
uint16_t rf_rx_path_comp;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_WRITE_RF_PATH_COMPENSATION 0x204d
struct bt_hci_cmd_le_write_rf_path_comp {
uint16_t rf_tx_path_comp;
uint16_t rf_rx_path_comp;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_SET_PRIV_MODE 0x204e
struct bt_hci_cmd_le_set_priv_mode {
uint8_t peer_id_addr_type;
uint8_t peer_id_addr[6];
uint8_t priv_mode;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_RECEIVER_TEST_V3 0x204f
struct bt_hci_cmd_le_receiver_test_v3 {
uint8_t rx_chan;
uint8_t phy;
uint8_t mod_index;
uint8_t cte_len;
uint8_t cte_type;
uint8_t duration;
uint8_t num_antenna_id;
uint8_t antenna_ids[0];
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_TX_TEST_V3 0x2050
struct bt_hci_cmd_le_tx_test_v3 {
uint8_t chan;
uint8_t data_len;
uint8_t payload;
uint8_t phy;
uint8_t cte_len;
uint8_t cte_type;
uint8_t duration;
uint8_t num_antenna_id;
uint8_t antenna_ids[0];
} __attribute__ ((packed));
#define BT_HCI_CMD_SET_PA_REC_ENABLE 0x2059
struct bt_hci_cmd_set_pa_rec_enable {
uint16_t sync_handle;
uint8_t enable;
} __attribute__ ((packed));
#define BT_HCI_CMD_PERIODIC_SYNC_TRANS 0x205a
struct bt_hci_cmd_periodic_sync_trans {
uint16_t handle;
uint16_t service_data;
uint16_t sync_handle;
} __attribute__ ((packed));
#define BT_HCI_CMD_PA_SET_INFO_TRANS 0x205b
struct bt_hci_cmd_pa_set_info_trans {
uint16_t handle;
uint16_t service_data;
uint16_t adv_handle;
} __attribute__ ((packed));
#define BT_HCI_CMD_PA_SYNC_TRANS_PARAMS 0x205c
struct bt_hci_cmd_pa_sync_trans_params {
uint16_t handle;
uint8_t mode;
uint16_t skip;
uint16_t sync_timeout;
uint8_t cte_type;
} __attribute__ ((packed));
#define BT_HCI_CMD_DEFAULT_PA_SYNC_TRANS_PARAMS 0x205d
struct bt_hci_cmd_default_pa_sync_trans_params {
uint8_t mode;
uint16_t skip;
uint16_t sync_timeout;
uint8_t cte_type;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_READ_BUFFER_SIZE_V2 0x2060
#define BT_HCI_BIT_LE_READ_BUFFER_SIZE_V2 BT_HCI_CMD_BIT(41, 5)
struct bt_hci_rsp_le_read_buffer_size_v2 {
uint8_t status;
uint16_t acl_mtu;
uint8_t acl_max_pkt;
uint16_t iso_mtu;
uint8_t iso_max_pkt;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_READ_ISO_TX_SYNC 0x2061
#define BT_HCI_BIT_LE_READ_ISO_TX_SYNC BT_HCI_CMD_BIT(41, 6)
struct bt_hci_cmd_le_read_iso_tx_sync {
uint16_t handle;
} __attribute__ ((packed));
struct bt_hci_rsp_le_read_iso_tx_sync {
uint8_t status;
uint16_t handle;
uint16_t seq;
uint32_t timestamp;
uint8_t offset[3];
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_SET_CIG_PARAMS 0x2062
#define BT_HCI_BIT_LE_SET_CIG_PARAMS BT_HCI_CMD_BIT(41, 7)
struct bt_hci_cis_params {
uint8_t cis_id;
uint16_t c_sdu;
uint16_t p_sdu;
uint8_t c_phy;
uint8_t p_phy;
uint8_t c_rtn;
uint8_t p_rtn;
} __attribute__ ((packed));
struct bt_hci_cmd_le_set_cig_params {
uint8_t cig_id;
uint8_t c_interval[3];
uint8_t p_interval[3];
uint8_t sca;
uint8_t packing;
uint8_t framing;
uint16_t c_latency;
uint16_t p_latency;
uint8_t num_cis;
struct bt_hci_cis_params cis[0];
} __attribute__ ((packed));
struct bt_hci_rsp_le_set_cig_params {
uint8_t status;
uint8_t cig_id;
uint8_t num_handles;
uint16_t handle[0];
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_SET_CIG_PARAMS_TEST 0x2063
#define BT_HCI_BIT_LE_SET_CIG_PARAMS_TEST BT_HCI_CMD_BIT(42, 0)
struct bt_hci_cis_params_test {
uint8_t cis_id;
uint8_t nse;
uint16_t c_sdu;
uint16_t p_sdu;
uint16_t c_pdu;
uint16_t p_pdu;
uint8_t c_phy;
uint8_t p_phy;
uint8_t c_bn;
uint8_t p_bn;
} __attribute__ ((packed));
struct bt_hci_cmd_le_set_cig_params_test {
uint8_t cig_id;
uint8_t c_interval[3];
uint8_t p_interval[3];
uint8_t c_ft;
uint8_t p_ft;
uint16_t iso_interval;
uint8_t sca;
uint8_t packing;
uint8_t framing;
uint8_t num_cis;
struct bt_hci_cis_params_test cis[0];
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_CREATE_CIS 0x2064
#define BT_HCI_BIT_LE_CREATE_CIS BT_HCI_CMD_BIT(42, 1)
struct bt_hci_cis {
uint16_t cis_handle;
uint16_t acl_handle;
} __attribute__ ((packed));
struct bt_hci_cmd_le_create_cis {
uint8_t num_cis;
struct bt_hci_cis cis[0];
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_REMOVE_CIG 0x2065
#define BT_HCI_BIT_LE_REMOVE_CIG BT_HCI_CMD_BIT(42, 2)
struct bt_hci_cmd_le_remove_cig {
uint8_t cig_id;
} __attribute__ ((packed));
struct bt_hci_rsp_le_remove_cig {
uint8_t status;
uint8_t cig_id;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_ACCEPT_CIS 0x2066
#define BT_HCI_BIT_LE_ACCEPT_CIS BT_HCI_CMD_BIT(42, 3)
struct bt_hci_cmd_le_accept_cis {
uint16_t handle;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_REJECT_CIS 0x2067
#define BT_HCI_BIT_LE_REJECT_CIS BT_HCI_CMD_BIT(42, 4)
struct bt_hci_cmd_le_reject_cis {
uint16_t handle;
uint8_t reason;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_CREATE_BIG 0x2068
#define BT_HCI_BIT_LE_CREATE_BIG BT_HCI_CMD_BIT(42, 5)
struct bt_hci_bis {
uint8_t sdu_interval[3];
uint16_t sdu;
uint16_t latency;
uint8_t rtn;
uint8_t phy;
uint8_t packing;
uint8_t framing;
uint8_t encryption;
uint8_t bcode[16];
} __attribute__ ((packed));
struct bt_hci_cmd_le_create_big {
uint8_t handle;
uint8_t adv_handle;
uint8_t num_bis;
struct bt_hci_bis bis;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_CREATE_BIG_TEST 0x2069
#define BT_HCI_BIT_LE_CREATE_BIG_TEST BT_HCI_CMD_BIT(42, 6)
struct bt_hci_bis_test {
uint8_t sdu_interval[3];
uint16_t iso_interval;
uint8_t nse;
uint16_t sdu;
uint8_t pdu;
uint8_t phy;
uint8_t packing;
uint8_t framing;
uint8_t bn;
uint8_t irc;
uint8_t pto;
uint8_t adv_handle;
uint8_t encryption;
uint8_t bcode[16];
} __attribute__ ((packed));
struct bt_hci_cmd_le_create_big_test {
uint8_t big_id;
uint8_t adv_handle;
uint8_t num_bis;
struct bt_hci_bis_test bis[0];
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_TERM_BIG 0x206a
#define BT_HCI_BIT_LE_TERM_BIG BT_HCI_CMD_BIT(42, 7)
struct bt_hci_cmd_le_term_big {
uint8_t handle;
uint8_t reason;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_BIG_CREATE_SYNC 0x206b
#define BT_HCI_BIT_LE_BIG_CREATE_SYNC BT_HCI_CMD_BIT(43, 0)
struct bt_hci_bis_sync {
uint8_t index;
} __attribute__ ((packed));
struct bt_hci_cmd_le_big_create_sync {
uint8_t handle;
uint16_t sync_handle;
uint8_t encryption;
uint8_t bcode[16];
uint8_t mse;
uint16_t timeout;
uint8_t num_bis;
struct bt_hci_bis_sync bis[0];
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_BIG_TERM_SYNC 0x206c
#define BT_HCI_BIT_LE_BIG_TERM_SYNC BT_HCI_CMD_BIT(43, 1)
struct bt_hci_cmd_le_big_term_sync {
uint8_t handle;
} __attribute__ ((packed));
struct bt_hci_rsp_le_big_term_sync {
uint8_t status;
uint8_t handle;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_REQ_PEER_SCA 0x206d
#define BT_HCI_BIT_LE_REQ_PEER_SCA BT_HCI_CMD_BIT(43, 2)
struct bt_hci_cmd_le_req_peer_sca {
uint16_t handle;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_SETUP_ISO_PATH 0x206e
#define BT_HCI_BIT_LE_SETUP_ISO_PATH BT_HCI_CMD_BIT(43, 3)
struct bt_hci_cmd_le_setup_iso_path {
uint16_t handle;
uint8_t direction;
uint8_t path;
uint8_t codec;
uint16_t codec_cid;
uint16_t codec_vid;
uint8_t delay[3];
uint8_t codec_cfg_len;
uint8_t codec_cfg[0];
} __attribute__ ((packed));
struct bt_hci_rsp_le_setup_iso_path {
uint8_t status;
uint16_t handle;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_REMOVE_ISO_PATH 0x206f
#define BT_HCI_BIT_LE_REMOVE_ISO_PATH BT_HCI_CMD_BIT(43, 4)
struct bt_hci_cmd_le_remove_iso_path {
uint16_t handle;
uint8_t direction;
} __attribute__ ((packed));
#define BT_HCI_CMD_LE_ISO_TX_TEST 0x2070
#define BT_HCI_BIT_LE_ISO_TX_TEST BT_HCI_CMD_BIT(43, 5)
#define BT_HCI_CMD_LE_ISO_RX_TEST 0x2071
#define BT_HCI_BIT_LE_ISO_RX_TEST BT_HCI_CMD_BIT(43, 6)
#define BT_HCI_CMD_LE_ISO_READ_TEST_COUNTER 0x2072
#define BT_HCI_BIT_LE_ISO_READ_TEST_COUNTER BT_HCI_CMD_BIT(43, 7)
#define BT_HCI_CMD_LE_ISO_TEST_END 0x2073
#define BT_HCI_BIT_LE_ISO_TEST_END BT_HCI_CMD_BIT(44, 0)
#define BT_HCI_CMD_LE_SET_HOST_FEATURE 0x2074
#define BT_HCI_BIT_LE_SET_HOST_FEATURE BT_HCI_CMD_BIT(44, 1)
struct bt_hci_cmd_le_set_host_feature {
uint8_t bit_number;
uint8_t bit_value;
} __attribute__ ((packed));
#define BT_HCI_EVT_INQUIRY_COMPLETE 0x01
struct bt_hci_evt_inquiry_complete {
uint8_t status;
} __attribute__ ((packed));
#define BT_HCI_EVT_INQUIRY_RESULT 0x02
struct bt_hci_evt_inquiry_result {
uint8_t num_resp;
uint8_t bdaddr[6];
uint8_t pscan_rep_mode;
uint8_t pscan_period_mode;
uint8_t pscan_mode;
uint8_t dev_class[3];
uint16_t clock_offset;
} __attribute__ ((packed));
#define BT_HCI_EVT_CONN_COMPLETE 0x03
struct bt_hci_evt_conn_complete {
uint8_t status;
uint16_t handle;
uint8_t bdaddr[6];
uint8_t link_type;
uint8_t encr_mode;
} __attribute__ ((packed));
#define BT_HCI_EVT_CONN_REQUEST 0x04
struct bt_hci_evt_conn_request {
uint8_t bdaddr[6];
uint8_t dev_class[3];
uint8_t link_type;
} __attribute__ ((packed));
#define BT_HCI_EVT_DISCONNECT_COMPLETE 0x05
struct bt_hci_evt_disconnect_complete {
uint8_t status;
uint16_t handle;
uint8_t reason;
} __attribute__ ((packed));
#define BT_HCI_EVT_AUTH_COMPLETE 0x06
struct bt_hci_evt_auth_complete {
uint8_t status;
uint16_t handle;
} __attribute__ ((packed));
#define BT_HCI_EVT_REMOTE_NAME_REQUEST_COMPLETE 0x07
struct bt_hci_evt_remote_name_request_complete {
uint8_t status;
uint8_t bdaddr[6];
uint8_t name[248];
} __attribute__ ((packed));
#define BT_HCI_EVT_ENCRYPT_CHANGE 0x08
struct bt_hci_evt_encrypt_change {
uint8_t status;
uint16_t handle;
uint8_t encr_mode;
} __attribute__ ((packed));
#define BT_HCI_EVT_CHANGE_CONN_LINK_KEY_COMPLETE 0x09
struct bt_hci_evt_change_conn_link_key_complete {
uint8_t status;
uint16_t handle;
} __attribute__ ((packed));
#define BT_HCI_EVT_LINK_KEY_TYPE_CHANGED 0x0a
struct bt_hci_evt_link_key_type_changed {
uint8_t status;
uint16_t handle;
uint8_t key_flag;
} __attribute__ ((packed));
#define BT_HCI_EVT_REMOTE_FEATURES_COMPLETE 0x0b
struct bt_hci_evt_remote_features_complete {
uint8_t status;
uint16_t handle;
uint8_t features[8];
} __attribute__ ((packed));
#define BT_HCI_EVT_REMOTE_VERSION_COMPLETE 0x0c
struct bt_hci_evt_remote_version_complete {
uint8_t status;
uint16_t handle;
uint8_t lmp_ver;
uint16_t manufacturer;
uint16_t lmp_subver;
} __attribute__ ((packed));
#define BT_HCI_EVT_QOS_SETUP_COMPLETE 0x0d
struct bt_hci_evt_qos_setup_complete {
uint8_t status;
uint16_t handle;
uint8_t flags;
uint8_t service_type;
uint32_t token_rate;
uint32_t peak_bandwidth;
uint32_t latency;
uint32_t delay_variation;
} __attribute__ ((packed));
#define BT_HCI_EVT_CMD_COMPLETE 0x0e
struct bt_hci_evt_cmd_complete {
uint8_t ncmd;
uint16_t opcode;
} __attribute__ ((packed));
#define BT_HCI_EVT_CMD_STATUS 0x0f
struct bt_hci_evt_cmd_status {
uint8_t status;
uint8_t ncmd;
uint16_t opcode;
} __attribute__ ((packed));
#define BT_HCI_EVT_HARDWARE_ERROR 0x10
struct bt_hci_evt_hardware_error {
uint8_t code;
} __attribute__ ((packed));
#define BT_HCI_EVT_FLUSH_OCCURRED 0x11
struct bt_hci_evt_flush_occurred {
uint16_t handle;
} __attribute__ ((packed));
#define BT_HCI_EVT_ROLE_CHANGE 0x12
struct bt_hci_evt_role_change {
uint8_t status;
uint8_t bdaddr[6];
uint8_t role;
} __attribute__ ((packed));
#define BT_HCI_EVT_NUM_COMPLETED_PACKETS 0x13
struct bt_hci_evt_num_completed_packets {
uint8_t num_handles;
uint16_t handle;
uint16_t count;
} __attribute__ ((packed));
#define BT_HCI_EVT_MODE_CHANGE 0x14
struct bt_hci_evt_mode_change {
uint8_t status;
uint16_t handle;
uint8_t mode;
uint16_t interval;
} __attribute__ ((packed));
#define BT_HCI_EVT_RETURN_LINK_KEYS 0x15
struct bt_hci_evt_return_link_keys {
uint8_t num_keys;
uint8_t keys[0];
} __attribute__ ((packed));
#define BT_HCI_EVT_PIN_CODE_REQUEST 0x16
struct bt_hci_evt_pin_code_request {
uint8_t bdaddr[6];
} __attribute__ ((packed));
#define BT_HCI_EVT_LINK_KEY_REQUEST 0x17
struct bt_hci_evt_link_key_request {
uint8_t bdaddr[6];
} __attribute__ ((packed));
#define BT_HCI_EVT_LINK_KEY_NOTIFY 0x18
struct bt_hci_evt_link_key_notify {
uint8_t bdaddr[6];
uint8_t link_key[16];
uint8_t key_type;
} __attribute__ ((packed));
#define BT_HCI_EVT_LOOPBACK_COMMAND 0x19
#define BT_HCI_EVT_DATA_BUFFER_OVERFLOW 0x1a
struct bt_hci_evt_data_buffer_overflow {
uint8_t link_type;
} __attribute__ ((packed));
#define BT_HCI_EVT_MAX_SLOTS_CHANGE 0x1b
struct bt_hci_evt_max_slots_change {
uint16_t handle;
uint8_t max_slots;
} __attribute__ ((packed));
#define BT_HCI_EVT_CLOCK_OFFSET_COMPLETE 0x1c
struct bt_hci_evt_clock_offset_complete {
uint8_t status;
uint16_t handle;
uint16_t clock_offset;
} __attribute__ ((packed));
#define BT_HCI_EVT_CONN_PKT_TYPE_CHANGED 0x1d
struct bt_hci_evt_conn_pkt_type_changed {
uint8_t status;
uint16_t handle;
uint16_t pkt_type;
} __attribute__ ((packed));
#define BT_HCI_EVT_QOS_VIOLATION 0x1e
struct bt_hci_evt_qos_violation {
uint16_t handle;
} __attribute__ ((packed));
#define BT_HCI_EVT_PSCAN_MODE_CHANGE 0x1f
struct bt_hci_evt_pscan_mode_change {
uint8_t bdaddr[6];
uint8_t pscan_mode;
} __attribute__ ((packed));
#define BT_HCI_EVT_PSCAN_REP_MODE_CHANGE 0x20
struct bt_hci_evt_pscan_rep_mode_change {
uint8_t bdaddr[6];
uint8_t pscan_rep_mode;
} __attribute__ ((packed));
#define BT_HCI_EVT_FLOW_SPEC_COMPLETE 0x21
struct bt_hci_evt_flow_spec_complete {
uint8_t status;
uint16_t handle;
uint8_t flags;
uint8_t direction;
uint8_t service_type;
uint32_t token_rate;
uint32_t token_bucket_size;
uint32_t peak_bandwidth;
uint32_t access_latency;
} __attribute__ ((packed));