ALSA: hda - Fix the detection of "Loopback Mixing" control for VIA codecs
authorTakashi Iwai <tiwai@suse.de>
Tue, 10 Jan 2012 14:16:02 +0000 (15:16 +0100)
committerTakashi Iwai <tiwai@suse.de>
Tue, 10 Jan 2012 14:16:02 +0000 (15:16 +0100)
Currently the driver checks only the out_mix_path[] for the primary
output route for judging whether to create the loopback-mixing control
or not.  But, there are cases where aamix-routing is available only on
headphone or speaker paths but not on the primary output path.  So, the
driver ignores such cases inappropriately.

This patch fixes the check of the loopback-mixing control by testing
all mix-routing paths.

Cc: <stable@kernel.org>
Signed-off-by: Takashi Iwai <tiwai@suse.de>
sound/pci/hda/patch_via.c

index ab56866cc94e495f1a13847d662e691afc5edb90..03e63fed9caf7d9e8342373901a5086f884122d9 100644 (file)
@@ -2208,7 +2208,10 @@ static int via_auto_create_loopback_switch(struct hda_codec *codec)
 {
        struct via_spec *spec = codec->spec;
 
-       if (!spec->aa_mix_nid || !spec->out_mix_path.depth)
+       if (!spec->aa_mix_nid)
+               return 0; /* no loopback switching available */
+       if (!(spec->out_mix_path.depth || spec->hp_mix_path.depth ||
+             spec->speaker_path.depth))
                return 0; /* no loopback switching available */
        if (!via_clone_control(spec, &via_aamix_ctl_enum))
                return -ENOMEM;