From e2fa5537f78303d50ca0fd6bbb2eb146b179e4e1 Mon Sep 17 00:00:00 2001 From: Silviu Florian Barbulescu Date: Wed, 2 Aug 2023 11:19:06 +0300 Subject: [PATCH] Add support for bluez5.roles for broadcast source. --- spa/plugins/bluez5/bluez5-dbus.c | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/spa/plugins/bluez5/bluez5-dbus.c b/spa/plugins/bluez5/bluez5-dbus.c index 3378704a0..2648ddfe6 100644 --- a/spa/plugins/bluez5/bluez5-dbus.c +++ b/spa/plugins/bluez5/bluez5-dbus.c @@ -513,10 +513,11 @@ static enum spa_bt_profile get_codec_profile(const struct media_codec *codec, { switch (direction) { case SPA_BT_MEDIA_SOURCE: - case SPA_BT_MEDIA_SOURCE_BROADCAST: return codec->bap ? SPA_BT_PROFILE_BAP_SOURCE : SPA_BT_PROFILE_A2DP_SOURCE; case SPA_BT_MEDIA_SINK: return codec->bap ? SPA_BT_PROFILE_BAP_SINK : SPA_BT_PROFILE_A2DP_SINK; + case SPA_BT_MEDIA_SOURCE_BROADCAST: + return SPA_BT_PROFILE_BAP_BROADCAST_SOURCE; default: spa_assert_not_reached(); } @@ -4906,7 +4907,8 @@ static bool have_codec_endpoints(struct spa_bt_monitor *monitor, bool bap) if (codec->bap != bap) continue; if (endpoint_should_be_registered(monitor, codec, SPA_BT_MEDIA_SINK) || - endpoint_should_be_registered(monitor, codec, SPA_BT_MEDIA_SOURCE)) + endpoint_should_be_registered(monitor, codec, SPA_BT_MEDIA_SOURCE) || + endpoint_should_be_registered(monitor, codec, SPA_BT_MEDIA_SOURCE_BROADCAST)) return true; } return false; @@ -5642,6 +5644,8 @@ int spa_bt_profiles_from_json_array(const char *str) profiles |= SPA_BT_PROFILE_BAP_SINK; } else if (spa_streq(role_name, "bap_source")) { profiles |= SPA_BT_PROFILE_BAP_SOURCE; + } else if (spa_streq(role_name, "bap_bcast_source")) { + profiles |= SPA_BT_PROFILE_BAP_BROADCAST_SOURCE; } }