Skip to content

Commit f2221c0

Browse files
committed
Merge branch 'bugfix/ble_update_lib_20231201_v5.0' into 'release/v5.0'
update lib on release/v5.0 See merge request espressif/esp-idf!27586
2 parents 7c5cb10 + 38f9aa0 commit f2221c0

File tree

5 files changed

+38
-10
lines changed

5 files changed

+38
-10
lines changed

components/bt/controller/esp32c2/Kconfig.in

+25-4
Original file line numberDiff line numberDiff line change
@@ -253,7 +253,7 @@ config BT_LE_CONTROLLER_TASK_STACK_SIZE
253253
help
254254
This configures stack size of NimBLE controller task
255255

256-
config BT_LE_CONTROLLER_LOG_ENABLED
256+
menuconfig BT_LE_CONTROLLER_LOG_ENABLED
257257
bool "Controller log enable"
258258
default n
259259
help
@@ -264,21 +264,42 @@ config BT_LE_CONTROLLER_LOG_CTRL_ENABLED
264264
depends on BT_LE_CONTROLLER_LOG_ENABLED
265265
default y
266266
help
267-
Enable controller log module
267+
Enable controller log module
268268

269269
config BT_LE_CONTROLLER_LOG_HCI_ENABLED
270270
bool "enable HCI log module"
271271
depends on BT_LE_CONTROLLER_LOG_ENABLED
272272
default y
273273
help
274-
Enable hci log module
274+
Enable hci log module
275275

276276
config BT_LE_CONTROLLER_LOG_DUMP_ONLY
277277
bool "Controller log dump mode only"
278278
depends on BT_LE_CONTROLLER_LOG_ENABLED
279279
default y
280280
help
281-
Only operate in dump mode
281+
Only operate in dump mode
282+
283+
config BT_LE_LOG_CTRL_BUF1_SIZE
284+
int "size of the first BLE controller LOG buffer"
285+
depends on BT_LE_CONTROLLER_LOG_ENABLED
286+
default 4096
287+
help
288+
Configure the size of the first BLE controller LOG buffer.
289+
290+
config BT_LE_LOG_CTRL_BUF2_SIZE
291+
int "size of the second BLE controller LOG buffer"
292+
depends on BT_LE_CONTROLLER_LOG_ENABLED
293+
default 1024
294+
help
295+
Configure the size of the second BLE controller LOG buffer.
296+
297+
config BT_LE_LOG_HCI_BUF_SIZE
298+
int "size of the BLE HCI LOG buffer"
299+
depends on BT_LE_CONTROLLER_LOG_ENABLED
300+
default 4096
301+
help
302+
Configure the size of the BLE HCI LOG buffer.
282303

283304
config BT_LE_LL_RESOLV_LIST_SIZE
284305
int "BLE LL Resolving list size"

components/bt/controller/esp32c2/bt.c

+4-3
Original file line numberDiff line numberDiff line change
@@ -78,7 +78,6 @@
7878
#define ACL_DATA_MBUF_LEADINGSPCAE 4
7979
#endif // CONFIG_BT_BLUEDROID_ENABLED
8080

81-
8281
/* Types definition
8382
************************************************************************
8483
*/
@@ -128,6 +127,7 @@ extern int ble_controller_init(esp_bt_controller_config_t *cfg);
128127
extern int ble_log_init_async(interface_func_t bt_controller_log_interface, bool task_create, uint8_t buffers, uint32_t *bufs_size);
129128
extern int ble_log_deinit_async(void);
130129
extern void ble_log_async_output_dump_all(bool output);
130+
extern void esp_panic_handler_reconfigure_wdts(void);
131131
#endif // CONFIG_BT_LE_CONTROLLER_LOG_ENABLED
132132
extern int ble_controller_deinit(void);
133133
extern int ble_controller_enable(uint8_t mode);
@@ -202,7 +202,7 @@ static void esp_bt_controller_log_interface(uint32_t len, const uint8_t *addr, b
202202
static DRAM_ATTR esp_bt_controller_status_t ble_controller_status = ESP_BT_CONTROLLER_STATUS_IDLE;
203203

204204
#if CONFIG_BT_LE_CONTROLLER_LOG_ENABLED
205-
const static uint32_t log_bufs_size[] = {2048, 1024, 1024};
205+
const static uint32_t log_bufs_size[] = {CONFIG_BT_LE_LOG_CTRL_BUF1_SIZE, CONFIG_BT_LE_LOG_HCI_BUF_SIZE, CONFIG_BT_LE_LOG_CTRL_BUF2_SIZE};
206206
#endif // CONFIG_BT_LE_CONTROLLER_LOG_ENABLED
207207

208208
/* This variable tells if BLE is running */
@@ -1015,9 +1015,10 @@ static void esp_bt_controller_log_interface(uint32_t len, const uint8_t *addr, b
10151015

10161016
void esp_ble_controller_log_dump_all(bool output)
10171017
{
1018-
portMUX_TYPE spinlock;
1018+
portMUX_TYPE spinlock = portMUX_INITIALIZER_UNLOCKED;
10191019

10201020
portENTER_CRITICAL_SAFE(&spinlock);
1021+
esp_panic_handler_reconfigure_wdts(5000);
10211022
BT_ASSERT_PRINT("\r\n[DUMP_START:");
10221023
ble_log_async_output_dump_all(output);
10231024
BT_ASSERT_PRINT("]\r\n");

components/bt/include/esp32c2/include/esp_bt.h

+2-2
Original file line numberDiff line numberDiff line change
@@ -223,7 +223,7 @@ typedef struct {
223223
uint8_t cca_drop_mode; /*!< CCA drop mode */
224224
int8_t cca_low_tx_pwr; /*!< Low TX power setting for CCA */
225225
uint8_t main_xtal_freq; /*!< Main crystal frequency */
226-
uint32_t version_num; /*!< Version number */
226+
uint8_t version_num; /*!< Version number */
227227
uint8_t ignore_wl_for_direct_adv; /*!< Ignore the white list for directed advertising */
228228
uint32_t config_magic; /*!< Configuration magic value */
229229
} esp_bt_controller_config_t;
@@ -275,7 +275,7 @@ typedef struct {
275275
.dis_scan_backoff = NIMBLE_DISABLE_SCAN_BACKOFF, \
276276
.ble_scan_classify_filter_enable = 0, \
277277
.main_xtal_freq = CONFIG_XTAL_FREQ, \
278-
.version_num = efuse_hal_chip_revision(), \
278+
.version_num = esp_ble_get_chip_rev_version(), \
279279
.ignore_wl_for_direct_adv = 0, \
280280
.config_magic = CONFIG_MAGIC, \
281281
}

components/bt/porting/npl/freertos/src/npl_os_freertos.c

+6
Original file line numberDiff line numberDiff line change
@@ -133,6 +133,9 @@ npl_freertos_eventq_init(struct ble_npl_eventq *evq)
133133
memset(eventq, 0, sizeof(*eventq));
134134
eventq->q = xQueueCreate(ble_freertos_total_event_cnt, sizeof(struct ble_npl_eventq *));
135135
BLE_LL_ASSERT(eventq->q);
136+
} else {
137+
eventq = (struct ble_npl_eventq_freertos*)evq->eventq;
138+
xQueueReset(eventq->q);
136139
}
137140
#else
138141
if(!evq->eventq) {
@@ -142,6 +145,9 @@ npl_freertos_eventq_init(struct ble_npl_eventq *evq)
142145
memset(eventq, 0, sizeof(*eventq));
143146
eventq->q = xQueueCreate(ble_freertos_total_event_cnt, sizeof(struct ble_npl_eventq *));
144147
BLE_LL_ASSERT(eventq->q);
148+
} else {
149+
eventq = (struct ble_npl_eventq_freertos*)evq->eventq;
150+
xQueueReset(eventq->q);
145151
}
146152
#endif
147153
}

0 commit comments

Comments
 (0)