mirror of
https://github.com/espressif/esp-idf.git
synced 2024-10-05 20:47:46 -04:00
Merge branch 'bugfix/btdm_a2dp_task_stack_size' into 'master'
component/bt: make A2DP source and sink task size configurable through menuconfig See merge request idf/esp-idf!1825
This commit is contained in:
commit
0f7d9cf7d3
@ -130,6 +130,16 @@ config A2DP_SRC_ENABLE
|
|||||||
bool "SOURCE"
|
bool "SOURCE"
|
||||||
endchoice
|
endchoice
|
||||||
|
|
||||||
|
config A2DP_SINK_TASK_STACK_SIZE
|
||||||
|
int "A2DP sink (audio stream decoding) task stack size"
|
||||||
|
depends on A2DP_ENABLE && A2DP_SINK_ENABLE
|
||||||
|
default 2048
|
||||||
|
|
||||||
|
config A2DP_SOURCE_TASK_STACK_SIZE
|
||||||
|
int "A2DP source (audio stream encoding) task stack size"
|
||||||
|
depends on A2DP_ENABLE && A2DP_SRC_ENABLE
|
||||||
|
default 2048
|
||||||
|
|
||||||
config BT_SPP_ENABLED
|
config BT_SPP_ENABLED
|
||||||
bool "SPP"
|
bool "SPP"
|
||||||
depends on CLASSIC_BT_ENABLED
|
depends on CLASSIC_BT_ENABLED
|
||||||
|
@ -176,7 +176,8 @@ esp_err_t esp_a2d_register_callback(esp_a2d_cb_t callback);
|
|||||||
/**
|
/**
|
||||||
* @brief Register A2DP sink data output function; For now the output is PCM data stream decoded
|
* @brief Register A2DP sink data output function; For now the output is PCM data stream decoded
|
||||||
* from SBC format. This function should be called only after esp_bluedroid_enable()
|
* from SBC format. This function should be called only after esp_bluedroid_enable()
|
||||||
* completes successfully, used only by A2DP sink.
|
* completes successfully, used only by A2DP sink. The callback is invoked in the context
|
||||||
|
* of A2DP sink task whose stack size is configurable through menuconfig
|
||||||
*
|
*
|
||||||
* @param[in] callback: A2DP sink data callback function
|
* @param[in] callback: A2DP sink data callback function
|
||||||
*
|
*
|
||||||
@ -291,7 +292,8 @@ esp_err_t esp_a2d_source_deinit(void);
|
|||||||
/**
|
/**
|
||||||
* @brief Register A2DP source data input function; For now the input is PCM data stream.
|
* @brief Register A2DP source data input function; For now the input is PCM data stream.
|
||||||
* This function should be called only after esp_bluedroid_enable() completes
|
* This function should be called only after esp_bluedroid_enable() completes
|
||||||
* successfully
|
* successfully. The callback is invoked in the context of A2DP source task whose
|
||||||
|
* stack size is configurable through menuconfig
|
||||||
*
|
*
|
||||||
* @param[in] callback: A2DP source data callback function
|
* @param[in] callback: A2DP source data callback function
|
||||||
*
|
*
|
||||||
|
@ -232,13 +232,13 @@ bool btc_a2dp_sink_startup(void)
|
|||||||
|
|
||||||
APPL_TRACE_EVENT("## A2DP SINK START MEDIA THREAD ##");
|
APPL_TRACE_EVENT("## A2DP SINK START MEDIA THREAD ##");
|
||||||
|
|
||||||
btc_aa_snk_queue_set = xQueueCreateSet(BTC_MEDIA_TASK_QUEUE_SET_LEN);
|
btc_aa_snk_queue_set = xQueueCreateSet(BTC_A2DP_SINK_TASK_QUEUE_SET_LEN);
|
||||||
configASSERT(btc_aa_snk_queue_set);
|
configASSERT(btc_aa_snk_queue_set);
|
||||||
btc_aa_snk_data_queue = xQueueCreate(BTC_MEDIA_DATA_QUEUE_LEN, sizeof(int32_t));
|
btc_aa_snk_data_queue = xQueueCreate(BTC_A2DP_SINK_DATA_QUEUE_LEN, sizeof(int32_t));
|
||||||
configASSERT(btc_aa_snk_data_queue);
|
configASSERT(btc_aa_snk_data_queue);
|
||||||
xQueueAddToSet(btc_aa_snk_data_queue, btc_aa_snk_queue_set);
|
xQueueAddToSet(btc_aa_snk_data_queue, btc_aa_snk_queue_set);
|
||||||
|
|
||||||
btc_aa_snk_ctrl_queue = xQueueCreate(BTC_MEDIA_CTRL_QUEUE_LEN, sizeof(void *));
|
btc_aa_snk_ctrl_queue = xQueueCreate(BTC_A2DP_SINK_CTRL_QUEUE_LEN, sizeof(void *));
|
||||||
configASSERT(btc_aa_snk_ctrl_queue);
|
configASSERT(btc_aa_snk_ctrl_queue);
|
||||||
xQueueAddToSet(btc_aa_snk_ctrl_queue, btc_aa_snk_queue_set);
|
xQueueAddToSet(btc_aa_snk_ctrl_queue, btc_aa_snk_queue_set);
|
||||||
|
|
||||||
@ -246,7 +246,7 @@ bool btc_a2dp_sink_startup(void)
|
|||||||
goto error_exit;
|
goto error_exit;
|
||||||
}
|
}
|
||||||
|
|
||||||
xTaskCreatePinnedToCore(btc_a2dp_sink_task_handler, BTC_MEDIA_TASK_NAME, BTC_MEDIA_TASK_STACK_SIZE, NULL, BTC_MEDIA_TASK_PRIO, &btc_aa_snk_task_hdl, BTC_MEDIA_TASK_PINNED_TO_CORE);
|
xTaskCreatePinnedToCore(btc_a2dp_sink_task_handler, BTC_A2DP_SINK_TASK_NAME, BTC_A2DP_SINK_TASK_STACK_SIZE, NULL, BTC_A2DP_SINK_TASK_PRIO, &btc_aa_snk_task_hdl, BTC_A2DP_SINK_TASK_PINNED_TO_CORE);
|
||||||
if (btc_aa_snk_task_hdl == NULL) {
|
if (btc_aa_snk_task_hdl == NULL) {
|
||||||
goto error_exit;
|
goto error_exit;
|
||||||
}
|
}
|
||||||
|
@ -307,13 +307,13 @@ bool btc_a2dp_source_startup(void)
|
|||||||
|
|
||||||
APPL_TRACE_EVENT("## A2DP SOURCE START MEDIA THREAD ##");
|
APPL_TRACE_EVENT("## A2DP SOURCE START MEDIA THREAD ##");
|
||||||
|
|
||||||
btc_aa_src_queue_set = xQueueCreateSet(BTC_MEDIA_TASK_QUEUE_SET_LEN);
|
btc_aa_src_queue_set = xQueueCreateSet(BTC_A2DP_SOURCE_TASK_QUEUE_SET_LEN);
|
||||||
configASSERT(btc_aa_src_queue_set);
|
configASSERT(btc_aa_src_queue_set);
|
||||||
btc_aa_src_data_queue = xQueueCreate(BTC_MEDIA_DATA_QUEUE_LEN, sizeof(void *));
|
btc_aa_src_data_queue = xQueueCreate(BTC_A2DP_SOURCE_DATA_QUEUE_LEN, sizeof(void *));
|
||||||
configASSERT(btc_aa_src_data_queue);
|
configASSERT(btc_aa_src_data_queue);
|
||||||
xQueueAddToSet(btc_aa_src_data_queue, btc_aa_src_queue_set);
|
xQueueAddToSet(btc_aa_src_data_queue, btc_aa_src_queue_set);
|
||||||
|
|
||||||
btc_aa_src_ctrl_queue = xQueueCreate(BTC_MEDIA_CTRL_QUEUE_LEN, sizeof(void *));
|
btc_aa_src_ctrl_queue = xQueueCreate(BTC_A2DP_SOURCE_CTRL_QUEUE_LEN, sizeof(void *));
|
||||||
configASSERT(btc_aa_src_ctrl_queue);
|
configASSERT(btc_aa_src_ctrl_queue);
|
||||||
xQueueAddToSet(btc_aa_src_ctrl_queue, btc_aa_src_queue_set);
|
xQueueAddToSet(btc_aa_src_ctrl_queue, btc_aa_src_queue_set);
|
||||||
|
|
||||||
@ -321,7 +321,7 @@ bool btc_a2dp_source_startup(void)
|
|||||||
goto error_exit;
|
goto error_exit;
|
||||||
}
|
}
|
||||||
|
|
||||||
xTaskCreatePinnedToCore(btc_a2dp_source_task_handler, BTC_MEDIA_TASK_NAME, BTC_MEDIA_TASK_STACK_SIZE, NULL, BTC_MEDIA_TASK_PRIO, &btc_aa_src_task_hdl, BTC_MEDIA_TASK_PINNED_TO_CORE);
|
xTaskCreatePinnedToCore(btc_a2dp_source_task_handler, BTC_A2DP_SOURCE_TASK_NAME, BTC_A2DP_SOURCE_TASK_STACK_SIZE, NULL, BTC_A2DP_SOURCE_TASK_PRIO, &btc_aa_src_task_hdl, BTC_A2DP_SOURCE_TASK_PINNED_TO_CORE);
|
||||||
if (btc_aa_src_task_hdl == NULL) {
|
if (btc_aa_src_task_hdl == NULL) {
|
||||||
goto error_exit;
|
goto error_exit;
|
||||||
}
|
}
|
||||||
|
@ -83,13 +83,21 @@ typedef enum {
|
|||||||
#define BTC_TASK_PRIO (configMAX_PRIORITIES - 6)
|
#define BTC_TASK_PRIO (configMAX_PRIORITIES - 6)
|
||||||
#define BTC_TASK_QUEUE_LEN 60
|
#define BTC_TASK_QUEUE_LEN 60
|
||||||
|
|
||||||
#define BTC_MEDIA_TASK_PINNED_TO_CORE (TASK_PINNED_TO_CORE)
|
#define BTC_A2DP_SINK_TASK_PINNED_TO_CORE (TASK_PINNED_TO_CORE)
|
||||||
#define BTC_MEDIA_TASK_STACK_SIZE (2048 + BT_TASK_EXTRA_STACK_SIZE)
|
#define BTC_A2DP_SINK_TASK_STACK_SIZE (CONFIG_A2DP_SINK_TASK_STACK_SIZE + BT_TASK_EXTRA_STACK_SIZE) // by menuconfig
|
||||||
#define BTC_MEDIA_TASK_NAME "BtcMediaT"
|
#define BTC_A2DP_SINK_TASK_NAME "BtA2dSinkT"
|
||||||
#define BTC_MEDIA_TASK_PRIO (configMAX_PRIORITIES - 3)
|
#define BTC_A2DP_SINK_TASK_PRIO (configMAX_PRIORITIES - 3)
|
||||||
#define BTC_MEDIA_DATA_QUEUE_LEN (3)
|
#define BTC_A2DP_SINK_DATA_QUEUE_LEN (3)
|
||||||
#define BTC_MEDIA_CTRL_QUEUE_LEN (5)
|
#define BTC_A2DP_SINK_CTRL_QUEUE_LEN (5)
|
||||||
#define BTC_MEDIA_TASK_QUEUE_SET_LEN (BTC_MEDIA_DATA_QUEUE_LEN + BTC_MEDIA_CTRL_QUEUE_LEN)
|
#define BTC_A2DP_SINK_TASK_QUEUE_SET_LEN (BTC_A2DP_SINK_DATA_QUEUE_LEN + BTC_A2DP_SINK_CTRL_QUEUE_LEN)
|
||||||
|
|
||||||
|
#define BTC_A2DP_SOURCE_TASK_PINNED_TO_CORE (TASK_PINNED_TO_CORE)
|
||||||
|
#define BTC_A2DP_SOURCE_TASK_STACK_SIZE (CONFIG_A2DP_SOURCE_TASK_STACK_SIZE + BT_TASK_EXTRA_STACK_SIZE) // by menuconfig
|
||||||
|
#define BTC_A2DP_SOURCE_TASK_NAME "BtA2dSourceT"
|
||||||
|
#define BTC_A2DP_SOURCE_TASK_PRIO (configMAX_PRIORITIES - 3)
|
||||||
|
#define BTC_A2DP_SOURCE_DATA_QUEUE_LEN (3)
|
||||||
|
#define BTC_A2DP_SOURCE_CTRL_QUEUE_LEN (5)
|
||||||
|
#define BTC_A2DP_SOURCE_TASK_QUEUE_SET_LEN (BTC_A2DP_SOURCE_DATA_QUEUE_LEN + BTC_A2DP_SOURCE_CTRL_QUEUE_LEN)
|
||||||
|
|
||||||
#define TASK_POST_NON_BLOCKING (0)
|
#define TASK_POST_NON_BLOCKING (0)
|
||||||
#define TASK_POST_BLOCKING (portMAX_DELAY)
|
#define TASK_POST_BLOCKING (portMAX_DELAY)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user