2016-09-26 09:37:39 -04:00
|
|
|
/******************************************************************************
|
|
|
|
*
|
|
|
|
* Copyright (C) 2000-2012 Broadcom Corporation
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at:
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*
|
|
|
|
******************************************************************************/
|
|
|
|
#include <string.h>
|
|
|
|
|
2018-04-08 00:10:50 -04:00
|
|
|
#include "common/bt_defs.h"
|
|
|
|
#include "common/bt_target.h"
|
|
|
|
#include "common/bt_trace.h"
|
|
|
|
#include "device/controller.h"
|
|
|
|
#include "osi/alarm.h"
|
|
|
|
#include "osi/hash_map.h"
|
|
|
|
#include "osi/hash_functions.h"
|
|
|
|
#include "osi/thread.h"
|
|
|
|
#include "osi/mutex.h"
|
2016-09-26 09:37:39 -04:00
|
|
|
|
|
|
|
#include "l2c_int.h"
|
2018-04-08 00:10:50 -04:00
|
|
|
#include "stack/dyn_mem.h"
|
|
|
|
#include "stack/btu.h"
|
2016-09-26 09:37:39 -04:00
|
|
|
#include "btm_int.h"
|
|
|
|
|
|
|
|
#if SDP_INCLUDED == TRUE
|
|
|
|
#include "sdpint.h"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if (BLE_INCLUDED == TRUE)
|
2018-04-08 00:10:50 -04:00
|
|
|
#include "stack/gatt_api.h"
|
2016-09-26 09:37:39 -04:00
|
|
|
#include "gatt_int.h"
|
|
|
|
#if SMP_INCLUDED == TRUE
|
|
|
|
#include "smp_int.h"
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
|
|
|
|
hash_map_t *btu_general_alarm_hash_map;
|
2017-08-17 09:13:45 -04:00
|
|
|
osi_mutex_t btu_general_alarm_lock;
|
2016-10-15 05:46:10 -04:00
|
|
|
static const size_t BTU_GENERAL_ALARM_HASH_MAP_SIZE = 34;
|
2016-09-26 09:37:39 -04:00
|
|
|
|
|
|
|
hash_map_t *btu_oneshot_alarm_hash_map;
|
2017-08-17 09:13:45 -04:00
|
|
|
osi_mutex_t btu_oneshot_alarm_lock;
|
2016-10-15 05:46:10 -04:00
|
|
|
static const size_t BTU_ONESHOT_ALARM_HASH_MAP_SIZE = 34;
|
2016-09-26 09:37:39 -04:00
|
|
|
|
|
|
|
hash_map_t *btu_l2cap_alarm_hash_map;
|
2017-08-17 09:13:45 -04:00
|
|
|
osi_mutex_t btu_l2cap_alarm_lock;
|
2016-10-15 05:46:10 -04:00
|
|
|
static const size_t BTU_L2CAP_ALARM_HASH_MAP_SIZE = 34;
|
2016-09-26 09:37:39 -04:00
|
|
|
|
|
|
|
//thread_t *bt_workqueue_thread;
|
|
|
|
//static const char *BT_WORKQUEUE_NAME = "bt_workqueue";
|
2016-10-10 09:34:21 -04:00
|
|
|
xTaskHandle xBtuTaskHandle = NULL;
|
|
|
|
xQueueHandle xBtuQueue = 0;
|
2016-09-26 09:37:39 -04:00
|
|
|
|
|
|
|
extern void PLATFORM_DisableHciTransport(UINT8 bDisable);
|
|
|
|
|
2016-10-10 09:34:21 -04:00
|
|
|
extern void btu_task_thread_handler(void *arg);
|
|
|
|
void btu_task_start_up(void);
|
|
|
|
void btu_task_shut_down(void);
|
2016-09-26 09:37:39 -04:00
|
|
|
/*****************************************************************************
|
|
|
|
** V A R I A B L E S *
|
|
|
|
******************************************************************************/
|
|
|
|
// TODO(cmanton) Move this out of this file
|
|
|
|
const BD_ADDR BT_BD_ANY = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
|
|
|
|
/*****************************************************************************
|
|
|
|
**
|
|
|
|
** Function btu_init_core
|
|
|
|
**
|
|
|
|
** Description Initialize control block memory for each core component.
|
|
|
|
**
|
|
|
|
**
|
|
|
|
** Returns void
|
|
|
|
**
|
|
|
|
******************************************************************************/
|
|
|
|
void btu_init_core(void)
|
|
|
|
{
|
|
|
|
/* Initialize the mandatory core stack components */
|
|
|
|
btm_init();
|
|
|
|
|
|
|
|
l2c_init();
|
|
|
|
|
|
|
|
#if (defined(SDP_INCLUDED) && SDP_INCLUDED == TRUE)
|
|
|
|
sdp_init();
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if BLE_INCLUDED == TRUE
|
|
|
|
#if (defined(GATT_INCLUDED) && GATT_INCLUDED == true)
|
|
|
|
gatt_init();
|
|
|
|
#endif
|
|
|
|
#if (defined(SMP_INCLUDED) && SMP_INCLUDED == TRUE)
|
|
|
|
SMP_Init();
|
|
|
|
#endif
|
|
|
|
btm_ble_init();
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
/*****************************************************************************
|
|
|
|
**
|
|
|
|
** Function btu_free_core
|
|
|
|
**
|
|
|
|
** Description Releases control block memory for each core component.
|
|
|
|
**
|
|
|
|
**
|
|
|
|
** Returns void
|
|
|
|
**
|
|
|
|
******************************************************************************/
|
|
|
|
void btu_free_core(void)
|
|
|
|
{
|
2016-11-24 13:10:15 -05:00
|
|
|
// Free the mandatory core stack components
|
|
|
|
l2c_free();
|
2016-09-26 09:37:39 -04:00
|
|
|
|
2018-03-15 02:36:49 -04:00
|
|
|
#if (defined(SDP_INCLUDED) && SDP_INCLUDED == TRUE)
|
|
|
|
sdp_deinit();
|
|
|
|
#endif
|
|
|
|
|
2016-09-26 09:37:39 -04:00
|
|
|
#if BLE_INCLUDED == TRUE
|
2017-10-18 03:34:43 -04:00
|
|
|
#if (defined(GATT_INCLUDED) && GATT_INCLUDED == true)
|
2016-11-24 13:10:15 -05:00
|
|
|
gatt_free();
|
2016-09-26 09:37:39 -04:00
|
|
|
#endif
|
2017-08-17 09:13:45 -04:00
|
|
|
btm_ble_free();
|
2016-09-26 09:37:39 -04:00
|
|
|
#endif
|
2017-08-17 09:13:45 -04:00
|
|
|
btm_free();
|
2017-10-18 03:34:43 -04:00
|
|
|
#if SMP_INCLUDED == TRUE
|
|
|
|
SMP_Free();
|
|
|
|
#endif
|
2016-09-26 09:37:39 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
/*****************************************************************************
|
|
|
|
**
|
|
|
|
** Function BTU_StartUp
|
|
|
|
**
|
|
|
|
** Description Initializes the BTU control block.
|
|
|
|
**
|
|
|
|
** NOTE: Must be called before creating any tasks
|
|
|
|
** (RPC, BTU, HCIT, APPL, etc.)
|
|
|
|
**
|
|
|
|
** Returns void
|
|
|
|
**
|
|
|
|
******************************************************************************/
|
2020-04-14 23:25:20 -04:00
|
|
|
#if (CONFIG_SPIRAM_USE_MALLOC && CONFIG_BT_ALLOCATION_FROM_SPIRAM_FIRST)
|
|
|
|
StaticQueue_t *btu_queue_buffer = NULL;
|
|
|
|
uint8_t *btu_queue_storage = NULL;
|
|
|
|
#endif
|
2016-09-26 09:37:39 -04:00
|
|
|
void BTU_StartUp(void)
|
|
|
|
{
|
2017-10-18 03:34:43 -04:00
|
|
|
#if BTU_DYNAMIC_MEMORY
|
|
|
|
btu_cb_ptr = (tBTU_CB *)osi_malloc(sizeof(tBTU_CB));
|
|
|
|
#endif /* #if BTU_DYNAMIC_MEMORY */
|
2016-09-26 09:37:39 -04:00
|
|
|
memset (&btu_cb, 0, sizeof (tBTU_CB));
|
|
|
|
btu_cb.trace_level = HCI_INITIAL_TRACE_LEVEL;
|
|
|
|
|
|
|
|
btu_general_alarm_hash_map = hash_map_new(BTU_GENERAL_ALARM_HASH_MAP_SIZE,
|
2016-11-24 13:10:15 -05:00
|
|
|
hash_function_pointer, NULL, (data_free_fn)osi_alarm_free, NULL);
|
|
|
|
if (btu_general_alarm_hash_map == NULL) {
|
2016-09-26 09:37:39 -04:00
|
|
|
goto error_exit;
|
2016-11-24 13:10:15 -05:00
|
|
|
}
|
2016-09-26 09:37:39 -04:00
|
|
|
|
2017-08-17 09:13:45 -04:00
|
|
|
osi_mutex_new(&btu_general_alarm_lock);
|
2016-09-26 09:37:39 -04:00
|
|
|
|
|
|
|
btu_oneshot_alarm_hash_map = hash_map_new(BTU_ONESHOT_ALARM_HASH_MAP_SIZE,
|
2016-11-24 13:10:15 -05:00
|
|
|
hash_function_pointer, NULL, (data_free_fn)osi_alarm_free, NULL);
|
|
|
|
if (btu_oneshot_alarm_hash_map == NULL) {
|
2016-09-26 09:37:39 -04:00
|
|
|
goto error_exit;
|
2016-11-24 13:10:15 -05:00
|
|
|
}
|
2016-09-26 09:37:39 -04:00
|
|
|
|
2017-08-17 09:13:45 -04:00
|
|
|
osi_mutex_new(&btu_oneshot_alarm_lock);
|
2016-09-26 09:37:39 -04:00
|
|
|
|
|
|
|
btu_l2cap_alarm_hash_map = hash_map_new(BTU_L2CAP_ALARM_HASH_MAP_SIZE,
|
2016-11-24 13:10:15 -05:00
|
|
|
hash_function_pointer, NULL, (data_free_fn)osi_alarm_free, NULL);
|
|
|
|
if (btu_l2cap_alarm_hash_map == NULL) {
|
2016-09-26 09:37:39 -04:00
|
|
|
goto error_exit;
|
2016-11-24 13:10:15 -05:00
|
|
|
}
|
2016-09-26 09:37:39 -04:00
|
|
|
|
2017-08-17 09:13:45 -04:00
|
|
|
osi_mutex_new(&btu_l2cap_alarm_lock);
|
2016-09-26 09:37:39 -04:00
|
|
|
|
2020-04-14 23:25:20 -04:00
|
|
|
#if (CONFIG_SPIRAM_USE_MALLOC && CONFIG_BT_ALLOCATION_FROM_SPIRAM_FIRST)
|
|
|
|
btu_queue_buffer = heap_caps_malloc(sizeof(StaticQueue_t), MALLOC_CAP_INTERNAL|MALLOC_CAP_8BIT);
|
|
|
|
if (!btu_queue_buffer) {
|
|
|
|
BTC_TRACE_ERROR("Btu Queue malloc fail in PSRAM.\n");
|
|
|
|
goto error_exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
btu_queue_storage = heap_caps_malloc((BTU_QUEUE_LEN*sizeof(BtTaskEvt_t)), MALLOC_CAP_SPIRAM|MALLOC_CAP_8BIT);
|
|
|
|
if (!btu_queue_storage ) {
|
|
|
|
BTC_TRACE_ERROR("Btu Queue malloc fail in PSRAM.\n");
|
|
|
|
goto error_exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
xBtuQueue = xQueueCreateStatic(BTU_QUEUE_LEN, sizeof(BtTaskEvt_t), btu_queue_storage, btu_queue_buffer);
|
|
|
|
BTC_TRACE_API("Btu Queue malloc in PSRAM Success.\n");
|
|
|
|
#else
|
|
|
|
BTC_TRACE_API("xBtuQueue in internal RAM.");
|
2017-10-20 05:09:03 -04:00
|
|
|
xBtuQueue = xQueueCreate(BTU_QUEUE_LEN, sizeof(BtTaskEvt_t));
|
2020-04-14 23:25:20 -04:00
|
|
|
#endif
|
|
|
|
|
2017-10-20 05:09:03 -04:00
|
|
|
xTaskCreatePinnedToCore(btu_task_thread_handler, BTU_TASK_NAME, BTU_TASK_STACK_SIZE, NULL, BTU_TASK_PRIO, &xBtuTaskHandle, BTU_TASK_PINNED_TO_CORE);
|
2017-01-23 03:11:27 -05:00
|
|
|
|
|
|
|
btu_task_post(SIG_BTU_START_UP, NULL, TASK_POST_BLOCKING);
|
|
|
|
|
2016-09-26 09:37:39 -04:00
|
|
|
return;
|
|
|
|
|
2020-04-14 23:25:20 -04:00
|
|
|
error_exit:
|
2016-09-26 09:37:39 -04:00
|
|
|
LOG_ERROR("%s Unable to allocate resources for bt_workqueue", __func__);
|
|
|
|
BTU_ShutDown();
|
|
|
|
}
|
|
|
|
|
2016-11-24 13:10:15 -05:00
|
|
|
void BTU_ShutDown(void)
|
|
|
|
{
|
2017-10-18 03:34:43 -04:00
|
|
|
#if BTU_DYNAMIC_MEMORY
|
|
|
|
FREE_AND_RESET(btu_cb_ptr);
|
|
|
|
#endif
|
2016-11-24 13:10:15 -05:00
|
|
|
btu_task_shut_down();
|
2016-12-12 15:10:44 -05:00
|
|
|
|
2016-11-24 13:10:15 -05:00
|
|
|
hash_map_free(btu_general_alarm_hash_map);
|
2017-08-17 09:13:45 -04:00
|
|
|
osi_mutex_free(&btu_general_alarm_lock);
|
2016-09-26 09:37:39 -04:00
|
|
|
|
2016-11-24 13:10:15 -05:00
|
|
|
hash_map_free(btu_oneshot_alarm_hash_map);
|
2017-08-17 09:13:45 -04:00
|
|
|
osi_mutex_free(&btu_oneshot_alarm_lock);
|
2016-09-26 09:37:39 -04:00
|
|
|
|
2016-11-24 13:10:15 -05:00
|
|
|
hash_map_free(btu_l2cap_alarm_hash_map);
|
2017-08-17 09:13:45 -04:00
|
|
|
osi_mutex_free(&btu_l2cap_alarm_lock);
|
2016-09-26 09:37:39 -04:00
|
|
|
|
2016-11-24 13:10:15 -05:00
|
|
|
vTaskDelete(xBtuTaskHandle);
|
|
|
|
vQueueDelete(xBtuQueue);
|
2016-09-26 09:37:39 -04:00
|
|
|
|
2020-04-14 23:25:20 -04:00
|
|
|
#if (CONFIG_SPIRAM_USE_MALLOC && CONFIG_BT_ALLOCATION_FROM_SPIRAM_FIRST)
|
|
|
|
if(btu_queue_buffer){
|
|
|
|
heap_caps_free(btu_queue_buffer);
|
|
|
|
btu_queue_buffer = NULL;
|
|
|
|
}
|
|
|
|
if(btu_queue_storage){
|
|
|
|
heap_caps_free(btu_queue_storage);
|
|
|
|
btu_queue_storage = NULL;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2016-11-24 13:10:15 -05:00
|
|
|
btu_general_alarm_hash_map = NULL;
|
2016-09-26 09:37:39 -04:00
|
|
|
|
2016-11-24 13:10:15 -05:00
|
|
|
btu_oneshot_alarm_hash_map = NULL;
|
2016-09-26 09:37:39 -04:00
|
|
|
|
2016-11-24 13:10:15 -05:00
|
|
|
btu_l2cap_alarm_hash_map = NULL;
|
2016-09-26 09:37:39 -04:00
|
|
|
|
2016-11-24 13:10:15 -05:00
|
|
|
xBtuTaskHandle = NULL;
|
|
|
|
xBtuQueue = 0;
|
2016-09-26 09:37:39 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
/*****************************************************************************
|
|
|
|
**
|
|
|
|
** Function BTU_BleAclPktSize
|
|
|
|
**
|
|
|
|
** Description export the BLE ACL packet size.
|
|
|
|
**
|
|
|
|
** Returns UINT16
|
|
|
|
**
|
|
|
|
******************************************************************************/
|
|
|
|
UINT16 BTU_BleAclPktSize(void)
|
|
|
|
{
|
|
|
|
#if BLE_INCLUDED == TRUE
|
|
|
|
return controller_get_interface()->get_acl_packet_size_ble();
|
|
|
|
#else
|
|
|
|
return 0;
|
|
|
|
#endif
|
|
|
|
}
|
2018-07-01 22:59:51 -04:00
|
|
|
#if SCAN_QUEUE_CONGEST_CHECK
|
|
|
|
bool BTU_check_queue_is_congest(void)
|
|
|
|
{
|
|
|
|
UBaseType_t wait_size = uxQueueMessagesWaiting(xBtuQueue);
|
|
|
|
if(wait_size >= QUEUE_CONGEST_SIZE ) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
#endif
|