ALSA: hda - fix wrong adc_idx in generic parser
authorDavid Henningsson <david.henningsson@canonical.com>
Wed, 16 Jan 2013 10:45:36 +0000 (11:45 +0100)
committerTakashi Iwai <tiwai@suse.de>
Wed, 16 Jan 2013 10:56:50 +0000 (11:56 +0100)
We use knew->index for adc_idx when we create "Capture Volume" and
"Capture Switch", so use the same to retrieve adc_idx.

Signed-off-by: David Henningsson <david.henningsson@canonical.com>
Signed-off-by: Takashi Iwai <tiwai@suse.de>
sound/pci/hda/hda_generic.c

index 1fa71ac..68947fa 100644 (file)
@@ -2432,7 +2432,7 @@ static int mux_enum_get(struct snd_kcontrol *kcontrol,
 {
        struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
        struct hda_gen_spec *spec = codec->spec;
 {
        struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
        struct hda_gen_spec *spec = codec->spec;
-       unsigned int adc_idx = snd_ctl_get_ioffidx(kcontrol, &ucontrol->id);
+       unsigned int adc_idx = kcontrol->id.index;
 
        ucontrol->value.enumerated.item[0] = spec->cur_mux[adc_idx];
        return 0;
 
        ucontrol->value.enumerated.item[0] = spec->cur_mux[adc_idx];
        return 0;
@@ -2442,7 +2442,7 @@ static int mux_enum_put(struct snd_kcontrol *kcontrol,
                            struct snd_ctl_elem_value *ucontrol)
 {
        struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
                            struct snd_ctl_elem_value *ucontrol)
 {
        struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
-       unsigned int adc_idx = snd_ctl_get_ioffidx(kcontrol, &ucontrol->id);
+       unsigned int adc_idx = kcontrol->id.index;
        return mux_select(codec, adc_idx,
                          ucontrol->value.enumerated.item[0]);
 }
        return mux_select(codec, adc_idx,
                          ucontrol->value.enumerated.item[0]);
 }
@@ -2474,7 +2474,7 @@ static int cap_put_caller(struct snd_kcontrol *kcontrol,
        int i, adc_idx, err = 0;
 
        imux = &spec->input_mux;
        int i, adc_idx, err = 0;
 
        imux = &spec->input_mux;
-       adc_idx = snd_ctl_get_ioffidx(kcontrol, &ucontrol->id);
+       adc_idx = kcontrol->id.index;
        mutex_lock(&codec->control_mutex);
        /* we use the cache-only update at first since multiple input paths
         * may shared the same amp; by updating only caches, the redundant
        mutex_lock(&codec->control_mutex);
        /* we use the cache-only update at first since multiple input paths
         * may shared the same amp; by updating only caches, the redundant