Bluetooth: Audio: Add broadcast source subgroup count Kconfig
Add a (initally hidden) Kconfig option for broadcast source used to determine the size of the advertisable BASE. Signed-off-by: Emil Gydesen <emil.gydesen@nordicsemi.no>
This commit is contained in:
parent
23e45c937a
commit
9efa22940c
3 changed files with 13 additions and 8 deletions
|
@ -143,10 +143,10 @@ extern "C" {
|
|||
|
||||
#if defined(CONFIG_BT_AUDIO_BROADCAST_SINK)
|
||||
#define BROADCAST_SNK_STREAM_CNT CONFIG_BT_AUDIO_BROADCAST_SNK_STREAM_COUNT
|
||||
#define BROADCAST_SUBGROUP_CNT CONFIG_BT_AUDIO_BROADCAST_SUBGROUP_COUNT
|
||||
#define BROADCAST_SNK_SUBGROUP_CNT CONFIG_BT_AUDIO_BROADCAST_SNK_SUBGROUP_COUNT
|
||||
#else /* !CONFIG_BT_AUDIO_BROADCAST_SINK */
|
||||
#define BROADCAST_SNK_STREAM_CNT 0
|
||||
#define BROADCAST_SUBGROUP_CNT 0
|
||||
#define BROADCAST_SNK_SUBGROUP_CNT 0
|
||||
#endif /* CONFIG_BT_AUDIO_BROADCAST_SINK*/
|
||||
|
||||
/** @brief Abstract Audio Unicast Group structure. */
|
||||
|
@ -291,7 +291,7 @@ struct bt_audio_base {
|
|||
/* Number of subgroups in the BASE */
|
||||
size_t subgroup_count;
|
||||
/* Array of subgroups in the BASE */
|
||||
struct bt_audio_base_subgroup subgroups[BROADCAST_SUBGROUP_CNT];
|
||||
struct bt_audio_base_subgroup subgroups[BROADCAST_SNK_SUBGROUP_CNT];
|
||||
};
|
||||
|
||||
/** @brief Audio Capability type */
|
||||
|
|
|
@ -123,6 +123,10 @@ config BT_AUDIO_BROADCAST_SOURCE
|
|||
Isochronous channels.
|
||||
if BT_AUDIO_BROADCAST_SOURCE
|
||||
|
||||
config BT_AUDIO_BROADCAST_SRC_SUBGROUP_COUNT
|
||||
int # hidden: TODO: Update once the API supports it
|
||||
default 1
|
||||
|
||||
config BT_AUDIO_BROADCAST_SRC_COUNT
|
||||
int "Basic Audio Broadcaster source count"
|
||||
default 1
|
||||
|
@ -153,7 +157,7 @@ config BT_AUDIO_BROADCAST_SINK
|
|||
|
||||
if BT_AUDIO_BROADCAST_SINK
|
||||
|
||||
config BT_AUDIO_BROADCAST_SUBGROUP_COUNT
|
||||
config BT_AUDIO_BROADCAST_SNK_SUBGROUP_COUNT
|
||||
int # hidden: TODO: Update once the API supports it
|
||||
default 1
|
||||
|
||||
|
|
|
@ -55,7 +55,7 @@ struct bt_audio_base_ad_subgroup {
|
|||
|
||||
struct bt_audio_base_ad {
|
||||
uint16_t uuid_val;
|
||||
struct bt_audio_base_ad_subgroup subgroups[BROADCAST_SUBGROUP_CNT];
|
||||
struct bt_audio_base_ad_subgroup subgroups[CONFIG_BT_AUDIO_BROADCAST_SRC_SUBGROUP_COUNT];
|
||||
} __packed;
|
||||
|
||||
static struct bt_audio_ep broadcast_source_eps
|
||||
|
@ -251,8 +251,9 @@ static void bt_audio_encode_base(const struct bt_audio_broadcast_source *source,
|
|||
uint8_t *start;
|
||||
uint8_t len;
|
||||
|
||||
__ASSERT(source->subgroup_count == BROADCAST_SUBGROUP_CNT,
|
||||
"Cannot encode BASE with more than a single subgroup");
|
||||
__ASSERT(source->subgroup_count == CONFIG_BT_AUDIO_BROADCAST_SRC_SUBGROUP_COUNT,
|
||||
"Cannot encode BASE with more than a %u subgroups",
|
||||
CONFIG_BT_AUDIO_BROADCAST_SRC_SUBGROUP_COUNT);
|
||||
|
||||
net_buf_simple_add_le16(buf, BT_UUID_BASIC_AUDIO_VAL);
|
||||
net_buf_simple_add_le24(buf, source->pd);
|
||||
|
@ -505,7 +506,7 @@ int bt_audio_broadcast_source_create(struct bt_audio_stream *streams,
|
|||
return err;
|
||||
}
|
||||
|
||||
source->subgroup_count = BROADCAST_SUBGROUP_CNT;
|
||||
source->subgroup_count = CONFIG_BT_AUDIO_BROADCAST_SRC_SUBGROUP_COUNT;
|
||||
source->pd = qos->pd;
|
||||
err = bt_audio_set_base(source, codec);
|
||||
if (err != 0) {
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue