/* * Copyright (C) 2014 BlueKitchen GmbH * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * 3. Neither the name of the copyright holders nor the names of * contributors may be used to endorse or promote products derived * from this software without specific prior written permission. * 4. Any redistribution, use, or modification is done solely for * personal benefit and not for any commercial purpose or for * monetary gain. * * THIS SOFTWARE IS PROVIDED BY BLUEKITCHEN GMBH AND CONTRIBUTORS * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL MATTHIAS * RINGWALD OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. * * Please inquire about commercial licensing options at * contact@bluekitchen-gmbh.com * */ /* * hci_cmds.h * * Created by Matthias Ringwald on 7/23/09. */ #ifndef __HCI_CMDS_H #define __HCI_CMDS_H #include #if defined __cplusplus extern "C" { #endif /** * packet types - used in BTstack and over the H4 UART interface */ #define HCI_COMMAND_DATA_PACKET 0x01 #define HCI_ACL_DATA_PACKET 0x02 #define HCI_SCO_DATA_PACKET 0x03 #define HCI_EVENT_PACKET 0x04 // extension for client/server communication #define DAEMON_EVENT_PACKET 0x05 // L2CAP data #define L2CAP_DATA_PACKET 0x06 // RFCOMM data #define RFCOMM_DATA_PACKET 0x07 // Attribute protocol data #define ATT_DATA_PACKET 0x08 // Security Manager protocol data #define SM_DATA_PACKET 0x09 // SDP query result // format: type (8), record_id (16), attribute_id (16), attribute_length (16), attribute_value (max 1k) #define SDP_CLIENT_PACKET 0x0a // BNEP data #define BNEP_DATA_PACKET 0x0b // Unicast Connectionless Data #define UCD_DATA_PACKET 0x0c // debug log messages #define LOG_MESSAGE_PACKET 0xfc // Fixed PSM numbers #define PSM_SDP 0x01 #define PSM_RFCOMM 0x03 #define PSM_HID_CONTROL 0x11 #define PSM_HID_INTERRUPT 0x13 #define PSM_BNEP 0x0F // Events from host controller to host /** * @format 1 * @param status */ #define HCI_EVENT_INQUIRY_COMPLETE 0x01 // no format yet, can contain multiple results /** * @format 1B11132 * @param num_responses * @param bd_addr * @param page_scan_repetition_mode * @param reserved1 * @param reserved2 * @param class_of_device * @param clock_offset */ #define HCI_EVENT_INQUIRY_RESULT 0x02 /** * @format 12B11 * @param status * @param connection_handle * @param bd_addr * @param link_type * @param encryption_enabled */ #define HCI_EVENT_CONNECTION_COMPLETE 0x03 /** * @format B31 * @param bd_addr * @param class_of_device * @param link_type */ #define HCI_EVENT_CONNECTION_REQUEST 0x04 /** * @format 121 * @param status * @param connection_handle * @param reason */ #define HCI_EVENT_DISCONNECTION_COMPLETE 0x05 /** * @format 12 * @param status * @param connection_handle */ #define HCI_EVENT_AUTHENTICATION_COMPLETE_EVENT 0x06 /** * @format 1BN * @param status * @param bd_addr * @param remote_name */ #define HCI_EVENT_REMOTE_NAME_REQUEST_COMPLETE 0x07 /** * @format 121 * @param status * @param connection_handle * @param encryption_enabled */ #define HCI_EVENT_ENCRYPTION_CHANGE 0x08 /** * @format 12 * @param status * @param connection_handle */ #define HCI_EVENT_CHANGE_CONNECTION_LINK_KEY_COMPLETE 0x09 /** * @format 121 * @param status * @param connection_handle * @param key_flag */ #define HCI_EVENT_MASTER_LINK_KEY_COMPLETE 0x0A #define HCI_EVENT_READ_REMOTE_SUPPORTED_FEATURES_COMPLETE 0x0B #define HCI_EVENT_READ_REMOTE_VERSION_INFORMATION_COMPLETE 0x0C #define HCI_EVENT_QOS_SETUP_COMPLETE 0x0D /** * @format 12R * @param num_hci_command_packets * @param command_opcode * @param return_parameters */ #define HCI_EVENT_COMMAND_COMPLETE 0x0E /** * @format 112 * @param status * @param num_hci_command_packets * @param command_opcode */ #define HCI_EVENT_COMMAND_STATUS 0x0F /** * @format 121 * @param hardware_code */ #define HCI_EVENT_HARDWARE_ERROR 0x10 #define HCI_EVENT_FLUSH_OCCURED 0x11 #define HCI_EVENT_ROLE_CHANGE 0x12 #define HCI_EVENT_NUMBER_OF_COMPLETED_PACKETS 0x13 #define HCI_EVENT_MODE_CHANGE_EVENT 0x14 #define HCI_EVENT_RETURN_LINK_KEYS 0x15 #define HCI_EVENT_PIN_CODE_REQUEST 0x16 #define HCI_EVENT_LINK_KEY_REQUEST 0x17 #define HCI_EVENT_LINK_KEY_NOTIFICATION 0x18 #define HCI_EVENT_DATA_BUFFER_OVERFLOW 0x1A #define HCI_EVENT_MAX_SLOTS_CHANGED 0x1B #define HCI_EVENT_READ_CLOCK_OFFSET_COMPLETE 0x1C #define HCI_EVENT_PACKET_TYPE_CHANGED 0x1D /** * @format 1B11321 * @param num_responses * @param bd_addr * @param page_scan_repetition_mode * @param reserved * @param class_of_device * @param clock_offset * @param rssi */ #define HCI_EVENT_INQUIRY_RESULT_WITH_RSSI 0x22 /** * @format 1HB111221 * @param status * @param handle * @param bd_addr * @param link_type * @param transmission_interval * @param retransmission_interval * @param rx_packet_length * @param tx_packet_length * @param air_mode */ #define HCI_EVENT_SYNCHRONOUS_CONNECTION_COMPLETE 0x2C // TODO: serialize extended_inquiry_response and provide parser /** * @format 1B11321 * @param num_responses * @param bd_addr * @param page_scan_repetition_mode * @param reserved * @param class_of_device * @param clock_offset * @param rssi */ #define HCI_EVENT_EXTENDED_INQUIRY_RESPONSE 0x2F #define HCI_EVENT_IO_CAPABILITY_REQUEST 0x31 #define HCI_EVENT_IO_CAPABILITY_RESPONSE 0x32 #define HCI_EVENT_USER_CONFIRMATION_REQUEST 0x33 #define HCI_EVENT_USER_PASSKEY_REQUEST 0x34 #define HCI_EVENT_REMOTE_OOB_DATA_REQUEST 0x35 #define HCI_EVENT_SIMPLE_PAIRING_COMPLETE 0x36 #define HCI_EVENT_LE_META 0x3E /** * @format 11211B2221 * @param subevent_code * @param status * @param connection_handle * @param role * @param peer_address_type * @param peer_address * @param conn_interval * @param conn_latency * @param supervision_timeout * @param master_clock_accuracy */ #define HCI_SUBEVENT_LE_CONNECTION_COMPLETE 0x01 #define HCI_SUBEVENT_LE_ADVERTISING_REPORT 0x02 #define HCI_SUBEVENT_LE_CONNECTION_UPDATE_COMPLETE 0x03 #define HCI_SUBEVENT_LE_READ_REMOTE_USED_FEATURES_COMPLETE 0x04 #define HCI_SUBEVENT_LE_LONG_TERM_KEY_REQUEST 0x05 // last used HCI_EVENT in 2.1 is 0x3d // last used HCI_EVENT in 4.1 is 0x57 /** * @format 1 * @param state */ #define BTSTACK_EVENT_STATE 0x60 // data: event(8), len(8), nr hci connections #define BTSTACK_EVENT_NR_CONNECTIONS_CHANGED 0x61 /** * @format */ #define BTSTACK_EVENT_POWERON_FAILED 0x62 /** * @format 112 * @param major * @param minor @ @param revision */ #define BTSTACK_EVENT_VERSION 0x63 // data: system bluetooth on/off (bool) #define BTSTACK_EVENT_SYSTEM_BLUETOOTH_ENABLED 0x64 // data: event (8), len(8), status (8) == 0, address (48), name (1984 bits = 248 bytes) #define BTSTACK_EVENT_REMOTE_NAME_CACHED 0x65 // data: discoverable enabled (bool) #define BTSTACK_EVENT_DISCOVERABLE_ENABLED 0x66 // Daemon Events used internally // data: event(8) #define DAEMON_EVENT_CONNECTION_OPENED 0x68 // data: event(8) #define DAEMON_EVENT_CONNECTION_CLOSED 0x69 // data: event(8), nr_connections(8) #define DAEMON_NR_CONNECTIONS_CHANGED 0x6A // data: event(8) #define DAEMON_EVENT_NEW_RFCOMM_CREDITS 0x6B // data: event(8) #define DAEMON_EVENT_HCI_PACKET_SENT 0x6C // L2CAP EVENTS // data: event (8), len(8), status (8), address(48), handle (16), psm (16), local_cid(16), remote_cid (16), local_mtu(16), remote_mtu(16), flush_timeout(16) #define L2CAP_EVENT_CHANNEL_OPENED 0x70 // data: event (8), len(8), channel (16) #define L2CAP_EVENT_CHANNEL_CLOSED 0x71 // data: event (8), len(8), address(48), handle (16), psm (16), local_cid(16), remote_cid (16) #define L2CAP_EVENT_INCOMING_CONNECTION 0x72 // data: event(8), len(8), handle(16) #define L2CAP_EVENT_TIMEOUT_CHECK 0x73 // data: event(8), len(8), local_cid(16), credits(8) #define L2CAP_EVENT_CREDITS 0x74 // data: event(8), len(8), status (8), psm (16) #define L2CAP_EVENT_SERVICE_REGISTERED 0x75 // data: event(8), len(8), handle(16), interval min(16), interval max(16), latency(16), timeout multiplier(16) #define L2CAP_EVENT_CONNECTION_PARAMETER_UPDATE_REQUEST 0x76 // data: event(8), len(8), handle(16), result (16) (0 == ok, 1 == fail) #define L2CAP_EVENT_CONNECTION_PARAMETER_UPDATE_RESPONSE 0x77 // RFCOMM EVENTS /** * @format 1B2122 * @param status * @param bd_addr * @param con_handle * @param server_channel * @param rfcomm_cid * @param max_frame_size */ #define RFCOMM_EVENT_OPEN_CHANNEL_COMPLETE 0x80 /** * @format 2 * @param rfcomm_cid */ #define RFCOMM_EVENT_CHANNEL_CLOSED 0x81 /** * @format B12 * @param bd_addr * @param server_channel * @param rfcomm_cid */ #define RFCOMM_EVENT_INCOMING_CONNECTION 0x82 /** * @format 21 * @param rfcomm_cid * @param line_status */ #define RFCOMM_EVENT_REMOTE_LINE_STATUS 0x83 /** * @format 21 * @param rfcomm_cid * @param credits */ #define RFCOMM_EVENT_CREDITS 0x84 /** * @format 11 * @param status * @param channel_id */ #define RFCOMM_EVENT_SERVICE_REGISTERED 0x85 /** * @format 11 * @param status * @param server_channel_id */ #define RFCOMM_EVENT_PERSISTENT_CHANNEL 0x86 // data: event (8), len(8), rfcomm_cid (16), modem status (8) /** * @format 21 * @param rfcomm_cid * @param modem_status */ #define RFCOMM_EVENT_REMOTE_MODEM_STATUS 0x87 // data: event (8), len(8), rfcomm_cid (16), rpn_data_t (67) /** * TODO: format for variable data * @param rfcomm_cid * @param rpn_data */ #define RFCOMM_EVENT_PORT_CONFIGURATION 0x88 // data: event(8), len(8), status(8), service_record_handle(32) /** * @format 14 * @param status * @param service_record_handle */ #define SDP_SERVICE_REGISTERED 0x90 // data: event(8), len(8), status(8) /** * @format 1 * @param status */ #define SDP_QUERY_COMPLETE 0x91 // data: event(8), len(8), rfcomm channel(8), name(var) /** * @format 1T * @param rfcomm_channel * @param name * @brief SDP_QUERY_RFCOMM_SERVICE 0x92 */ #define SDP_QUERY_RFCOMM_SERVICE 0x92 // data: event(8), len(8), record nr(16), attribute id(16), attribute value(var) /** * TODO: format for variable data * @param record_nr * @param attribute_id * @param attribute_value */ #define SDP_QUERY_ATTRIBUTE_VALUE 0x93 // not provided by daemon, only used for internal testing #define SDP_QUERY_SERVICE_RECORD_HANDLE 0x94 /** * @format H1 * @param handle * @param status */ #define GATT_QUERY_COMPLETE 0xA0 /** * @format HX * @param handle * @param service */ #define GATT_SERVICE_QUERY_RESULT 0xA1 /** * @format HY * @param handle * @param characteristic */ #define GATT_CHARACTERISTIC_QUERY_RESULT 0xA2 /** * @format HX * @param handle * @param service */ #define GATT_INCLUDED_SERVICE_QUERY_RESULT 0xA3 /** * @format HZ * @param handle * @param characteristic_descriptor */ #define GATT_ALL_CHARACTERISTIC_DESCRIPTORS_QUERY_RESULT 0xA4 /** * @format H2LV * @param handle * @param value_handle * @param value_length * @param value */ #define GATT_CHARACTERISTIC_VALUE_QUERY_RESULT 0xA5 /** * @format H2LV * @param handle * @param value_handle * @param value_length * @param value */ #define GATT_LONG_CHARACTERISTIC_VALUE_QUERY_RESULT 0xA6 /** * @format H2LV * @param handle * @param value_handle * @param value_length * @param value */ #define GATT_NOTIFICATION 0xA7 /** * @format H2LV * @param handle * @param value_handle * @param value_length * @param value */ #define GATT_INDICATION 0xA8 #define GATT_CHARACTERISTIC_DESCRIPTOR_QUERY_RESULT 0xA9 #define GATT_LONG_CHARACTERISTIC_DESCRIPTOR_QUERY_RESULT 0xAA /** * @format H2 * @param handle * @param MTU */ #define GATT_MTU 0xAB /** * @format H2 * @param handle * @param MTU */ #define ATT_MTU_EXCHANGE_COMPLETE 0xB5 // data: event(8), len(8), status (8), hci_handle (16), attribute_handle (16) #define ATT_HANDLE_VALUE_INDICATION_COMPLETE 0xB6 // data: event(8), len(8), status (8), bnep service uuid (16) #define BNEP_EVENT_SERVICE_REGISTERED 0xC0 // data: event(8), len(8), status (8), bnep source uuid (16), bnep destination uuid (16), mtu (16), remote_address (48) #define BNEP_EVENT_OPEN_CHANNEL_COMPLETE 0xC1 // data: event(8), len(8), status (8), bnep source uuid (16), bnep destination uuid (16), mtu (16), remote_address (48) #define BNEP_EVENT_INCOMING_CONNECTION 0xC2 // data: event(8), len(8), bnep source uuid (16), bnep destination uuid (16), remote_address (48) #define BNEP_EVENT_CHANNEL_CLOSED 0xC3 // data: event(8), len(8), bnep source uuid (16), bnep destination uuid (16), remote_address (48), channel state (8) #define BNEP_EVENT_CHANNEL_TIMEOUT 0xC4 // data: event(8), len(8) #define BNEP_EVENT_READY_TO_SEND 0xC5 // data: event(8), address_type(8), address (48), [number(32)] #define SM_JUST_WORKS_REQUEST 0xD0 #define SM_JUST_WORKS_CANCEL 0xD1 #define SM_PASSKEY_DISPLAY_NUMBER 0xD2 #define SM_PASSKEY_DISPLAY_CANCEL 0xD3 #define SM_PASSKEY_INPUT_NUMBER 0xD4 #define SM_PASSKEY_INPUT_CANCEL 0xD5 #define SM_IDENTITY_RESOLVING_STARTED 0xD6 #define SM_IDENTITY_RESOLVING_FAILED 0xD7 #define SM_IDENTITY_RESOLVING_SUCCEEDED 0xD8 #define SM_AUTHORIZATION_REQUEST 0xD9 #define SM_AUTHORIZATION_RESULT 0xDA // GAP // data: event(8), len(8), hci_handle (16), security_level (8) #define GAP_SECURITY_LEVEL 0xE0 // data: event(8), len(8), status (8), bd_addr(48) #define GAP_DEDICATED_BONDING_COMPLETED 0xE1 /** * @format 11B1JV * @param advertising_event_type * @param address_type * @param address * @param rssi * @param data_length * @param data */ #define GAP_LE_ADVERTISING_REPORT 0xE2 #define HCI_EVENT_HSP_META 0xE8 #define HSP_SUBEVENT_AUDIO_CONNECTION_COMPLETE 0x01 #define HSP_SUBEVENT_AUDIO_DISCONNECTION_COMPLETE 0x02 #define HSP_SUBEVENT_MICROPHONE_GAIN_CHANGED 0x03 #define HSP_SUBEVENT_SPEAKER_GAIN_CHANGED 0x04 #define HSP_SUBEVENT_HS_COMMAND 0x05 #define HSP_SUBEVENT_AG_INDICATION 0x06 #define HSP_SUBEVENT_ERROR 0x07 #define HSP_SUBEVENT_RING 0x08 // ANCS Client #define ANCS_CLIENT_CONNECTED 0xF0 #define ANCS_CLIENT_NOTIFICATION 0xF1 #define ANCS_CLIENT_DISCONNECTED 0xF2 // #define HCI_EVENT_HFP_META 0xxx // #define HCI_EVENT_GATT_META 0xxx // #define HCI_EVENT_SDP_META 0xxx // #define HCI_EVENT_ANCS_META 0xxx // #define HCI_EVENT_SM_META 0xxx // #define HCI_EVENT_GAP_META 0xxx // #define HCI_EVENT_BNEP_META 0xxx // #define HCI_EVENT_PAN_META 0xxx #define HCI_EVENT_VENDOR_SPECIFIC 0xFF // // Error Codes // // from Bluetooth Core Specification #define ERROR_CODE_UNKNOWN_CONNECTION_IDENTIFIER 0x02 #define ERROR_CODE_AUTHENTICATION_FAILURE 0x05 #define ERROR_CODE_COMMAND_DISALLOWED 0x0C #define ERROR_CODE_PAIRING_NOT_ALLOWED 0x18 #define ERROR_CODE_INSUFFICIENT_SECURITY 0x2F // last error code in 2.1 is 0x38 - we start with 0x50 for BTstack errors #define BTSTACK_CONNECTION_TO_BTDAEMON_FAILED 0x50 #define BTSTACK_ACTIVATION_FAILED_SYSTEM_BLUETOOTH 0x51 #define BTSTACK_ACTIVATION_POWERON_FAILED 0x52 #define BTSTACK_ACTIVATION_FAILED_UNKNOWN 0x53 #define BTSTACK_NOT_ACTIVATED 0x54 #define BTSTACK_BUSY 0x55 #define BTSTACK_MEMORY_ALLOC_FAILED 0x56 #define BTSTACK_ACL_BUFFERS_FULL 0x57 // l2cap errors - enumeration by the command that created them #define L2CAP_COMMAND_REJECT_REASON_COMMAND_NOT_UNDERSTOOD 0x60 #define L2CAP_COMMAND_REJECT_REASON_SIGNALING_MTU_EXCEEDED 0x61 #define L2CAP_COMMAND_REJECT_REASON_INVALID_CID_IN_REQUEST 0x62 #define L2CAP_CONNECTION_RESPONSE_RESULT_SUCCESSFUL 0x63 #define L2CAP_CONNECTION_RESPONSE_RESULT_PENDING 0x64 #define L2CAP_CONNECTION_RESPONSE_RESULT_REFUSED_PSM 0x65 #define L2CAP_CONNECTION_RESPONSE_RESULT_REFUSED_SECURITY 0x66 #define L2CAP_CONNECTION_RESPONSE_RESULT_REFUSED_RESOURCES 0x67 #define L2CAP_CONNECTION_RESPONSE_RESULT_RTX_TIMEOUT 0x68 #define L2CAP_SERVICE_ALREADY_REGISTERED 0x69 #define L2CAP_DATA_LEN_EXCEEDS_REMOTE_MTU 0x6A #define RFCOMM_MULTIPLEXER_STOPPED 0x70 #define RFCOMM_CHANNEL_ALREADY_REGISTERED 0x71 #define RFCOMM_NO_OUTGOING_CREDITS 0x72 #define RFCOMM_AGGREGATE_FLOW_OFF 0x73 #define RFCOMM_DATA_LEN_EXCEEDS_MTU 0x74 #define SDP_HANDLE_ALREADY_REGISTERED 0x80 #define SDP_QUERY_INCOMPLETE 0x81 #define SDP_SERVICE_NOT_FOUND 0x82 #define ATT_HANDLE_VALUE_INDICATION_IN_PORGRESS 0x90 #define ATT_HANDLE_VALUE_INDICATION_TIMEOUT 0x91 #define GATT_CLIENT_NOT_CONNECTED 0x93 #define GATT_CLIENT_BUSY 0x94 #define BNEP_SERVICE_ALREADY_REGISTERED 0xA0 #define BNEP_CHANNEL_NOT_CONNECTED 0xA1 #define BNEP_DATA_LEN_EXCEEDS_MTU 0xA2 typedef enum { BLE_PERIPHERAL_OK = 0xA0, BLE_PERIPHERAL_IN_WRONG_STATE, BLE_PERIPHERAL_DIFFERENT_CONTEXT_FOR_ADDRESS_ALREADY_EXISTS, BLE_PERIPHERAL_NOT_CONNECTED, BLE_VALUE_TOO_LONG, BLE_PERIPHERAL_BUSY, BLE_CHARACTERISTIC_NOTIFICATION_NOT_SUPPORTED, BLE_CHARACTERISTIC_INDICATION_NOT_SUPPORTED } le_command_status_t; /** * Default INQ Mode */ #define HCI_INQUIRY_LAP 0x9E8B33L // 0x9E8B33: General/Unlimited Inquiry Access Code (GIAC) /** * SSP IO Capabilities - if capability is set, BTstack answers IO Capability Requests */ #define SSP_IO_CAPABILITY_DISPLAY_ONLY 0 #define SSP_IO_CAPABILITY_DISPLAY_YES_NO 1 #define SSP_IO_CAPABILITY_KEYBOARD_ONLY 2 #define SSP_IO_CAPABILITY_NO_INPUT_NO_OUTPUT 3 #define SSP_IO_CAPABILITY_UNKNOWN 0xff /** * SSP Authentication Requirements, see IO Capability Request Reply Commmand */ // Numeric comparison with automatic accept allowed. #define SSP_IO_AUTHREQ_MITM_PROTECTION_NOT_REQUIRED_NO_BONDING 0x00 // Use IO Capabilities to deter- mine authentication procedure #define SSP_IO_AUTHREQ_MITM_PROTECTION_REQUIRED_NO_BONDING 0x01 // Numeric compar- ison with automatic accept allowed. #define SSP_IO_AUTHREQ_MITM_PROTECTION_NOT_REQUIRED_DEDICATED_BONDING 0x02 // Use IO Capabilities to determine authentication procedure #define SSP_IO_AUTHREQ_MITM_PROTECTION_REQUIRED_DEDICATED_BONDING 0x03 // Numeric Compari- son with automatic accept allowed. #define SSP_IO_AUTHREQ_MITM_PROTECTION_NOT_REQUIRED_GENERAL_BONDING 0x04 // . Use IO capabilities to determine authentication procedure. #define SSP_IO_AUTHREQ_MITM_PROTECTION_REQUIRED_GENERAL_BONDING 0x05 /** * Address types * @note: BTstack uses a custom addr type to refer to classic ACL and SCO devices */ typedef enum { BD_ADDR_TYPE_LE_PUBLIC = 0, BD_ADDR_TYPE_LE_RANDOM = 1, BD_ADDR_TYPE_SCO = 0xfe, BD_ADDR_TYPE_CLASSIC = 0xff, BD_ADDR_TYPE_UNKNOWN = 0xfe } bd_addr_type_t; /** * Hardware state of Bluetooth controller */ typedef enum { HCI_POWER_OFF = 0, HCI_POWER_ON, HCI_POWER_SLEEP } HCI_POWER_MODE; /** * State of BTstack */ typedef enum { HCI_STATE_OFF = 0, HCI_STATE_INITIALIZING, HCI_STATE_WORKING, HCI_STATE_HALTING, HCI_STATE_SLEEPING, HCI_STATE_FALLING_ASLEEP } HCI_STATE; /** * compact HCI Command packet description */ typedef struct { uint16_t opcode; const char *format; } hci_cmd_t; // HCI Commands - see hci_cmds.c for info on parameters extern const hci_cmd_t btstack_get_state; extern const hci_cmd_t btstack_set_power_mode; extern const hci_cmd_t btstack_set_acl_capture_mode; extern const hci_cmd_t btstack_get_version; extern const hci_cmd_t btstack_get_system_bluetooth_enabled; extern const hci_cmd_t btstack_set_system_bluetooth_enabled; extern const hci_cmd_t btstack_set_discoverable; extern const hci_cmd_t btstack_set_bluetooth_enabled; // only used by btstack config extern const hci_cmd_t hci_accept_connection_request; extern const hci_cmd_t hci_accept_synchronous_connection_command; extern const hci_cmd_t hci_authentication_requested; extern const hci_cmd_t hci_change_connection_link_key; extern const hci_cmd_t hci_change_connection_packet_type; extern const hci_cmd_t hci_create_connection; extern const hci_cmd_t hci_create_connection_cancel; extern const hci_cmd_t hci_delete_stored_link_key; extern const hci_cmd_t hci_enhanced_setup_synchronous_connection_command; extern const hci_cmd_t hci_enhanced_accept_synchronous_connection_command; extern const hci_cmd_t hci_disconnect; extern const hci_cmd_t hci_host_buffer_size; extern const hci_cmd_t hci_inquiry; extern const hci_cmd_t hci_io_capability_request_reply; extern const hci_cmd_t hci_io_capability_request_negative_reply; extern const hci_cmd_t hci_inquiry_cancel; extern const hci_cmd_t hci_link_key_request_negative_reply; extern const hci_cmd_t hci_link_key_request_reply; extern const hci_cmd_t hci_pin_code_request_reply; extern const hci_cmd_t hci_pin_code_request_negative_reply; extern const hci_cmd_t hci_qos_setup; extern const hci_cmd_t hci_read_bd_addr; extern const hci_cmd_t hci_read_buffer_size; extern const hci_cmd_t hci_read_le_host_supported; extern const hci_cmd_t hci_read_link_policy_settings; extern const hci_cmd_t hci_read_link_supervision_timeout; extern const hci_cmd_t hci_read_local_supported_features; extern const hci_cmd_t hci_read_num_broadcast_retransmissions; extern const hci_cmd_t hci_read_remote_supported_features_command; extern const hci_cmd_t hci_read_rssi; extern const hci_cmd_t hci_reject_connection_request; extern const hci_cmd_t hci_remote_name_request; extern const hci_cmd_t hci_remote_name_request_cancel; extern const hci_cmd_t hci_remote_oob_data_request_negative_reply; extern const hci_cmd_t hci_reset; extern const hci_cmd_t hci_role_discovery; extern const hci_cmd_t hci_set_event_mask; extern const hci_cmd_t hci_set_connection_encryption; extern const hci_cmd_t hci_setup_synchronous_connection_command; extern const hci_cmd_t hci_sniff_mode; extern const hci_cmd_t hci_switch_role_command; extern const hci_cmd_t hci_user_confirmation_request_negative_reply; extern const hci_cmd_t hci_user_confirmation_request_reply; extern const hci_cmd_t hci_user_passkey_request_negative_reply; extern const hci_cmd_t hci_user_passkey_request_reply; extern const hci_cmd_t hci_write_authentication_enable; extern const hci_cmd_t hci_write_class_of_device; extern const hci_cmd_t hci_write_extended_inquiry_response; extern const hci_cmd_t hci_write_inquiry_mode; extern const hci_cmd_t hci_write_le_host_supported; extern const hci_cmd_t hci_write_link_policy_settings; extern const hci_cmd_t hci_write_link_supervision_timeout; extern const hci_cmd_t hci_write_local_name; extern const hci_cmd_t hci_write_num_broadcast_retransmissions; extern const hci_cmd_t hci_write_page_timeout; extern const hci_cmd_t hci_write_scan_enable; extern const hci_cmd_t hci_write_simple_pairing_mode; extern const hci_cmd_t hci_write_synchronous_flow_control_enable; extern const hci_cmd_t hci_le_add_device_to_whitelist; extern const hci_cmd_t hci_le_clear_white_list; extern const hci_cmd_t hci_le_connection_update; extern const hci_cmd_t hci_le_create_connection; extern const hci_cmd_t hci_le_create_connection_cancel; extern const hci_cmd_t hci_le_encrypt; extern const hci_cmd_t hci_le_long_term_key_negative_reply; extern const hci_cmd_t hci_le_long_term_key_request_reply; extern const hci_cmd_t hci_le_rand; extern const hci_cmd_t hci_le_read_advertising_channel_tx_power; extern const hci_cmd_t hci_le_read_buffer_size ; extern const hci_cmd_t hci_le_read_channel_map; extern const hci_cmd_t hci_le_read_remote_used_features; extern const hci_cmd_t hci_le_read_supported_features; extern const hci_cmd_t hci_le_read_supported_states; extern const hci_cmd_t hci_le_read_white_list_size; extern const hci_cmd_t hci_le_receiver_test; extern const hci_cmd_t hci_le_remove_device_from_whitelist; extern const hci_cmd_t hci_le_set_advertise_enable; extern const hci_cmd_t hci_le_set_advertising_data; extern const hci_cmd_t hci_le_set_advertising_parameters; extern const hci_cmd_t hci_le_set_event_mask; extern const hci_cmd_t hci_le_set_host_channel_classification; extern const hci_cmd_t hci_le_set_random_address; extern const hci_cmd_t hci_le_set_scan_enable; extern const hci_cmd_t hci_le_set_scan_parameters; extern const hci_cmd_t hci_le_set_scan_response_data; extern const hci_cmd_t hci_le_start_encryption; extern const hci_cmd_t hci_le_test_end; extern const hci_cmd_t hci_le_transmitter_test; extern const hci_cmd_t l2cap_accept_connection; extern const hci_cmd_t l2cap_create_channel; extern const hci_cmd_t l2cap_create_channel_mtu; extern const hci_cmd_t l2cap_decline_connection; extern const hci_cmd_t l2cap_disconnect; extern const hci_cmd_t l2cap_register_service; extern const hci_cmd_t l2cap_unregister_service; extern const hci_cmd_t sdp_register_service_record; extern const hci_cmd_t sdp_unregister_service_record; extern const hci_cmd_t sdp_client_query_rfcomm_services; extern const hci_cmd_t sdp_client_query_services; // accept connection @param bd_addr(48), rfcomm_cid (16) extern const hci_cmd_t rfcomm_accept_connection; // create rfcomm channel: @param bd_addr(48), channel (8) extern const hci_cmd_t rfcomm_create_channel; // create rfcomm channel: @param bd_addr(48), channel (8), mtu (16), credits (8) extern const hci_cmd_t rfcomm_create_channel_with_initial_credits; // decline rfcomm disconnect,@param bd_addr(48), rfcomm cid (16), reason(8) extern const hci_cmd_t rfcomm_decline_connection; // disconnect rfcomm disconnect, @param rfcomm_cid(8), reason(8) extern const hci_cmd_t rfcomm_disconnect; // register rfcomm service: @param channel(8), mtu (16) extern const hci_cmd_t rfcomm_register_service; // register rfcomm service: @param channel(8), mtu (16), initial credits (8) extern const hci_cmd_t rfcomm_register_service_with_initial_credits; // unregister rfcomm service, @param service_channel(16) extern const hci_cmd_t rfcomm_unregister_service; // request persisten rfcomm channel for service name: serive name (char*) extern const hci_cmd_t rfcomm_persistent_channel_for_service; extern const hci_cmd_t gap_disconnect_cmd; extern const hci_cmd_t gap_le_scan_start; extern const hci_cmd_t gap_le_scan_stop; extern const hci_cmd_t gap_le_set_scan_parameters; extern const hci_cmd_t gap_le_connect_cmd; extern const hci_cmd_t gap_le_connect_cancel_cmd; extern const hci_cmd_t gatt_discover_primary_services_cmd; #if defined __cplusplus } #endif #endif // __HCI_CMDS_H