bluetooth: audio: added support for 24kHz frequency to broadcast source
Added option to support 24kHz frequency for broadcast_sample_source
Signed-off-by: Michele Imbriani <mbim@demant.com>
diff --git a/samples/bluetooth/broadcast_audio_source/Kconfig b/samples/bluetooth/broadcast_audio_source/Kconfig
new file mode 100644
index 0000000..91cca49
--- /dev/null
+++ b/samples/bluetooth/broadcast_audio_source/Kconfig
@@ -0,0 +1,22 @@
+# Copyright (c) 2023 Demant A/S
+# SPDX-License-Identifier: Apache-2.0
+
+mainmenu "Bluetooth: Broadcast Audio Source"
+
+choice BAP_LC3_PRESET
+ prompt "The BAP LC3 Preset to be used"
+ default BAP_BROADCAST_16_2_1
+
+config BAP_BROADCAST_16_2_1
+ bool "BAP_LC3_BROADCAST_PRESET_16_2_1 preset"
+ help
+ Using the BAP_LC3_BROADCAST_PRESET_16_2_1 preset.
+
+config BAP_BROADCAST_24_2_1
+ bool "BAP_LC3_BROADCAST_PRESET_24_2_1 preset"
+ help
+ Using the BAP_LC3_BROADCAST_PRESET_24_2_1 preset.
+
+endchoice
+
+source "Kconfig.zephyr"
diff --git a/samples/bluetooth/broadcast_audio_source/src/main.c b/samples/bluetooth/broadcast_audio_source/src/main.c
index 6dc853f..f9a2a53 100644
--- a/samples/bluetooth/broadcast_audio_source/src/main.c
+++ b/samples/bluetooth/broadcast_audio_source/src/main.c
@@ -32,8 +32,18 @@
"CONFIG_BT_ISO_TX_BUF_COUNT should be at least "
"BROADCAST_ENQUEUE_COUNT * CONFIG_BT_BAP_BROADCAST_SRC_STREAM_COUNT");
-static struct bt_bap_lc3_preset preset_16_2_1 = BT_BAP_LC3_BROADCAST_PRESET_16_2_1(
+#if defined(CONFIG_BAP_BROADCAST_16_2_1)
+
+static struct bt_bap_lc3_preset preset_active = BT_BAP_LC3_BROADCAST_PRESET_16_2_1(
BT_AUDIO_LOCATION_FRONT_LEFT, BT_AUDIO_CONTEXT_TYPE_UNSPECIFIED);
+
+#elif defined(CONFIG_BAP_BROADCAST_24_2_1)
+
+static struct bt_bap_lc3_preset preset_active = BT_BAP_LC3_BROADCAST_PRESET_24_2_1(
+ BT_AUDIO_LOCATION_FRONT_LEFT, BT_AUDIO_CONTEXT_TYPE_UNSPECIFIED);
+
+#endif
+
static struct broadcast_source_stream {
struct bt_bap_stream stream;
uint16_t seq_num;
@@ -70,7 +80,7 @@
static void init_lc3(void)
{
- const struct bt_audio_codec_cfg *codec_cfg = &preset_16_2_1.codec_cfg;
+ const struct bt_audio_codec_cfg *codec_cfg = &preset_active.codec_cfg;
int ret;
ret = bt_audio_codec_cfg_get_freq(codec_cfg);
@@ -152,7 +162,7 @@
net_buf_reserve(buf, BT_ISO_CHAN_SEND_RESERVE);
#if defined(CONFIG_LIBLC3)
int lc3_ret;
- uint8_t lc3_encoder_buffer[preset_16_2_1.qos.sdu];
+ uint8_t lc3_encoder_buffer[preset_active.qos.sdu];
if (lc3_encoder == NULL) {
printk("LC3 encoder not setup, cannot encode data.\n");
@@ -167,9 +177,9 @@
return;
}
- net_buf_add_mem(buf, lc3_encoder_buffer, preset_16_2_1.qos.sdu);
+ net_buf_add_mem(buf, lc3_encoder_buffer, preset_active.qos.sdu);
#else
- net_buf_add_mem(buf, mock_data, preset_16_2_1.qos.sdu);
+ net_buf_add_mem(buf, mock_data, preset_active.qos.sdu);
#endif /* defined(CONFIG_LIBLC3) */
ret = bt_bap_stream_send(stream, buf, source_stream->seq_num++, BT_ISO_TIMESTAMP_NONE);
@@ -207,7 +217,7 @@
for (size_t i = 0U; i < ARRAY_SIZE(subgroup_param); i++) {
subgroup_param[i].params_count = streams_per_subgroup;
subgroup_param[i].params = stream_params + i * streams_per_subgroup;
- subgroup_param[i].codec_cfg = &preset_16_2_1.codec_cfg;
+ subgroup_param[i].codec_cfg = &preset_active.codec_cfg;
}
for (size_t j = 0U; j < ARRAY_SIZE(stream_params); j++) {
@@ -219,7 +229,7 @@
create_param.params_count = ARRAY_SIZE(subgroup_param);
create_param.params = subgroup_param;
- create_param.qos = &preset_16_2_1.qos;
+ create_param.qos = &preset_active.qos;
create_param.encryption = false;
create_param.packing = BT_ISO_PACKING_SEQUENTIAL;