mirror of
https://github.com/bluekitchen/btstack.git
synced 2025-01-03 23:47:08 +00:00
hci: ENABLE_HCI_SERIALIZED_CONTROLLER_OPERATIONS serializes Inquiry, Remote Name Request and Create Connection operations
This commit is contained in:
parent
8ce1c2c25b
commit
6c0d5426fc
@ -9,6 +9,7 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0.
|
|||||||
## Unreleased
|
## Unreleased
|
||||||
|
|
||||||
### Added
|
### Added
|
||||||
|
- HCI: ENABLE_HCI_SERIALIZED_CONTROLLER_OPERATIONS serializes Inquiry, Remote Name Request and Create Connection operations
|
||||||
- GAP: support extended advertising with ENABLE_LE_EXTENDED_ADVERTISING
|
- GAP: support extended advertising with ENABLE_LE_EXTENDED_ADVERTISING
|
||||||
- ATT DB: provide gatt_server_get_handle_range_for_service_with_uuid16 to find included service within handle range
|
- ATT DB: provide gatt_server_get_handle_range_for_service_with_uuid16 to find included service within handle range
|
||||||
- GATT Service: Audio Input Control Service Server (AICS 1.0)
|
- GATT Service: Audio Input Control Service Server (AICS 1.0)
|
||||||
|
@ -100,6 +100,7 @@ ENABLE_L2CAP_ENHANCED_RETRANSMISSION_MODE | Enable Enhanced Retransmission Mode
|
|||||||
ENABLE_L2CAP_LE_CREDIT_BASED_FLOW_CONTROL_MODE | Enable LE credit-based flow-control mode for L2CAP channels
|
ENABLE_L2CAP_LE_CREDIT_BASED_FLOW_CONTROL_MODE | Enable LE credit-based flow-control mode for L2CAP channels
|
||||||
ENABLE_L2CAP_ENHANCED_CREDIT_BASED_FLOW_CONTROL_MODE | Enable Enhanced credit-based flow-control mode for L2CAP Channels
|
ENABLE_L2CAP_ENHANCED_CREDIT_BASED_FLOW_CONTROL_MODE | Enable Enhanced credit-based flow-control mode for L2CAP Channels
|
||||||
ENABLE_HCI_CONTROLLER_TO_HOST_FLOW_CONTROL | Enable HCI Controller to Host Flow Control, see below
|
ENABLE_HCI_CONTROLLER_TO_HOST_FLOW_CONTROL | Enable HCI Controller to Host Flow Control, see below
|
||||||
|
ENABLE_HCI_SERIALIZED_CONTROLLER_OPERATIONS | Serialize Inquiry, Remote Name Request, and Create Connection operations
|
||||||
ENABLE_ATT_DELAYED_RESPONSE | Enable support for delayed ATT operations, see [GATT Server](profiles/#sec:GATTServerProfile)
|
ENABLE_ATT_DELAYED_RESPONSE | Enable support for delayed ATT operations, see [GATT Server](profiles/#sec:GATTServerProfile)
|
||||||
ENABLE_BCM_PCM_WBS | Enable support for Wide-Band Speech codec in BCM controller, requires ENABLE_SCO_OVER_PCM
|
ENABLE_BCM_PCM_WBS | Enable support for Wide-Band Speech codec in BCM controller, requires ENABLE_SCO_OVER_PCM
|
||||||
ENABLE_CC256X_ASSISTED_HFP | Enable support for Assisted HFP mode in CC256x Controller, requires ENABLE_SCO_OVER_PCM
|
ENABLE_CC256X_ASSISTED_HFP | Enable support for Assisted HFP mode in CC256x Controller, requires ENABLE_SCO_OVER_PCM
|
||||||
|
40
src/hci.c
40
src/hci.c
@ -4517,6 +4517,31 @@ static bool hci_run_acl_fragments(void){
|
|||||||
}
|
}
|
||||||
|
|
||||||
#ifdef ENABLE_CLASSIC
|
#ifdef ENABLE_CLASSIC
|
||||||
|
|
||||||
|
#ifdef ENABLE_HCI_SERIALIZED_CONTROLLER_OPERATIONS
|
||||||
|
static bool hci_classic_operation_active(void) {
|
||||||
|
if (hci_stack->inquiry_state >= GAP_INQUIRY_STATE_W4_ACTIVE){
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (hci_stack->remote_name_state == GAP_REMOTE_NAME_STATE_W4_COMPLETE){
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
btstack_linked_item_t * it;
|
||||||
|
for (it = (btstack_linked_item_t *) hci_stack->connections; it != NULL; it = it->next) {
|
||||||
|
hci_connection_t *connection = (hci_connection_t *) it;
|
||||||
|
switch (connection->state) {
|
||||||
|
case SENT_CREATE_CONNECTION:
|
||||||
|
case SENT_CANCEL_CONNECTION:
|
||||||
|
case SENT_DISCONNECT:
|
||||||
|
return true;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
static bool hci_run_general_gap_classic(void){
|
static bool hci_run_general_gap_classic(void){
|
||||||
|
|
||||||
// assert stack is working and classic is active
|
// assert stack is working and classic is active
|
||||||
@ -4538,11 +4563,16 @@ static bool hci_run_general_gap_classic(void){
|
|||||||
|
|
||||||
// start/stop inquiry
|
// start/stop inquiry
|
||||||
if ((hci_stack->inquiry_state >= GAP_INQUIRY_DURATION_MIN) && (hci_stack->inquiry_state <= GAP_INQUIRY_DURATION_MAX)){
|
if ((hci_stack->inquiry_state >= GAP_INQUIRY_DURATION_MIN) && (hci_stack->inquiry_state <= GAP_INQUIRY_DURATION_MAX)){
|
||||||
|
#ifdef ENABLE_HCI_SERIALIZED_CONTROLLER_OPERATIONS
|
||||||
|
if (hci_classic_operation_active() == false)
|
||||||
|
#endif
|
||||||
|
{
|
||||||
uint8_t duration = hci_stack->inquiry_state;
|
uint8_t duration = hci_stack->inquiry_state;
|
||||||
hci_stack->inquiry_state = GAP_INQUIRY_STATE_W4_ACTIVE;
|
hci_stack->inquiry_state = GAP_INQUIRY_STATE_W4_ACTIVE;
|
||||||
hci_send_cmd(&hci_inquiry, hci_stack->inquiry_lap, duration, 0);
|
hci_send_cmd(&hci_inquiry, hci_stack->inquiry_lap, duration, 0);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
if (hci_stack->inquiry_state == GAP_INQUIRY_STATE_W2_CANCEL){
|
if (hci_stack->inquiry_state == GAP_INQUIRY_STATE_W2_CANCEL){
|
||||||
hci_stack->inquiry_state = GAP_INQUIRY_STATE_W4_CANCELLED;
|
hci_stack->inquiry_state = GAP_INQUIRY_STATE_W4_CANCELLED;
|
||||||
hci_send_cmd(&hci_inquiry_cancel);
|
hci_send_cmd(&hci_inquiry_cancel);
|
||||||
@ -4550,11 +4580,16 @@ static bool hci_run_general_gap_classic(void){
|
|||||||
}
|
}
|
||||||
// remote name request
|
// remote name request
|
||||||
if (hci_stack->remote_name_state == GAP_REMOTE_NAME_STATE_W2_SEND){
|
if (hci_stack->remote_name_state == GAP_REMOTE_NAME_STATE_W2_SEND){
|
||||||
|
#ifdef ENABLE_HCI_SERIALIZED_CONTROLLER_OPERATIONS
|
||||||
|
if (hci_classic_operation_active() == false)
|
||||||
|
#endif
|
||||||
|
{
|
||||||
hci_stack->remote_name_state = GAP_REMOTE_NAME_STATE_W4_COMPLETE;
|
hci_stack->remote_name_state = GAP_REMOTE_NAME_STATE_W4_COMPLETE;
|
||||||
hci_send_cmd(&hci_remote_name_request, hci_stack->remote_name_addr,
|
hci_send_cmd(&hci_remote_name_request, hci_stack->remote_name_addr,
|
||||||
hci_stack->remote_name_page_scan_repetition_mode, 0, hci_stack->remote_name_clock_offset);
|
hci_stack->remote_name_page_scan_repetition_mode, 0, hci_stack->remote_name_clock_offset);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
#ifdef ENABLE_CLASSIC_PAIRING_OOB
|
#ifdef ENABLE_CLASSIC_PAIRING_OOB
|
||||||
// Local OOB data
|
// Local OOB data
|
||||||
if (hci_stack->classic_read_local_oob_data){
|
if (hci_stack->classic_read_local_oob_data){
|
||||||
@ -5757,6 +5792,11 @@ uint8_t hci_send_cmd_packet(uint8_t *packet, int size){
|
|||||||
// create connection triggered in disconnect complete event, let's do it now
|
// create connection triggered in disconnect complete event, let's do it now
|
||||||
break;
|
break;
|
||||||
case SEND_CREATE_CONNECTION:
|
case SEND_CREATE_CONNECTION:
|
||||||
|
#ifdef ENABLE_HCI_SERIALIZED_CONTROLLER_OPERATIONS
|
||||||
|
if (hci_classic_operation_active()){
|
||||||
|
return ERROR_CODE_SUCCESS;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
// connection created by hci, e.g. dedicated bonding, but not executed yet, let's do it now
|
// connection created by hci, e.g. dedicated bonding, but not executed yet, let's do it now
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
Loading…
Reference in New Issue
Block a user