10.06.2016 22:55, Tanu Kaskinen пиÑ?еÑ?: > The alsa card hasn't so far set any availability for profiles. That > caused an issue with some HDMI hardware: the sound card has two HDMI > outputs, but only the second of them is actually usable. The > unavailable port is marked as unavailable and the available port is > marked as available, but this information isn't propagated to the > profile availability. Without profile availability information, the > initial profile policy picks the unavailable one, since it has a > higher priority value. > > This patch adds simple logic for marking some profiles unavailable: > if the profile only contains unavailable ports, the profile is > unavailable too. This can be improved in the future so that if a > profile contains sinks or sources that only contain unavailable ports, > the profile should be marked as unavailable. Implementing that > requires adding more information about the sinks and sources to > pa_card_profile, however. > > BugLink: https://bugzilla.yoctoproject.org/show_bug.cgi?id=8448 Looks OK to me, too. I was surprised that the only calls to pa_card_profile_set_available() were in bluez modules. Now all that remains is to test it with my hardware, I will do it a bit later. -- Alexander E. Patrakov > --- > src/modules/alsa/module-alsa-card.c | 27 +++++++++++++++++++++++++++ > 1 file changed, 27 insertions(+) > > diff --git a/src/modules/alsa/module-alsa-card.c b/src/modules/alsa/module-alsa-card.c > index 1976230..323e08a 100644 > --- a/src/modules/alsa/module-alsa-card.c > +++ b/src/modules/alsa/module-alsa-card.c > @@ -366,6 +366,7 @@ static int report_jack_state(snd_mixer_elem_t *melem, unsigned int mask) { > void *state; > pa_alsa_jack *jack; > struct temp_port_avail *tp, *tports; > + pa_card_profile *profile; > > pa_assert(u); > > @@ -426,6 +427,32 @@ static int report_jack_state(snd_mixer_elem_t *melem, unsigned int mask) { > if (tp->avail == PA_AVAILABLE_NO) > pa_device_port_set_available(tp->port, tp->avail); > > + /* Update profile availabilities. The logic could be improved; for now we > + * only set obviously unavailable profiles (those that contain only > + * unavailable ports) to PA_AVAILABLE_NO and all others to > + * PA_AVAILABLE_UNKNOWN. */ > + PA_HASHMAP_FOREACH(profile, u->card->profiles, state) { > + pa_device_port *port; > + void *state2; > + pa_available_t available = PA_AVAILABLE_NO; > + > + /* Don't touch the "off" profile. */ > + if (profile->n_sources == 0 && profile->n_sinks == 0) > + continue; > + > + PA_HASHMAP_FOREACH(port, u->card->ports, state2) { > + if (!pa_hashmap_get(port->profiles, profile->name)) > + continue; > + > + if (port->available != PA_AVAILABLE_NO) { > + available = PA_AVAILABLE_UNKNOWN; > + break; > + } > + } > + > + pa_card_profile_set_available(profile, available); > + } > + > pa_xfree(tports); > return 0; > } >