From 9b16f5d831754bcb637c125a126eaa0e0ce3b273 Mon Sep 17 00:00:00 2001 From: xiewenxiang Date: Mon, 1 Nov 2021 20:39:37 +0800 Subject: [PATCH] component/bt: fix crash when shutdown bt --- components/bt/controller/esp32/bt.c | 14 ++++++++------ components/bt/controller/lib_esp32 | 2 +- 2 files changed, 9 insertions(+), 7 deletions(-) diff --git a/components/bt/controller/esp32/bt.c b/components/bt/controller/esp32/bt.c index b50d676d15..09cdee59f7 100644 --- a/components/bt/controller/esp32/bt.c +++ b/components/bt/controller/esp32/bt.c @@ -239,6 +239,8 @@ extern uint8_t coex_schm_curr_period_get(void); extern void * coex_schm_curr_phase_get(void); extern int coex_wifi_channel_get(uint8_t *primary, uint8_t *secondary); extern int coex_register_wifi_channel_change_callback(void *cb); +/* Shutdown */ +extern void esp_bt_controller_shutdown(void); extern char _bss_start_btdm; extern char _bss_end_btdm; @@ -1787,13 +1789,13 @@ esp_err_t esp_bt_controller_deinit(void) static void bt_shutdown(void) { - esp_err_t ret = ESP_OK; - ESP_LOGD(BTDM_LOG_TAG, "stop Bluetooth"); - - ret = esp_bt_controller_disable(); - if (ESP_OK != ret) { - ESP_LOGW(BTDM_LOG_TAG, "controller disable ret=%d", ret); + if (btdm_controller_status != ESP_BT_CONTROLLER_STATUS_ENABLED) { + return; } + + esp_bt_controller_shutdown(); + esp_phy_disable(); + return; } diff --git a/components/bt/controller/lib_esp32 b/components/bt/controller/lib_esp32 index f26e741554..fe048744fc 160000 --- a/components/bt/controller/lib_esp32 +++ b/components/bt/controller/lib_esp32 @@ -1 +1 @@ -Subproject commit f26e741554f70f0fe0621924c26e89fb9ee8f765 +Subproject commit fe048744fce335ab75777f4a386885faf4acc250