From 91b25005978d343a989c9485e226dc9a18a2fb28 Mon Sep 17 00:00:00 2001 From: David Henningsson Date: Thu, 2 Feb 2012 12:46:54 +0100 Subject: alsa-mixer: Take override-maps into account in subset elimination The practical problem is that some users were left with only one "LFE on Mono" port, as analog-output was considered a subset of analog-output-lfe-on-mono. Which was not what they wanted. BugLink: https://bugs.freedesktop.org/show_bug.cgi?id=40910 BugLink: https://bugs.launchpad.net/bugs/922656 Signed-off-by: David Henningsson --- src/modules/alsa/alsa-mixer.c | 13 +++++++++++++ 1 file changed, 13 insertions(+) (limited to 'src/modules/alsa/alsa-mixer.c') diff --git a/src/modules/alsa/alsa-mixer.c b/src/modules/alsa/alsa-mixer.c index 2aa708dc6..9bf806957 100644 --- a/src/modules/alsa/alsa-mixer.c +++ b/src/modules/alsa/alsa-mixer.c @@ -3014,6 +3014,19 @@ static pa_bool_t element_is_subset(pa_alsa_element *a, pa_alsa_element *b, snd_m if (a_limit > b->volume_limit) return FALSE; } + + if (a->volume_use == PA_ALSA_VOLUME_MERGE) { + int s; + /* If override-maps are different, they're not subsets */ + if (a->n_channels != b->n_channels) + return FALSE; + for (s = 0; s < SND_MIXER_SCHN_LAST; s++) + if (a->masks[s][a->n_channels-1] != b->masks[s][b->n_channels-1]) { + pa_log_debug("Element %s is not a subset - mask a: 0x%lx, mask b: 0x%lx, at channel %d", + a->alsa_name, a->masks[s][a->n_channels-1], b->masks[s][b->n_channels-1], s); + return FALSE; + } + } } if (a->switch_use != PA_ALSA_SWITCH_IGNORE) { -- cgit v1.2.3