[pulseaudio-discuss] [PATCH] bluetooth: set better priorities for profiles
Georg Chini
georg at chini.tk
Sun Oct 15 18:05:58 UTC 2017
On 15.10.2017 12:29, Tanu Kaskinen wrote:
> Since HSP had higher priority than A2DP, the default profile when
> connecting a new headset was HSP. To me it makes more sense to default
> to high-quality output. We already have some automatic policies to
> switch to HSP when it's needed.
>
> I also made the A2DP source and HSP/HFP gateway profiles have lower
> priority than the A2DP sink and HSP headset profiles. The A2DP source
> and HSP/HFP gateway profiles should only be activated if the remote
> device initiates audio streaming, so it makes sense to have lower
> priority for those profiles.
>
> BugLink: https://bugs.freedesktop.org/show_bug.cgi?id=103058
> ---
> src/modules/bluetooth/module-bluez5-device.c | 8 ++++----
> 1 file changed, 4 insertions(+), 4 deletions(-)
>
> diff --git a/src/modules/bluetooth/module-bluez5-device.c b/src/modules/bluetooth/module-bluez5-device.c
> index 8a9063932..fb9914727 100644
> --- a/src/modules/bluetooth/module-bluez5-device.c
> +++ b/src/modules/bluetooth/module-bluez5-device.c
> @@ -1861,7 +1861,7 @@ static pa_card_profile *create_card_profile(struct userdata *u, pa_bluetooth_pro
> switch (profile) {
> case PA_BLUETOOTH_PROFILE_A2DP_SINK:
> cp = pa_card_profile_new(name, _("High Fidelity Playback (A2DP Sink)"), sizeof(pa_bluetooth_profile_t));
> - cp->priority = 10;
> + cp->priority = 40;
> cp->n_sinks = 1;
> cp->n_sources = 0;
> cp->max_sink_channels = 2;
> @@ -1873,7 +1873,7 @@ static pa_card_profile *create_card_profile(struct userdata *u, pa_bluetooth_pro
>
> case PA_BLUETOOTH_PROFILE_A2DP_SOURCE:
> cp = pa_card_profile_new(name, _("High Fidelity Capture (A2DP Source)"), sizeof(pa_bluetooth_profile_t));
> - cp->priority = 10;
> + cp->priority = 20;
> cp->n_sinks = 0;
> cp->n_sources = 1;
> cp->max_sink_channels = 0;
> @@ -1885,7 +1885,7 @@ static pa_card_profile *create_card_profile(struct userdata *u, pa_bluetooth_pro
>
> case PA_BLUETOOTH_PROFILE_HEADSET_HEAD_UNIT:
> cp = pa_card_profile_new(name, _("Headset Head Unit (HSP/HFP)"), sizeof(pa_bluetooth_profile_t));
> - cp->priority = 20;
> + cp->priority = 30;
> cp->n_sinks = 1;
> cp->n_sources = 1;
> cp->max_sink_channels = 1;
> @@ -1898,7 +1898,7 @@ static pa_card_profile *create_card_profile(struct userdata *u, pa_bluetooth_pro
>
> case PA_BLUETOOTH_PROFILE_HEADSET_AUDIO_GATEWAY:
> cp = pa_card_profile_new(name, _("Headset Audio Gateway (HSP/HFP)"), sizeof(pa_bluetooth_profile_t));
> - cp->priority = 20;
> + cp->priority = 10;
> cp->n_sinks = 1;
> cp->n_sources = 1;
> cp->max_sink_channels = 1;
Looks good to me.
More information about the pulseaudio-discuss
mailing list