mirror of
https://github.com/bluekitchen/btstack.git
synced 2025-03-15 22:20:59 +00:00
hci: provide hci_opcode_t and daemon_opcode_t definitions and use in hci_cmd.c and daemon_cmd.c
This commit is contained in:
parent
5c54401929
commit
ea5cc3a8d3
@ -51,50 +51,50 @@
|
||||
|
||||
// BTstack commands
|
||||
const hci_cmd_t btstack_get_state = {
|
||||
OPCODE(OGF_BTSTACK, BTSTACK_GET_STATE), ""
|
||||
DAEMON_OPCODE_BTSTACK_GET_STATE, ""
|
||||
};
|
||||
|
||||
/**
|
||||
* @param power_mode (0 = off, 1 = on)
|
||||
*/
|
||||
const hci_cmd_t btstack_set_power_mode = {
|
||||
OPCODE(OGF_BTSTACK, BTSTACK_SET_POWER_MODE), "1"
|
||||
DAEMON_OPCODE_BTSTACK_SET_POWER_MODE, "1"
|
||||
};
|
||||
|
||||
/**
|
||||
* @param acl_capture_mode (0 = off, 1 = on)
|
||||
*/
|
||||
const hci_cmd_t btstack_set_acl_capture_mode = {
|
||||
OPCODE(OGF_BTSTACK, BTSTACK_SET_ACL_CAPTURE_MODE), "1"
|
||||
DAEMON_OPCODE_BTSTACK_SET_ACL_CAPTURE_MODE, "1"
|
||||
};
|
||||
|
||||
const hci_cmd_t btstack_get_version = {
|
||||
OPCODE(OGF_BTSTACK, BTSTACK_GET_VERSION), ""
|
||||
DAEMON_OPCODE_BTSTACK_GET_VERSION, ""
|
||||
};
|
||||
|
||||
const hci_cmd_t btstack_get_system_bluetooth_enabled = {
|
||||
OPCODE(OGF_BTSTACK, BTSTACK_GET_SYSTEM_BLUETOOTH_ENABLED), ""
|
||||
DAEMON_OPCODE_BTSTACK_GET_SYSTEM_BLUETOOTH_ENABLED, ""
|
||||
};
|
||||
|
||||
/**
|
||||
* @param bluetooth_enabled_flag (0 = off, 1 = on, only used by btstack config)
|
||||
*/
|
||||
const hci_cmd_t btstack_set_system_bluetooth_enabled = {
|
||||
OPCODE(OGF_BTSTACK, BTSTACK_SET_SYSTEM_BLUETOOTH_ENABLED), "1"
|
||||
DAEMON_OPCODE_BTSTACK_SET_SYSTEM_BLUETOOTH_ENABLED, "1"
|
||||
};
|
||||
|
||||
/**
|
||||
* @param discoverable_flag (0 = off, 1 = on)
|
||||
*/
|
||||
const hci_cmd_t btstack_set_discoverable = {
|
||||
OPCODE(OGF_BTSTACK, BTSTACK_SET_DISCOVERABLE), "1"
|
||||
DAEMON_OPCODE_BTSTACK_SET_DISCOVERABLE, "1"
|
||||
};
|
||||
|
||||
/**
|
||||
* @param bluetooth_enabled_flag (0 = off, 1 = on, only used by btstack config)
|
||||
*/
|
||||
const hci_cmd_t btstack_set_bluetooth_enabled = {
|
||||
OPCODE(OGF_BTSTACK, BTSTACK_SET_BLUETOOTH_ENABLED), "1"
|
||||
DAEMON_OPCODE_BTSTACK_SET_BLUETOOTH_ENABLED, "1"
|
||||
};
|
||||
|
||||
/**
|
||||
@ -102,7 +102,7 @@ OPCODE(OGF_BTSTACK, BTSTACK_SET_BLUETOOTH_ENABLED), "1"
|
||||
* @param psm (16)
|
||||
*/
|
||||
const hci_cmd_t l2cap_create_channel_cmd = {
|
||||
OPCODE(OGF_BTSTACK, L2CAP_CREATE_CHANNEL), "B2"
|
||||
DAEMON_OPCODE_L2CAP_CREATE_CHANNEL, "B2"
|
||||
};
|
||||
|
||||
/**
|
||||
@ -111,7 +111,7 @@ OPCODE(OGF_BTSTACK, L2CAP_CREATE_CHANNEL), "B2"
|
||||
* @param mtu (16)
|
||||
*/
|
||||
const hci_cmd_t l2cap_create_channel_mtu_cmd = {
|
||||
OPCODE(OGF_BTSTACK, L2CAP_CREATE_CHANNEL_MTU), "B22"
|
||||
DAEMON_OPCODE_L2CAP_CREATE_CHANNEL_MTU, "B22"
|
||||
// @param bd_addr(48), psm (16), mtu (16)
|
||||
};
|
||||
|
||||
@ -120,7 +120,7 @@ OPCODE(OGF_BTSTACK, L2CAP_CREATE_CHANNEL_MTU), "B22"
|
||||
* @param reason (16)
|
||||
*/
|
||||
const hci_cmd_t l2cap_disconnect_cmd = {
|
||||
OPCODE(OGF_BTSTACK, L2CAP_DISCONNECT), "21"
|
||||
DAEMON_OPCODE_L2CAP_DISCONNECT, "21"
|
||||
};
|
||||
|
||||
/**
|
||||
@ -128,21 +128,21 @@ OPCODE(OGF_BTSTACK, L2CAP_DISCONNECT), "21"
|
||||
* @param mtu (16)
|
||||
*/
|
||||
const hci_cmd_t l2cap_register_service_cmd = {
|
||||
OPCODE(OGF_BTSTACK, L2CAP_REGISTER_SERVICE), "22"
|
||||
DAEMON_OPCODE_L2CAP_REGISTER_SERVICE, "22"
|
||||
};
|
||||
|
||||
/**
|
||||
* @param psm (16)
|
||||
*/
|
||||
const hci_cmd_t l2cap_unregister_service_cmd = {
|
||||
OPCODE(OGF_BTSTACK, L2CAP_UNREGISTER_SERVICE), "2"
|
||||
DAEMON_OPCODE_L2CAP_UNREGISTER_SERVICE, "2"
|
||||
};
|
||||
|
||||
/**
|
||||
* @param source_cid (16)
|
||||
*/
|
||||
const hci_cmd_t l2cap_accept_connection_cmd = {
|
||||
OPCODE(OGF_BTSTACK, L2CAP_ACCEPT_CONNECTION), "2"
|
||||
DAEMON_OPCODE_L2CAP_ACCEPT_CONNECTION, "2"
|
||||
};
|
||||
|
||||
/**
|
||||
@ -150,7 +150,7 @@ OPCODE(OGF_BTSTACK, L2CAP_ACCEPT_CONNECTION), "2"
|
||||
* @param reason (deprecated)
|
||||
*/
|
||||
const hci_cmd_t l2cap_decline_connection_cmd = {
|
||||
OPCODE(OGF_BTSTACK, L2CAP_DECLINE_CONNECTION), "21"
|
||||
DAEMON_OPCODE_L2CAP_DECLINE_CONNECTION, "21"
|
||||
};
|
||||
|
||||
|
||||
@ -158,14 +158,14 @@ OPCODE(OGF_BTSTACK, L2CAP_DECLINE_CONNECTION), "21"
|
||||
* @param service_record
|
||||
*/
|
||||
const hci_cmd_t sdp_register_service_record_cmd = {
|
||||
OPCODE(OGF_BTSTACK, SDP_REGISTER_SERVICE_RECORD), "S"
|
||||
DAEMON_OPCODE_SDP_REGISTER_SERVICE_RECORD, "S"
|
||||
};
|
||||
|
||||
/**
|
||||
* @param service_record_handle
|
||||
*/
|
||||
const hci_cmd_t sdp_unregister_service_record_cmd = {
|
||||
OPCODE(OGF_BTSTACK, SDP_UNREGISTER_SERVICE_RECORD), "4"
|
||||
DAEMON_OPCODE_SDP_UNREGISTER_SERVICE_RECORD, "4"
|
||||
};
|
||||
|
||||
/**
|
||||
@ -173,7 +173,7 @@ OPCODE(OGF_BTSTACK, SDP_UNREGISTER_SERVICE_RECORD), "4"
|
||||
* @param service_search_pattern
|
||||
*/
|
||||
const hci_cmd_t sdp_client_query_rfcomm_services_cmd = {
|
||||
OPCODE(OGF_BTSTACK, SDP_CLIENT_QUERY_RFCOMM_SERVICES), "BS"
|
||||
DAEMON_OPCODE_SDP_CLIENT_QUERY_RFCOMM_SERVICES, "BS"
|
||||
};
|
||||
|
||||
/**
|
||||
@ -182,7 +182,7 @@ OPCODE(OGF_BTSTACK, SDP_CLIENT_QUERY_RFCOMM_SERVICES), "BS"
|
||||
* @param attribute_ID_list
|
||||
*/
|
||||
const hci_cmd_t sdp_client_query_services_cmd = {
|
||||
OPCODE(OGF_BTSTACK, SDP_CLIENT_QUERY_SERVICES), "BSS"
|
||||
DAEMON_OPCODE_SDP_CLIENT_QUERY_SERVICES, "BSS"
|
||||
};
|
||||
|
||||
/**
|
||||
@ -190,7 +190,7 @@ OPCODE(OGF_BTSTACK, SDP_CLIENT_QUERY_SERVICES), "BSS"
|
||||
* @param server_channel
|
||||
*/
|
||||
const hci_cmd_t rfcomm_create_channel_cmd = {
|
||||
OPCODE(OGF_BTSTACK, RFCOMM_CREATE_CHANNEL), "B1"
|
||||
DAEMON_OPCODE_RFCOMM_CREATE_CHANNEL, "B1"
|
||||
};
|
||||
|
||||
/**
|
||||
@ -200,7 +200,7 @@ OPCODE(OGF_BTSTACK, RFCOMM_CREATE_CHANNEL), "B1"
|
||||
* @param credits
|
||||
*/
|
||||
const hci_cmd_t rfcomm_create_channel_with_initial_credits_cmd = {
|
||||
OPCODE(OGF_BTSTACK, RFCOMM_CREATE_CHANNEL_WITH_CREDITS), "B121"
|
||||
DAEMON_OPCODE_RFCOMM_CREATE_CHANNEL_WITH_INITIAL_CREDITS, "B121"
|
||||
};
|
||||
|
||||
/**
|
||||
@ -208,7 +208,7 @@ OPCODE(OGF_BTSTACK, RFCOMM_CREATE_CHANNEL_WITH_CREDITS), "B121"
|
||||
* @param credits
|
||||
*/
|
||||
const hci_cmd_t rfcomm_grants_credits_cmd = {
|
||||
OPCODE(OGF_BTSTACK, RFCOMM_GRANT_CREDITS), "21"
|
||||
DAEMON_OPCODE_RFCOMM_GRANTS_CREDITS, "21"
|
||||
};
|
||||
|
||||
/**
|
||||
@ -216,7 +216,7 @@ OPCODE(OGF_BTSTACK, RFCOMM_GRANT_CREDITS), "21"
|
||||
* @param reason
|
||||
*/
|
||||
const hci_cmd_t rfcomm_disconnect_cmd = {
|
||||
OPCODE(OGF_BTSTACK, RFCOMM_DISCONNECT), "21"
|
||||
DAEMON_OPCODE_RFCOMM_DISCONNECT, "21"
|
||||
};
|
||||
|
||||
/**
|
||||
@ -224,7 +224,7 @@ OPCODE(OGF_BTSTACK, RFCOMM_DISCONNECT), "21"
|
||||
* @param mtu
|
||||
*/
|
||||
const hci_cmd_t rfcomm_register_service_cmd = {
|
||||
OPCODE(OGF_BTSTACK, RFCOMM_REGISTER_SERVICE), "12"
|
||||
DAEMON_OPCODE_RFCOMM_REGISTER_SERVICE, "12"
|
||||
};
|
||||
|
||||
/**
|
||||
@ -233,21 +233,21 @@ OPCODE(OGF_BTSTACK, RFCOMM_REGISTER_SERVICE), "12"
|
||||
* @param initial_credits
|
||||
*/
|
||||
const hci_cmd_t rfcomm_register_service_with_initial_credits_cmd = {
|
||||
OPCODE(OGF_BTSTACK, RFCOMM_REGISTER_SERVICE_WITH_CREDITS), "121"
|
||||
DAEMON_OPCODE_RFCOMM_REGISTER_SERVICE_WITH_INITIAL_CREDITS, "121"
|
||||
};
|
||||
|
||||
/**
|
||||
* @param service_channel
|
||||
*/
|
||||
const hci_cmd_t rfcomm_unregister_service_cmd = {
|
||||
OPCODE(OGF_BTSTACK, RFCOMM_UNREGISTER_SERVICE), "2"
|
||||
DAEMON_OPCODE_RFCOMM_UNREGISTER_SERVICE, "2"
|
||||
};
|
||||
|
||||
/**
|
||||
* @param source_cid
|
||||
*/
|
||||
const hci_cmd_t rfcomm_accept_connection_cmd = {
|
||||
OPCODE(OGF_BTSTACK, RFCOMM_ACCEPT_CONNECTION), "2"
|
||||
DAEMON_OPCODE_RFCOMM_ACCEPT_CONNECTION, "2"
|
||||
};
|
||||
|
||||
|
||||
@ -256,7 +256,7 @@ OPCODE(OGF_BTSTACK, RFCOMM_ACCEPT_CONNECTION), "2"
|
||||
* @param reason
|
||||
*/
|
||||
const hci_cmd_t rfcomm_decline_connection_cmd = {
|
||||
OPCODE(OGF_BTSTACK, RFCOMM_DECLINE_CONNECTION), "21"
|
||||
DAEMON_OPCODE_RFCOMM_DECLINE_CONNECTION, "21"
|
||||
};
|
||||
|
||||
// request persistent rfcomm channel number for named service
|
||||
@ -264,26 +264,26 @@ OPCODE(OGF_BTSTACK, RFCOMM_DECLINE_CONNECTION), "21"
|
||||
* @param named_service
|
||||
*/
|
||||
const hci_cmd_t rfcomm_persistent_channel_for_service_cmd = {
|
||||
OPCODE(OGF_BTSTACK, RFCOMM_PERSISTENT_CHANNEL), "N"
|
||||
DAEMON_OPCODE_RFCOMM_PERSISTENT_CHANNEL_FOR_SERVICE, "N"
|
||||
};
|
||||
|
||||
/**
|
||||
* @param handle
|
||||
*/
|
||||
const hci_cmd_t gap_disconnect_cmd = {
|
||||
OPCODE(OGF_BTSTACK, GAP_DISCONNECT), "H"
|
||||
DAEMON_OPCODE_GAP_DISCONNECT, "H"
|
||||
};
|
||||
|
||||
/**
|
||||
*/
|
||||
const hci_cmd_t gap_le_scan_start = {
|
||||
OPCODE(OGF_BTSTACK, GAP_LE_SCAN_START), ""
|
||||
DAEMON_OPCODE_GAP_LE_SCAN_START, ""
|
||||
};
|
||||
|
||||
/**
|
||||
*/
|
||||
const hci_cmd_t gap_le_scan_stop = {
|
||||
OPCODE(OGF_BTSTACK, GAP_LE_SCAN_STOP), ""
|
||||
DAEMON_OPCODE_GAP_LE_SCAN_STOP, ""
|
||||
};
|
||||
|
||||
/**
|
||||
@ -292,7 +292,7 @@ OPCODE(OGF_BTSTACK, GAP_LE_SCAN_STOP), ""
|
||||
* @param scan_window
|
||||
*/
|
||||
const hci_cmd_t gap_le_set_scan_parameters = {
|
||||
OPCODE(OGF_BTSTACK, GAP_LE_SET_SCAN_PARAMETERS), "122"
|
||||
DAEMON_OPCODE_GAP_LE_SET_SCAN_PARAMETERS, "122"
|
||||
};
|
||||
|
||||
/**
|
||||
@ -300,7 +300,7 @@ OPCODE(OGF_BTSTACK, GAP_LE_SET_SCAN_PARAMETERS), "122"
|
||||
* @param peer_address
|
||||
*/
|
||||
const hci_cmd_t gap_le_connect_cmd = {
|
||||
OPCODE(OGF_BTSTACK, GAP_LE_CONNECT), "1B"
|
||||
DAEMON_OPCODE_GAP_LE_CONNECT, "1B"
|
||||
};
|
||||
|
||||
/**
|
||||
@ -308,14 +308,14 @@ OPCODE(OGF_BTSTACK, GAP_LE_CONNECT), "1B"
|
||||
* @param peer_address
|
||||
*/
|
||||
const hci_cmd_t gap_le_connect_cancel_cmd = {
|
||||
OPCODE(OGF_BTSTACK, GAP_LE_CONNECT_CANCEL), ""
|
||||
DAEMON_OPCODE_GAP_LE_CONNECT_CANCEL, ""
|
||||
};
|
||||
|
||||
/**
|
||||
* @param handle
|
||||
*/
|
||||
const hci_cmd_t gatt_discover_primary_services_cmd = {
|
||||
OPCODE(OGF_BTSTACK, GATT_DISCOVER_ALL_PRIMARY_SERVICES), "H"
|
||||
DAEMON_OPCODE_GATT_DISCOVER_PRIMARY_SERVICES, "H"
|
||||
};
|
||||
|
||||
/**
|
||||
@ -323,7 +323,7 @@ OPCODE(OGF_BTSTACK, GATT_DISCOVER_ALL_PRIMARY_SERVICES), "H"
|
||||
* @param uuid16
|
||||
*/
|
||||
const hci_cmd_t gatt_discover_primary_services_by_uuid16_cmd = {
|
||||
OPCODE(OGF_BTSTACK, GATT_DISCOVER_PRIMARY_SERVICES_BY_UUID16), "H2"
|
||||
DAEMON_OPCODE_GATT_DISCOVER_PRIMARY_SERVICES_BY_UUID16, "H2"
|
||||
};
|
||||
|
||||
/**
|
||||
@ -331,7 +331,7 @@ const hci_cmd_t gatt_discover_primary_services_by_uuid16_cmd = {
|
||||
* @param uuid128
|
||||
*/
|
||||
const hci_cmd_t gatt_discover_primary_services_by_uuid128_cmd = {
|
||||
OPCODE(OGF_BTSTACK, GATT_DISCOVER_PRIMARY_SERVICES_BY_UUID128), "HU"
|
||||
DAEMON_OPCODE_GATT_DISCOVER_PRIMARY_SERVICES_BY_UUID128, "HU"
|
||||
};
|
||||
|
||||
/**
|
||||
@ -339,7 +339,7 @@ const hci_cmd_t gatt_discover_primary_services_by_uuid128_cmd = {
|
||||
* @param service
|
||||
*/
|
||||
const hci_cmd_t gatt_find_included_services_for_service_cmd = {
|
||||
OPCODE(OGF_BTSTACK, GATT_FIND_INCLUDED_SERVICES_FOR_SERVICE), "HX"
|
||||
DAEMON_OPCODE_GATT_FIND_INCLUDED_SERVICES_FOR_SERVICE, "HX"
|
||||
};
|
||||
|
||||
/**
|
||||
@ -347,7 +347,7 @@ const hci_cmd_t gatt_find_included_services_for_service_cmd = {
|
||||
* @param service
|
||||
*/
|
||||
const hci_cmd_t gatt_discover_characteristics_for_service_cmd = {
|
||||
OPCODE(OGF_BTSTACK, GATT_DISCOVER_CHARACTERISTICS_FOR_SERVICE), "HX"
|
||||
DAEMON_OPCODE_GATT_DISCOVER_CHARACTERISTICS_FOR_SERVICE, "HX"
|
||||
};
|
||||
|
||||
/**
|
||||
@ -356,7 +356,7 @@ const hci_cmd_t gatt_discover_characteristics_for_service_cmd = {
|
||||
* @param uuid128
|
||||
*/
|
||||
const hci_cmd_t gatt_discover_characteristics_for_service_by_uuid128_cmd = {
|
||||
OPCODE(OGF_BTSTACK, GATT_DISCOVER_CHARACTERISTICS_FOR_SERVICE_BY_UUID128), "HXU"
|
||||
DAEMON_OPCODE_GATT_DISCOVER_CHARACTERISTICS_FOR_SERVICE_BY_UUID128, "HXU"
|
||||
};
|
||||
|
||||
/**
|
||||
@ -364,7 +364,7 @@ const hci_cmd_t gatt_discover_characteristics_for_service_by_uuid128_cmd = {
|
||||
* @param characteristic
|
||||
*/
|
||||
const hci_cmd_t gatt_discover_characteristic_descriptors_cmd = {
|
||||
OPCODE(OGF_BTSTACK, GATT_DISCOVER_CHARACTERISTIC_DESCRIPTORS), "HY"
|
||||
DAEMON_OPCODE_GATT_DISCOVER_CHARACTERISTIC_DESCRIPTORS, "HY"
|
||||
};
|
||||
|
||||
/**
|
||||
@ -372,7 +372,7 @@ const hci_cmd_t gatt_discover_characteristic_descriptors_cmd = {
|
||||
* @param characteristic
|
||||
*/
|
||||
const hci_cmd_t gatt_read_value_of_characteristic_cmd = {
|
||||
OPCODE(OGF_BTSTACK, GATT_READ_VALUE_OF_CHARACTERISTIC), "HY"
|
||||
DAEMON_OPCODE_GATT_READ_VALUE_OF_CHARACTERISTIC, "HY"
|
||||
};
|
||||
|
||||
/**
|
||||
@ -380,7 +380,7 @@ const hci_cmd_t gatt_read_value_of_characteristic_cmd = {
|
||||
* @param characteristic
|
||||
*/
|
||||
const hci_cmd_t gatt_read_long_value_of_characteristic_cmd = {
|
||||
OPCODE(OGF_BTSTACK, GATT_READ_LONG_VALUE_OF_CHARACTERISTIC), "HY"
|
||||
DAEMON_OPCODE_GATT_READ_LONG_VALUE_OF_CHARACTERISTIC, "HY"
|
||||
};
|
||||
|
||||
/**
|
||||
@ -390,7 +390,7 @@ const hci_cmd_t gatt_read_long_value_of_characteristic_cmd = {
|
||||
* @param data
|
||||
*/
|
||||
const hci_cmd_t gatt_write_value_of_characteristic_without_response_cmd = {
|
||||
OPCODE(OGF_BTSTACK, GATT_WRITE_VALUE_OF_CHARACTERISTIC_WITHOUT_RESPONSE), "HYLV"
|
||||
DAEMON_OPCODE_GATT_WRITE_VALUE_OF_CHARACTERISTIC_WITHOUT_RESPONSE, "HYLV"
|
||||
};
|
||||
|
||||
/**
|
||||
@ -400,7 +400,7 @@ const hci_cmd_t gatt_write_value_of_characteristic_without_response_cmd = {
|
||||
* @param data
|
||||
*/
|
||||
const hci_cmd_t gatt_write_value_of_characteristic_cmd = {
|
||||
OPCODE(OGF_BTSTACK, GATT_WRITE_VALUE_OF_CHARACTERISTIC), "HYLV"
|
||||
DAEMON_OPCODE_GATT_WRITE_VALUE_OF_CHARACTERISTIC, "HYLV"
|
||||
};
|
||||
|
||||
/**
|
||||
@ -410,7 +410,7 @@ const hci_cmd_t gatt_write_value_of_characteristic_cmd = {
|
||||
* @param data
|
||||
*/
|
||||
const hci_cmd_t gatt_write_long_value_of_characteristic_cmd = {
|
||||
OPCODE(OGF_BTSTACK, GATT_WRITE_LONG_VALUE_OF_CHARACTERISTIC), "HYLV"
|
||||
DAEMON_OPCODE_GATT_WRITE_LONG_VALUE_OF_CHARACTERISTIC, "HYLV"
|
||||
};
|
||||
|
||||
/**
|
||||
@ -420,7 +420,7 @@ const hci_cmd_t gatt_write_long_value_of_characteristic_cmd = {
|
||||
* @param data
|
||||
*/
|
||||
const hci_cmd_t gatt_reliable_write_long_value_of_characteristic_cmd = {
|
||||
OPCODE(OGF_BTSTACK, GATT_RELIABLE_WRITE_LONG_VALUE_OF_CHARACTERISTIC), "HYLV"
|
||||
DAEMON_OPCODE_GATT_RELIABLE_WRITE_LONG_VALUE_OF_CHARACTERISTIC, "HYLV"
|
||||
};
|
||||
|
||||
/**
|
||||
@ -428,7 +428,7 @@ const hci_cmd_t gatt_reliable_write_long_value_of_characteristic_cmd = {
|
||||
* @param descriptor
|
||||
*/
|
||||
const hci_cmd_t gatt_read_characteristic_descriptor_cmd = {
|
||||
OPCODE(OGF_BTSTACK, GATT_READ_CHARACTERISTIC_DESCRIPTOR), "HZ"
|
||||
DAEMON_OPCODE_GATT_READ_CHARACTERISTIC_DESCRIPTOR, "HZ"
|
||||
};
|
||||
|
||||
/**
|
||||
@ -436,7 +436,7 @@ const hci_cmd_t gatt_read_characteristic_descriptor_cmd = {
|
||||
* @param descriptor
|
||||
*/
|
||||
const hci_cmd_t gatt_read_long_characteristic_descriptor_cmd = {
|
||||
OPCODE(OGF_BTSTACK, GATT_READ_LONG_CHARACTERISTIC_DESCRIPTOR), "HZ"
|
||||
DAEMON_OPCODE_GATT_READ_LONG_CHARACTERISTIC_DESCRIPTOR, "HZ"
|
||||
};
|
||||
|
||||
/**
|
||||
@ -446,7 +446,7 @@ const hci_cmd_t gatt_read_long_characteristic_descriptor_cmd = {
|
||||
* @param data
|
||||
*/
|
||||
const hci_cmd_t gatt_write_characteristic_descriptor_cmd = {
|
||||
OPCODE(OGF_BTSTACK, GATT_WRITE_CHARACTERISTIC_DESCRIPTOR), "HZLV"
|
||||
DAEMON_OPCODE_GATT_WRITE_CHARACTERISTIC_DESCRIPTOR, "HZLV"
|
||||
};
|
||||
|
||||
/**
|
||||
@ -456,7 +456,7 @@ const hci_cmd_t gatt_write_characteristic_descriptor_cmd = {
|
||||
* @param data
|
||||
*/
|
||||
const hci_cmd_t gatt_write_long_characteristic_descriptor_cmd = {
|
||||
OPCODE(OGF_BTSTACK, GATT_WRITE_LONG_CHARACTERISTIC_DESCRIPTOR), "HZLV"
|
||||
DAEMON_OPCODE_GATT_WRITE_LONG_CHARACTERISTIC_DESCRIPTOR, "HZLV"
|
||||
};
|
||||
|
||||
/**
|
||||
@ -465,14 +465,14 @@ const hci_cmd_t gatt_write_long_characteristic_descriptor_cmd = {
|
||||
* @param configuration
|
||||
*/
|
||||
const hci_cmd_t gatt_write_client_characteristic_configuration_cmd = {
|
||||
OPCODE(OGF_BTSTACK, GATT_WRITE_CLIENT_CHARACTERISTIC_CONFIGURATION), "HY2"
|
||||
DAEMON_OPCODE_GATT_WRITE_CLIENT_CHARACTERISTIC_CONFIGURATION, "HY2"
|
||||
};
|
||||
|
||||
/**
|
||||
* @param handle
|
||||
*/
|
||||
const hci_cmd_t gatt_get_mtu = {
|
||||
OPCODE(OGF_BTSTACK, GATT_GET_MTU), "H"
|
||||
DAEMON_OPCODE_GATT_GET_MTU, "H"
|
||||
};
|
||||
|
||||
/**
|
||||
@ -480,7 +480,7 @@ const hci_cmd_t gatt_get_mtu = {
|
||||
* @param auth_req OR combination of SM_AUTHREQ_ flags
|
||||
*/
|
||||
const hci_cmd_t sm_set_authentication_requirements_cmd = {
|
||||
OPCODE(OGF_BTSTACK, SM_SET_AUTHENTICATION_REQUIREMENTS), "1"
|
||||
DAEMON_OPCODE_SM_SET_AUTHENTICATION_REQUIREMENTS, "1"
|
||||
};
|
||||
|
||||
/**
|
||||
@ -488,7 +488,7 @@ const hci_cmd_t sm_set_authentication_requirements_cmd = {
|
||||
* @param io_capabilities
|
||||
*/
|
||||
const hci_cmd_t sm_set_io_capabilities_cmd = {
|
||||
OPCODE(OGF_BTSTACK, SM_SET_IO_CAPABILITIES), "1"
|
||||
DAEMON_OPCODE_SM_SET_IO_CAPABILITIES, "1"
|
||||
};
|
||||
|
||||
/**
|
||||
@ -496,7 +496,7 @@ const hci_cmd_t sm_set_io_capabilities_cmd = {
|
||||
* @param con_handle
|
||||
*/
|
||||
const hci_cmd_t sm_bonding_decline_cmd = {
|
||||
OPCODE(OGF_BTSTACK, SM_BONDING_DECLINE), "H"
|
||||
DAEMON_OPCODE_SM_BONDING_DECLINE, "H"
|
||||
};
|
||||
|
||||
/**
|
||||
@ -504,7 +504,7 @@ const hci_cmd_t sm_bonding_decline_cmd = {
|
||||
* @param con_handle
|
||||
*/
|
||||
const hci_cmd_t sm_just_works_confirm_cmd = {
|
||||
OPCODE(OGF_BTSTACK, SM_JUST_WORKS_CONFIRM), "H"
|
||||
DAEMON_OPCODE_SM_JUST_WORKS_CONFIRM, "H"
|
||||
};
|
||||
|
||||
/**
|
||||
@ -512,7 +512,7 @@ const hci_cmd_t sm_just_works_confirm_cmd = {
|
||||
* @param con_handle
|
||||
*/
|
||||
const hci_cmd_t sm_numeric_comparison_confirm_cmd = {
|
||||
OPCODE(OGF_BTSTACK, SM_NUMERIC_COMPARISON_CONFIRM), "H"
|
||||
DAEMON_OPCODE_SM_NUMERIC_COMPARISON_CONFIRM, "H"
|
||||
};
|
||||
|
||||
/**
|
||||
@ -521,5 +521,5 @@ const hci_cmd_t sm_numeric_comparison_confirm_cmd = {
|
||||
* @param passkey in [0..999999]
|
||||
*/
|
||||
const hci_cmd_t sm_passkey_input_cmd = {
|
||||
OPCODE(OGF_BTSTACK, SM_PASSKEY_INPUT), "H4"
|
||||
DAEMON_OPCODE_SM_PASSKEY_INPUT, "H4"
|
||||
};
|
||||
|
@ -50,7 +50,73 @@
|
||||
#if defined __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
|
||||
// calculate daemon (hci) opcode for ocf value
|
||||
#define DAEMON_OPCODE(ocf) ((ocf) | ((OGF_BTSTACK) << 10))
|
||||
|
||||
typedef enum {
|
||||
DAEMON_OPCODE_BTSTACK_GET_STATE = DAEMON_OPCODE(BTSTACK_GET_STATE),
|
||||
DAEMON_OPCODE_BTSTACK_SET_POWER_MODE = DAEMON_OPCODE(BTSTACK_SET_POWER_MODE),
|
||||
DAEMON_OPCODE_BTSTACK_SET_ACL_CAPTURE_MODE = DAEMON_OPCODE(BTSTACK_SET_ACL_CAPTURE_MODE),
|
||||
DAEMON_OPCODE_BTSTACK_GET_VERSION = DAEMON_OPCODE(BTSTACK_GET_VERSION),
|
||||
DAEMON_OPCODE_BTSTACK_GET_SYSTEM_BLUETOOTH_ENABLED = DAEMON_OPCODE(BTSTACK_GET_SYSTEM_BLUETOOTH_ENABLED),
|
||||
DAEMON_OPCODE_BTSTACK_SET_SYSTEM_BLUETOOTH_ENABLED = DAEMON_OPCODE(BTSTACK_SET_SYSTEM_BLUETOOTH_ENABLED),
|
||||
DAEMON_OPCODE_BTSTACK_SET_DISCOVERABLE = DAEMON_OPCODE(BTSTACK_SET_DISCOVERABLE),
|
||||
DAEMON_OPCODE_BTSTACK_SET_BLUETOOTH_ENABLED = DAEMON_OPCODE(BTSTACK_SET_BLUETOOTH_ENABLED),
|
||||
DAEMON_OPCODE_L2CAP_CREATE_CHANNEL = DAEMON_OPCODE(L2CAP_CREATE_CHANNEL),
|
||||
DAEMON_OPCODE_L2CAP_CREATE_CHANNEL_MTU = DAEMON_OPCODE(L2CAP_CREATE_CHANNEL_MTU),
|
||||
DAEMON_OPCODE_L2CAP_DISCONNECT = DAEMON_OPCODE(L2CAP_DISCONNECT),
|
||||
DAEMON_OPCODE_L2CAP_REGISTER_SERVICE = DAEMON_OPCODE(L2CAP_REGISTER_SERVICE),
|
||||
DAEMON_OPCODE_L2CAP_UNREGISTER_SERVICE = DAEMON_OPCODE(L2CAP_UNREGISTER_SERVICE),
|
||||
DAEMON_OPCODE_L2CAP_ACCEPT_CONNECTION = DAEMON_OPCODE(L2CAP_ACCEPT_CONNECTION),
|
||||
DAEMON_OPCODE_L2CAP_DECLINE_CONNECTION = DAEMON_OPCODE(L2CAP_DECLINE_CONNECTION),
|
||||
DAEMON_OPCODE_SDP_REGISTER_SERVICE_RECORD = DAEMON_OPCODE(SDP_REGISTER_SERVICE_RECORD),
|
||||
DAEMON_OPCODE_SDP_UNREGISTER_SERVICE_RECORD = DAEMON_OPCODE(SDP_UNREGISTER_SERVICE_RECORD),
|
||||
DAEMON_OPCODE_SDP_CLIENT_QUERY_RFCOMM_SERVICES = DAEMON_OPCODE(SDP_CLIENT_QUERY_RFCOMM_SERVICES),
|
||||
DAEMON_OPCODE_SDP_CLIENT_QUERY_SERVICES = DAEMON_OPCODE(SDP_CLIENT_QUERY_SERVICES),
|
||||
DAEMON_OPCODE_RFCOMM_CREATE_CHANNEL = DAEMON_OPCODE(RFCOMM_CREATE_CHANNEL),
|
||||
DAEMON_OPCODE_RFCOMM_CREATE_CHANNEL_WITH_INITIAL_CREDITS = DAEMON_OPCODE(RFCOMM_CREATE_CHANNEL_WITH_CREDITS),
|
||||
DAEMON_OPCODE_RFCOMM_GRANTS_CREDITS = DAEMON_OPCODE(RFCOMM_GRANT_CREDITS),
|
||||
DAEMON_OPCODE_RFCOMM_DISCONNECT = DAEMON_OPCODE(RFCOMM_DISCONNECT),
|
||||
DAEMON_OPCODE_RFCOMM_REGISTER_SERVICE = DAEMON_OPCODE(RFCOMM_REGISTER_SERVICE),
|
||||
DAEMON_OPCODE_RFCOMM_REGISTER_SERVICE_WITH_INITIAL_CREDITS = DAEMON_OPCODE(RFCOMM_REGISTER_SERVICE_WITH_CREDITS),
|
||||
DAEMON_OPCODE_RFCOMM_UNREGISTER_SERVICE = DAEMON_OPCODE(RFCOMM_UNREGISTER_SERVICE),
|
||||
DAEMON_OPCODE_RFCOMM_ACCEPT_CONNECTION = DAEMON_OPCODE(RFCOMM_ACCEPT_CONNECTION),
|
||||
DAEMON_OPCODE_RFCOMM_DECLINE_CONNECTION = DAEMON_OPCODE(RFCOMM_DECLINE_CONNECTION),
|
||||
DAEMON_OPCODE_RFCOMM_PERSISTENT_CHANNEL_FOR_SERVICE = DAEMON_OPCODE(RFCOMM_PERSISTENT_CHANNEL),
|
||||
DAEMON_OPCODE_GAP_DISCONNECT = DAEMON_OPCODE(GAP_DISCONNECT),
|
||||
DAEMON_OPCODE_GAP_LE_SCAN_START = DAEMON_OPCODE(GAP_LE_SCAN_START),
|
||||
DAEMON_OPCODE_GAP_LE_SCAN_STOP = DAEMON_OPCODE(GAP_LE_SCAN_STOP),
|
||||
DAEMON_OPCODE_GAP_LE_SET_SCAN_PARAMETERS = DAEMON_OPCODE(GAP_LE_SET_SCAN_PARAMETERS),
|
||||
DAEMON_OPCODE_GAP_LE_CONNECT = DAEMON_OPCODE(GAP_LE_CONNECT),
|
||||
DAEMON_OPCODE_GAP_LE_CONNECT_CANCEL = DAEMON_OPCODE(GAP_LE_CONNECT_CANCEL),
|
||||
DAEMON_OPCODE_GATT_DISCOVER_PRIMARY_SERVICES = DAEMON_OPCODE(GATT_DISCOVER_ALL_PRIMARY_SERVICES),
|
||||
DAEMON_OPCODE_GATT_DISCOVER_PRIMARY_SERVICES_BY_UUID16 = DAEMON_OPCODE(GATT_DISCOVER_PRIMARY_SERVICES_BY_UUID16),
|
||||
DAEMON_OPCODE_GATT_DISCOVER_PRIMARY_SERVICES_BY_UUID128 = DAEMON_OPCODE(GATT_DISCOVER_PRIMARY_SERVICES_BY_UUID128),
|
||||
DAEMON_OPCODE_GATT_FIND_INCLUDED_SERVICES_FOR_SERVICE = DAEMON_OPCODE(GATT_FIND_INCLUDED_SERVICES_FOR_SERVICE),
|
||||
DAEMON_OPCODE_GATT_DISCOVER_CHARACTERISTICS_FOR_SERVICE = DAEMON_OPCODE(GATT_DISCOVER_CHARACTERISTICS_FOR_SERVICE),
|
||||
DAEMON_OPCODE_GATT_DISCOVER_CHARACTERISTICS_FOR_SERVICE_BY_UUID128 = DAEMON_OPCODE(GATT_DISCOVER_CHARACTERISTICS_FOR_SERVICE_BY_UUID128),
|
||||
DAEMON_OPCODE_GATT_DISCOVER_CHARACTERISTIC_DESCRIPTORS = DAEMON_OPCODE(GATT_DISCOVER_CHARACTERISTIC_DESCRIPTORS),
|
||||
DAEMON_OPCODE_GATT_READ_VALUE_OF_CHARACTERISTIC = DAEMON_OPCODE(GATT_READ_VALUE_OF_CHARACTERISTIC),
|
||||
DAEMON_OPCODE_GATT_READ_LONG_VALUE_OF_CHARACTERISTIC = DAEMON_OPCODE(GATT_READ_LONG_VALUE_OF_CHARACTERISTIC),
|
||||
DAEMON_OPCODE_GATT_WRITE_VALUE_OF_CHARACTERISTIC_WITHOUT_RESPONSE = DAEMON_OPCODE(GATT_WRITE_VALUE_OF_CHARACTERISTIC_WITHOUT_RESPONSE),
|
||||
DAEMON_OPCODE_GATT_WRITE_VALUE_OF_CHARACTERISTIC = DAEMON_OPCODE(GATT_WRITE_VALUE_OF_CHARACTERISTIC),
|
||||
DAEMON_OPCODE_GATT_WRITE_LONG_VALUE_OF_CHARACTERISTIC = DAEMON_OPCODE(GATT_WRITE_LONG_VALUE_OF_CHARACTERISTIC),
|
||||
DAEMON_OPCODE_GATT_RELIABLE_WRITE_LONG_VALUE_OF_CHARACTERISTIC = DAEMON_OPCODE(GATT_RELIABLE_WRITE_LONG_VALUE_OF_CHARACTERISTIC),
|
||||
DAEMON_OPCODE_GATT_READ_CHARACTERISTIC_DESCRIPTOR = DAEMON_OPCODE(GATT_READ_CHARACTERISTIC_DESCRIPTOR),
|
||||
DAEMON_OPCODE_GATT_READ_LONG_CHARACTERISTIC_DESCRIPTOR = DAEMON_OPCODE(GATT_READ_LONG_CHARACTERISTIC_DESCRIPTOR),
|
||||
DAEMON_OPCODE_GATT_WRITE_CHARACTERISTIC_DESCRIPTOR = DAEMON_OPCODE(GATT_WRITE_CHARACTERISTIC_DESCRIPTOR),
|
||||
DAEMON_OPCODE_GATT_WRITE_LONG_CHARACTERISTIC_DESCRIPTOR = DAEMON_OPCODE(GATT_WRITE_LONG_CHARACTERISTIC_DESCRIPTOR),
|
||||
DAEMON_OPCODE_GATT_WRITE_CLIENT_CHARACTERISTIC_CONFIGURATION = DAEMON_OPCODE(GATT_WRITE_CLIENT_CHARACTERISTIC_CONFIGURATION),
|
||||
DAEMON_OPCODE_GATT_GET_MTU = DAEMON_OPCODE(GATT_GET_MTU),
|
||||
DAEMON_OPCODE_SM_SET_AUTHENTICATION_REQUIREMENTS = DAEMON_OPCODE(SM_SET_AUTHENTICATION_REQUIREMENTS),
|
||||
DAEMON_OPCODE_SM_SET_IO_CAPABILITIES = DAEMON_OPCODE(SM_SET_IO_CAPABILITIES),
|
||||
DAEMON_OPCODE_SM_BONDING_DECLINE = DAEMON_OPCODE(SM_BONDING_DECLINE),
|
||||
DAEMON_OPCODE_SM_JUST_WORKS_CONFIRM = DAEMON_OPCODE(SM_JUST_WORKS_CONFIRM),
|
||||
DAEMON_OPCODE_SM_NUMERIC_COMPARISON_CONFIRM = DAEMON_OPCODE(SM_NUMERIC_COMPARISON_CONFIRM),
|
||||
DAEMON_OPCODE_SM_PASSKEY_INPUT = DAEMON_OPCODE(SM_PASSKEY_INPUT),
|
||||
} daemon_opcode_t;
|
||||
|
||||
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;
|
||||
|
365
src/hci_cmd.c
365
src/hci_cmd.c
File diff suppressed because it is too large
Load Diff
138
src/hci_cmd.h
138
src/hci_cmd.h
@ -54,6 +54,9 @@
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
// calculate hci opcode for ogf/ocf value
|
||||
#define HCI_OPCODE(ogf, ocf) ((ocf) | ((ogf) << 10))
|
||||
|
||||
/**
|
||||
* Hardware state of Bluetooth controller
|
||||
*/
|
||||
@ -83,6 +86,141 @@ typedef enum {
|
||||
const char *format;
|
||||
} hci_cmd_t;
|
||||
|
||||
typedef enum {
|
||||
HCI_OPCODE_HCI_INQUIRY = HCI_OPCODE (OGF_LINK_CONTROL, 0x01),
|
||||
HCI_OPCODE_HCI_INQUIRY_CANCEL = HCI_OPCODE (OGF_LINK_CONTROL, 0x02),
|
||||
HCI_OPCODE_HCI_CREATE_CONNECTION = HCI_OPCODE (OGF_LINK_CONTROL, 0x05),
|
||||
HCI_OPCODE_HCI_DISCONNECT = HCI_OPCODE (OGF_LINK_CONTROL, 0x06),
|
||||
HCI_OPCODE_HCI_CREATE_CONNECTION_CANCEL = HCI_OPCODE (OGF_LINK_CONTROL, 0x08),
|
||||
HCI_OPCODE_HCI_ACCEPT_CONNECTION_REQUEST = HCI_OPCODE (OGF_LINK_CONTROL, 0x09),
|
||||
HCI_OPCODE_HCI_REJECT_CONNECTION_REQUEST = HCI_OPCODE (OGF_LINK_CONTROL, 0x0a),
|
||||
HCI_OPCODE_HCI_LINK_KEY_REQUEST_REPLY = HCI_OPCODE (OGF_LINK_CONTROL, 0x0b),
|
||||
HCI_OPCODE_HCI_LINK_KEY_REQUEST_NEGATIVE_REPLY = HCI_OPCODE (OGF_LINK_CONTROL, 0x0c),
|
||||
HCI_OPCODE_HCI_PIN_CODE_REQUEST_REPLY = HCI_OPCODE (OGF_LINK_CONTROL, 0x0d),
|
||||
HCI_OPCODE_HCI_PIN_CODE_REQUEST_NEGATIVE_REPLY = HCI_OPCODE (OGF_LINK_CONTROL, 0x0e),
|
||||
HCI_OPCODE_HCI_CHANGE_CONNECTION_PACKET_TYPE = HCI_OPCODE (OGF_LINK_CONTROL, 0x0f),
|
||||
HCI_OPCODE_HCI_AUTHENTICATION_REQUESTED = HCI_OPCODE (OGF_LINK_CONTROL, 0x11),
|
||||
HCI_OPCODE_HCI_SET_CONNECTION_ENCRYPTION = HCI_OPCODE (OGF_LINK_CONTROL, 0x13),
|
||||
HCI_OPCODE_HCI_CHANGE_CONNECTION_LINK_KEY = HCI_OPCODE (OGF_LINK_CONTROL, 0x15),
|
||||
HCI_OPCODE_HCI_REMOTE_NAME_REQUEST = HCI_OPCODE (OGF_LINK_CONTROL, 0x19),
|
||||
HCI_OPCODE_HCI_REMOTE_NAME_REQUEST_CANCEL = HCI_OPCODE (OGF_LINK_CONTROL, 0x1A),
|
||||
HCI_OPCODE_HCI_READ_REMOTE_SUPPORTED_FEATURES_COMMAND = HCI_OPCODE (OGF_LINK_CONTROL, 0x1B),
|
||||
HCI_OPCODE_HCI_READ_REMOTE_EXTENDED_FEATURES_COMMAND = HCI_OPCODE (OGF_LINK_CONTROL, 0x1C),
|
||||
HCI_OPCODE_HCI_READ_REMOTE_VERSION_INFORMATION = HCI_OPCODE (OGF_LINK_CONTROL, 0x1D),
|
||||
HCI_OPCODE_HCI_SETUP_SYNCHRONOUS_CONNECTION = HCI_OPCODE (OGF_LINK_CONTROL, 0x0028),
|
||||
HCI_OPCODE_HCI_ACCEPT_SYNCHRONOUS_CONNECTION = HCI_OPCODE (OGF_LINK_CONTROL, 0x0029),
|
||||
HCI_OPCODE_HCI_IO_CAPABILITY_REQUEST_REPLY = HCI_OPCODE (OGF_LINK_CONTROL, 0x2b),
|
||||
HCI_OPCODE_HCI_USER_CONFIRMATION_REQUEST_REPLY = HCI_OPCODE (OGF_LINK_CONTROL, 0x2c),
|
||||
HCI_OPCODE_HCI_USER_CONFIRMATION_REQUEST_NEGATIVE_REPLY = HCI_OPCODE (OGF_LINK_CONTROL, 0x2d),
|
||||
HCI_OPCODE_HCI_USER_PASSKEY_REQUEST_REPLY = HCI_OPCODE (OGF_LINK_CONTROL, 0x2e),
|
||||
HCI_OPCODE_HCI_USER_PASSKEY_REQUEST_NEGATIVE_REPLY = HCI_OPCODE (OGF_LINK_CONTROL, 0x2f),
|
||||
HCI_OPCODE_HCI_REMOTE_OOB_DATA_REQUEST_REPLY = HCI_OPCODE (OGF_LINK_CONTROL, 0x30),
|
||||
HCI_OPCODE_HCI_REMOTE_OOB_DATA_REQUEST_NEGATIVE_REPLY = HCI_OPCODE (OGF_LINK_CONTROL, 0x33),
|
||||
HCI_OPCODE_HCI_IO_CAPABILITY_REQUEST_NEGATIVE_REPLY = HCI_OPCODE (OGF_LINK_CONTROL, 0x34),
|
||||
HCI_OPCODE_HCI_ENHANCED_SETUP_SYNCHRONOUS_CONNECTION = HCI_OPCODE (OGF_LINK_CONTROL, 0x3d),
|
||||
HCI_OPCODE_HCI_ENHANCED_ACCEPT_SYNCHRONOUS_CONNECTION = HCI_OPCODE (OGF_LINK_CONTROL, 0x3e),
|
||||
HCI_OPCODE_HCI_SNIFF_MODE = HCI_OPCODE (OGF_LINK_POLICY, 0x03),
|
||||
HCI_OPCODE_HCI_EXIT_SNIFF_MODE = HCI_OPCODE (OGF_LINK_POLICY, 0x04),
|
||||
HCI_OPCODE_HCI_QOS_SETUP = HCI_OPCODE (OGF_LINK_POLICY, 0x07),
|
||||
HCI_OPCODE_HCI_ROLE_DISCOVERY = HCI_OPCODE (OGF_LINK_POLICY, 0x09),
|
||||
HCI_OPCODE_HCI_SWITCH_ROLE_COMMAND = HCI_OPCODE (OGF_LINK_POLICY, 0x0b),
|
||||
HCI_OPCODE_HCI_READ_LINK_POLICY_SETTINGS = HCI_OPCODE (OGF_LINK_POLICY, 0x0c),
|
||||
HCI_OPCODE_HCI_WRITE_LINK_POLICY_SETTINGS = HCI_OPCODE (OGF_LINK_POLICY, 0x0d),
|
||||
HCI_OPCODE_HCI_WRITE_DEFAULT_LINK_POLICY_SETTING = HCI_OPCODE (OGF_LINK_POLICY, 0x0F),
|
||||
HCI_OPCODE_HCI_SET_EVENT_MASK = HCI_OPCODE (OGF_CONTROLLER_BASEBAND, 0x01),
|
||||
HCI_OPCODE_HCI_RESET = HCI_OPCODE (OGF_CONTROLLER_BASEBAND, 0x03),
|
||||
HCI_OPCODE_HCI_FLUSH = HCI_OPCODE (OGF_CONTROLLER_BASEBAND, 0x08),
|
||||
HCI_OPCODE_HCI_READ_PIN_TYPE = HCI_OPCODE (OGF_CONTROLLER_BASEBAND, 0x09),
|
||||
HCI_OPCODE_HCI_WRITE_PIN_TYPE = HCI_OPCODE (OGF_CONTROLLER_BASEBAND, 0x0A),
|
||||
HCI_OPCODE_HCI_DELETE_STORED_LINK_KEY = HCI_OPCODE (OGF_CONTROLLER_BASEBAND, 0x12),
|
||||
HCI_OPCODE_HCI_WRITE_LOCAL_NAME = HCI_OPCODE (OGF_CONTROLLER_BASEBAND, 0x13),
|
||||
HCI_OPCODE_HCI_READ_LOCAL_NAME = HCI_OPCODE (OGF_CONTROLLER_BASEBAND, 0x14),
|
||||
HCI_OPCODE_HCI_READ_PAGE_TIMEOUT = HCI_OPCODE (OGF_CONTROLLER_BASEBAND, 0x17),
|
||||
HCI_OPCODE_HCI_WRITE_PAGE_TIMEOUT = HCI_OPCODE (OGF_CONTROLLER_BASEBAND, 0x18),
|
||||
HCI_OPCODE_HCI_WRITE_SCAN_ENABLE = HCI_OPCODE (OGF_CONTROLLER_BASEBAND, 0x1A),
|
||||
HCI_OPCODE_HCI_READ_PAGE_SCAN_ACTIVITY = HCI_OPCODE (OGF_CONTROLLER_BASEBAND, 0x1B),
|
||||
HCI_OPCODE_HCI_WRITE_PAGE_SCAN_ACTIVITY = HCI_OPCODE (OGF_CONTROLLER_BASEBAND, 0x1C),
|
||||
HCI_OPCODE_HCI_READ_INQUIRY_SCAN_ACTIVITY = HCI_OPCODE (OGF_CONTROLLER_BASEBAND, 0x1D),
|
||||
HCI_OPCODE_HCI_WRITE_INQUIRY_SCAN_ACTIVITY = HCI_OPCODE (OGF_CONTROLLER_BASEBAND, 0x1E),
|
||||
HCI_OPCODE_HCI_WRITE_AUTHENTICATION_ENABLE = HCI_OPCODE (OGF_CONTROLLER_BASEBAND, 0x20),
|
||||
HCI_OPCODE_HCI_WRITE_CLASS_OF_DEVICE = HCI_OPCODE (OGF_CONTROLLER_BASEBAND, 0x24),
|
||||
HCI_OPCODE_HCI_READ_NUM_BROADCAST_RETRANSMISSIONS = HCI_OPCODE (OGF_CONTROLLER_BASEBAND, 0x29),
|
||||
HCI_OPCODE_HCI_WRITE_NUM_BROADCAST_RETRANSMISSIONS = HCI_OPCODE (OGF_CONTROLLER_BASEBAND, 0x2a),
|
||||
HCI_OPCODE_HCI_READ_TRANSMIT_POWER_LEVEL = HCI_OPCODE (OGF_CONTROLLER_BASEBAND, 0x2D),
|
||||
HCI_OPCODE_HCI_WRITE_SYNCHRONOUS_FLOW_CONTROL_ENABLE = HCI_OPCODE (OGF_CONTROLLER_BASEBAND, 0x2f),
|
||||
HCI_OPCODE_HCI_SET_CONTROLLER_TO_HOST_FLOW_CONTROL = HCI_OPCODE (OGF_CONTROLLER_BASEBAND, 0x31),
|
||||
HCI_OPCODE_HCI_HOST_BUFFER_SIZE = HCI_OPCODE (OGF_CONTROLLER_BASEBAND, 0x33),
|
||||
HCI_OPCODE_HCI_HOST_NUMBER_OF_COMPLETED_PACKETS = HCI_OPCODE (OGF_CONTROLLER_BASEBAND, 0x35),
|
||||
HCI_OPCODE_HCI_READ_LINK_SUPERVISION_TIMEOUT = HCI_OPCODE (OGF_CONTROLLER_BASEBAND, 0x36),
|
||||
HCI_OPCODE_HCI_WRITE_LINK_SUPERVISION_TIMEOUT = HCI_OPCODE (OGF_CONTROLLER_BASEBAND, 0x37),
|
||||
HCI_OPCODE_HCI_WRITE_CURRENT_IAC_LAP_TWO_IACS = HCI_OPCODE (OGF_CONTROLLER_BASEBAND, 0x3A),
|
||||
HCI_OPCODE_HCI_WRITE_INQUIRY_MODE = HCI_OPCODE (OGF_CONTROLLER_BASEBAND, 0x45),
|
||||
HCI_OPCODE_HCI_WRITE_EXTENDED_INQUIRY_RESPONSE = HCI_OPCODE (OGF_CONTROLLER_BASEBAND, 0x52),
|
||||
HCI_OPCODE_HCI_WRITE_SIMPLE_PAIRING_MODE = HCI_OPCODE (OGF_CONTROLLER_BASEBAND, 0x56),
|
||||
HCI_OPCODE_HCI_READ_LOCAL_OOB_DATA = HCI_OPCODE (OGF_CONTROLLER_BASEBAND, 0x57),
|
||||
HCI_OPCODE_HCI_WRITE_DEFAULT_ERRONEOUS_DATA_REPORTING = HCI_OPCODE (OGF_CONTROLLER_BASEBAND, 0x5B),
|
||||
HCI_OPCODE_HCI_READ_LE_HOST_SUPPORTED = HCI_OPCODE (OGF_CONTROLLER_BASEBAND, 0x6c),
|
||||
HCI_OPCODE_HCI_WRITE_LE_HOST_SUPPORTED = HCI_OPCODE (OGF_CONTROLLER_BASEBAND, 0x6d),
|
||||
HCI_OPCODE_HCI_WRITE_SECURE_CONNECTIONS_HOST_SUPPORT = HCI_OPCODE (OGF_CONTROLLER_BASEBAND, 0x7a),
|
||||
HCI_OPCODE_HCI_READ_LOCAL_EXTENDED_OB_DATA = HCI_OPCODE (OGF_CONTROLLER_BASEBAND, 0x7d),
|
||||
HCI_OPCODE_HCI_READ_LOOPBACK_MODE = HCI_OPCODE (OGF_TESTING, 0x01),
|
||||
HCI_OPCODE_HCI_WRITE_LOOPBACK_MODE = HCI_OPCODE (OGF_TESTING, 0x02),
|
||||
HCI_OPCODE_HCI_ENABLE_DEVICE_UNDER_TEST_MODE = HCI_OPCODE (OGF_TESTING, 0x03),
|
||||
HCI_OPCODE_HCI_WRITE_SIMPLE_PAIRING_DEBUG_MODE = HCI_OPCODE (OGF_TESTING, 0x04),
|
||||
HCI_OPCODE_HCI_WRITE_SECURE_CONNECTIONS_TEST_MODE = HCI_OPCODE (OGF_TESTING, 0x0a),
|
||||
HCI_OPCODE_HCI_READ_LOCAL_VERSION_INFORMATION = HCI_OPCODE (OGF_INFORMATIONAL_PARAMETERS, 0x01),
|
||||
HCI_OPCODE_HCI_READ_LOCAL_SUPPORTED_COMMANDS = HCI_OPCODE (OGF_INFORMATIONAL_PARAMETERS, 0x02),
|
||||
HCI_OPCODE_HCI_READ_LOCAL_SUPPORTED_FEATURES = HCI_OPCODE (OGF_INFORMATIONAL_PARAMETERS, 0x03),
|
||||
HCI_OPCODE_HCI_READ_BUFFER_SIZE = HCI_OPCODE (OGF_INFORMATIONAL_PARAMETERS, 0x05),
|
||||
HCI_OPCODE_HCI_READ_BD_ADDR = HCI_OPCODE (OGF_INFORMATIONAL_PARAMETERS, 0x09),
|
||||
HCI_OPCODE_HCI_READ_RSSI = HCI_OPCODE (OGF_STATUS_PARAMETERS, 0x05),
|
||||
HCI_OPCODE_HCI_READ_ENCRYPTION_KEY_SIZE = HCI_OPCODE (OGF_STATUS_PARAMETERS, 0x08),
|
||||
HCI_OPCODE_HCI_LE_SET_EVENT_MASK = HCI_OPCODE (OGF_LE_CONTROLLER, 0x01),
|
||||
HCI_OPCODE_HCI_LE_READ_BUFFER_SIZE = HCI_OPCODE (OGF_LE_CONTROLLER, 0x02),
|
||||
HCI_OPCODE_HCI_LE_READ_SUPPORTED_FEATURES = HCI_OPCODE (OGF_LE_CONTROLLER, 0x03),
|
||||
HCI_OPCODE_HCI_LE_SET_RANDOM_ADDRESS = HCI_OPCODE (OGF_LE_CONTROLLER, 0x05),
|
||||
HCI_OPCODE_HCI_LE_SET_ADVERTISING_PARAMETERS = HCI_OPCODE (OGF_LE_CONTROLLER, 0x06),
|
||||
HCI_OPCODE_HCI_LE_READ_ADVERTISING_CHANNEL_TX_POWER = HCI_OPCODE (OGF_LE_CONTROLLER, 0x07),
|
||||
HCI_OPCODE_HCI_LE_SET_ADVERTISING_DATA = HCI_OPCODE (OGF_LE_CONTROLLER, 0x08),
|
||||
HCI_OPCODE_HCI_LE_SET_SCAN_RESPONSE_DATA = HCI_OPCODE (OGF_LE_CONTROLLER, 0x09),
|
||||
HCI_OPCODE_HCI_LE_SET_ADVERTISE_ENABLE = HCI_OPCODE (OGF_LE_CONTROLLER, 0x0a),
|
||||
HCI_OPCODE_HCI_LE_SET_SCAN_PARAMETERS = HCI_OPCODE (OGF_LE_CONTROLLER, 0x0b),
|
||||
HCI_OPCODE_HCI_LE_SET_SCAN_ENABLE = HCI_OPCODE (OGF_LE_CONTROLLER, 0x0c),
|
||||
HCI_OPCODE_HCI_LE_CREATE_CONNECTION = HCI_OPCODE (OGF_LE_CONTROLLER, 0x0d),
|
||||
HCI_OPCODE_HCI_LE_CREATE_CONNECTION_CANCEL = HCI_OPCODE (OGF_LE_CONTROLLER, 0x0e),
|
||||
HCI_OPCODE_HCI_LE_READ_WHITE_LIST_SIZE = HCI_OPCODE (OGF_LE_CONTROLLER, 0x0f),
|
||||
HCI_OPCODE_HCI_LE_CLEAR_WHITE_LIST = HCI_OPCODE (OGF_LE_CONTROLLER, 0x10),
|
||||
HCI_OPCODE_HCI_LE_ADD_DEVICE_TO_WHITE_LIST = HCI_OPCODE (OGF_LE_CONTROLLER, 0x11),
|
||||
HCI_OPCODE_HCI_LE_REMOVE_DEVICE_FROM_WHITE_LIST = HCI_OPCODE (OGF_LE_CONTROLLER, 0x12),
|
||||
HCI_OPCODE_HCI_LE_CONNECTION_UPDATE = HCI_OPCODE (OGF_LE_CONTROLLER, 0x13),
|
||||
HCI_OPCODE_HCI_LE_SET_HOST_CHANNEL_CLASSIFICATION = HCI_OPCODE (OGF_LE_CONTROLLER, 0x14),
|
||||
HCI_OPCODE_HCI_LE_READ_CHANNEL_MAP = HCI_OPCODE (OGF_LE_CONTROLLER, 0x15),
|
||||
HCI_OPCODE_HCI_LE_READ_REMOTE_USED_FEATURES = HCI_OPCODE (OGF_LE_CONTROLLER, 0x16),
|
||||
HCI_OPCODE_HCI_LE_ENCRYPT = HCI_OPCODE (OGF_LE_CONTROLLER, 0x17),
|
||||
HCI_OPCODE_HCI_LE_RAND = HCI_OPCODE (OGF_LE_CONTROLLER, 0x18),
|
||||
HCI_OPCODE_HCI_LE_START_ENCRYPTION = HCI_OPCODE (OGF_LE_CONTROLLER, 0x19),
|
||||
HCI_OPCODE_HCI_LE_LONG_TERM_KEY_REQUEST_REPLY = HCI_OPCODE (OGF_LE_CONTROLLER, 0x1a),
|
||||
HCI_OPCODE_HCI_LE_LONG_TERM_KEY_NEGATIVE_REPLY = HCI_OPCODE (OGF_LE_CONTROLLER, 0x1b),
|
||||
HCI_OPCODE_HCI_LE_READ_SUPPORTED_STATES = HCI_OPCODE (OGF_LE_CONTROLLER, 0x1c),
|
||||
HCI_OPCODE_HCI_LE_RECEIVER_TEST = HCI_OPCODE (OGF_LE_CONTROLLER, 0x1d),
|
||||
HCI_OPCODE_HCI_LE_TRANSMITTER_TEST = HCI_OPCODE (OGF_LE_CONTROLLER, 0x1e),
|
||||
HCI_OPCODE_HCI_LE_TEST_END = HCI_OPCODE (OGF_LE_CONTROLLER, 0x1f),
|
||||
HCI_OPCODE_HCI_LE_REMOTE_CONNECTION_PARAMETER_REQUEST_REPLY = HCI_OPCODE (OGF_LE_CONTROLLER, 0x20),
|
||||
HCI_OPCODE_HCI_LE_REMOTE_CONNECTION_PARAMETER_REQUEST_NEGATIVE_REPLY = HCI_OPCODE (OGF_LE_CONTROLLER, 0x21),
|
||||
HCI_OPCODE_HCI_LE_SET_DATA_LENGTH = HCI_OPCODE (OGF_LE_CONTROLLER, 0x22),
|
||||
HCI_OPCODE_HCI_LE_READ_SUGGESTED_DEFAULT_DATA_LENGTH = HCI_OPCODE (OGF_LE_CONTROLLER, 0x23),
|
||||
HCI_OPCODE_HCI_LE_WRITE_SUGGESTED_DEFAULT_DATA_LENGTH = HCI_OPCODE (OGF_LE_CONTROLLER, 0x24),
|
||||
HCI_OPCODE_HCI_LE_READ_LOCAL_P256_PUBLIC_KEY = HCI_OPCODE (OGF_LE_CONTROLLER, 0x25),
|
||||
HCI_OPCODE_HCI_LE_GENERATE_DHKEY = HCI_OPCODE (OGF_LE_CONTROLLER, 0x26),
|
||||
HCI_OPCODE_HCI_LE_READ_MAXIMUM_DATA_LENGTH = HCI_OPCODE (OGF_LE_CONTROLLER, 0x2F),
|
||||
HCI_OPCODE_HCI_LE_READ_PHY = HCI_OPCODE (OGF_LE_CONTROLLER, 0x30),
|
||||
HCI_OPCODE_HCI_LE_SET_DEFAULT_PHY = HCI_OPCODE (OGF_LE_CONTROLLER, 0x31),
|
||||
HCI_OPCODE_HCI_LE_SET_PHY = HCI_OPCODE (OGF_LE_CONTROLLER, 0x32),
|
||||
HCI_OPCODE_HCI_BCM_WRITE_SCO_PCM_INT = HCI_OPCODE (0x3f, 0x1c),
|
||||
HCI_OPCODE_HCI_BCM_SET_SLEEP_MODE = HCI_OPCODE (0x3f, 0x0027),
|
||||
HCI_OPCODE_HCI_BCM_WRITE_TX_POWER_TABLE = HCI_OPCODE (0x3f, 0x1C9),
|
||||
HCI_OPCODE_HCI_BCM_SET_TX_PWR = HCI_OPCODE (0x3f, 0x1A5),
|
||||
} hci_opcode_t;
|
||||
|
||||
// HCI Commands - see hci_cmd.c for info on parameters
|
||||
extern const hci_cmd_t hci_accept_connection_request;
|
||||
|
Loading…
x
Reference in New Issue
Block a user