ALSA: hda - Allow aamix as a capture source
authorTakashi Iwai <tiwai@suse.de>
Wed, 9 Jan 2013 08:14:23 +0000 (09:14 +0100)
committerTakashi Iwai <tiwai@suse.de>
Sat, 12 Jan 2013 07:44:21 +0000 (08:44 +0100)
Since some codecs can choose the aamix as a capture source, we should
support it as well.  When spec->add_stereo_mix_input flag is set, the
parser checks the availability of aamix as the input source, and adds
the paths automatically when possible.

Signed-off-by: Takashi Iwai <tiwai@suse.de>
sound/pci/hda/hda_generic.c
sound/pci/hda/hda_generic.h

index d16ef1d490fbf9f86ab66cb83d33c6ae56d983c9..26e8d83b56729b60ed5bc8b8957d341fd733c34a 100644 (file)
@@ -2067,6 +2067,40 @@ static int check_dyn_adc_switch(struct hda_codec *codec)
        return 0;
 }
 
+/* parse capture source paths from the given pin and create imux items */
+static int parse_capture_source(struct hda_codec *codec, hda_nid_t pin,
+                               int num_adcs, const char *label, int anchor)
+{
+       struct hda_gen_spec *spec = codec->spec;
+       struct hda_input_mux *imux = &spec->input_mux;
+       int imux_idx = imux->num_items;
+       bool imux_added = false;
+       int c;
+
+       for (c = 0; c < num_adcs; c++) {
+               struct nid_path *path;
+               hda_nid_t adc = spec->adc_nids[c];
+
+               if (!is_reachable_path(codec, pin, adc))
+                       continue;
+               path = snd_hda_add_new_path(codec, pin, adc, anchor);
+               if (!path)
+                       continue;
+               print_nid_path("input", path);
+               spec->input_paths[imux_idx][c] =
+                       snd_hda_get_path_idx(codec, path);
+
+               if (!imux_added) {
+                       spec->imux_pins[imux->num_items] = pin;
+                       snd_hda_add_imux_item(imux, label,
+                                             imux->num_items, NULL);
+                       imux_added = true;
+               }
+       }
+
+       return 0;
+}
+
 /*
  * create playback/capture controls for input pins
  */
@@ -2075,9 +2109,8 @@ static int create_input_ctls(struct hda_codec *codec)
        struct hda_gen_spec *spec = codec->spec;
        const struct auto_pin_cfg *cfg = &spec->autocfg;
        hda_nid_t mixer = spec->mixer_nid;
-       struct hda_input_mux *imux = &spec->input_mux;
        int num_adcs;
-       int i, c, err, type_idx = 0;
+       int i, err, type_idx = 0;
        const char *prev_label = NULL;
 
        num_adcs = fill_adc_nids(codec);
@@ -2087,8 +2120,6 @@ static int create_input_ctls(struct hda_codec *codec)
        for (i = 0; i < cfg->num_inputs; i++) {
                hda_nid_t pin;
                const char *label;
-               int imux_idx;
-               bool imux_added;
 
                pin = cfg->inputs[i].pin;
                if (!is_input_pin(codec, pin))
@@ -2110,28 +2141,16 @@ static int create_input_ctls(struct hda_codec *codec)
                        }
                }
 
-               imux_added = false;
-               imux_idx = imux->num_items;
-               for (c = 0; c < num_adcs; c++) {
-                       struct nid_path *path;
-                       hda_nid_t adc = spec->adc_nids[c];
-
-                       if (!is_reachable_path(codec, pin, adc))
-                               continue;
-                       path = snd_hda_add_new_path(codec, pin, adc, -mixer);
-                       if (!path)
-                               continue;
-                       print_nid_path("input", path);
-                       spec->input_paths[imux_idx][c] =
-                               snd_hda_get_path_idx(codec, path);
+               err = parse_capture_source(codec, pin, num_adcs, label, -mixer);
+               if (err < 0)
+                       return err;
+       }
 
-                       if (!imux_added) {
-                               spec->imux_pins[imux->num_items] = pin;
-                               snd_hda_add_imux_item(imux, label,
-                                                     imux->num_items, NULL);
-                               imux_added = true;
-                       }
-               }
+       if (mixer && spec->add_stereo_mix_input) {
+               err = parse_capture_source(codec, mixer, num_adcs,
+                                          "Stereo Mix", 0);
+               if (err < 0)
+                       return err;
        }
 
        return 0;
index 1763e33b90efcdd4cbf496ecfbd6f1ef53c10848..89683c7fe2638ffe0bf7ff9b35a0ec5c898bf619 100644 (file)
@@ -190,6 +190,7 @@ struct hda_gen_spec {
        unsigned int vmaster_mute_enum:1; /* add vmaster mute mode enum */
        unsigned int indep_hp:1; /* independent HP supported */
        unsigned int indep_hp_enabled:1; /* independent HP enabled */
+       unsigned int add_stereo_mix_input:1; /* add aamix as a capture src */
 
        /* loopback mixing mode */
        bool aamix_mode;