Commit 69b2c6d7 authored by Takashi Iwai's avatar Takashi Iwai

ALSA: hda - Use the common helper for thinkpad_acpi mic mute LED handling

Use the new common helper for setting up and controlling the mic mute
LED over thinkpad_acpi.  This also provides a new mixer enum "Mic
Mute-LED Mode" (that was present only for Dell models), which allows
user to choose the mic mute LED behavior.  For example, if you want
the mic mute LED turned on only while mic is on, choose "Follow
Capture" there.
Tested-by: default avatarPali Rohár <pali.rohar@gmail.com>
Signed-off-by: default avatarTakashi Iwai <tiwai@suse.de>
parent f567b788
...@@ -27,17 +27,11 @@ static void update_tpacpi_mute_led(void *private_data, int enabled) ...@@ -27,17 +27,11 @@ static void update_tpacpi_mute_led(void *private_data, int enabled)
led_set_func(TPACPI_LED_MUTE, !enabled); led_set_func(TPACPI_LED_MUTE, !enabled);
} }
static void update_tpacpi_micmute_led(struct hda_codec *codec, static void update_tpacpi_micmute(struct hda_codec *codec)
struct snd_kcontrol *kcontrol,
struct snd_ctl_elem_value *ucontrol)
{ {
if (!ucontrol || !led_set_func) struct hda_gen_spec *spec = codec->spec;
return;
if (strcmp("Capture Switch", ucontrol->id.name) == 0 && ucontrol->id.index == 0) { led_set_func(TPACPI_LED_MICMUTE, spec->micmute_led.led_value);
/* TODO: How do I verify if it's a mono or stereo here? */
bool val = ucontrol->value.integer.value[0] || ucontrol->value.integer.value[1];
led_set_func(TPACPI_LED_MICMUTE, !val);
}
} }
static void hda_fixup_thinkpad_acpi(struct hda_codec *codec, static void hda_fixup_thinkpad_acpi(struct hda_codec *codec,
...@@ -63,16 +57,11 @@ static void hda_fixup_thinkpad_acpi(struct hda_codec *codec, ...@@ -63,16 +57,11 @@ static void hda_fixup_thinkpad_acpi(struct hda_codec *codec,
spec->vmaster_mute.hook = update_tpacpi_mute_led; spec->vmaster_mute.hook = update_tpacpi_mute_led;
removefunc = false; removefunc = false;
} }
if (led_set_func(TPACPI_LED_MICMUTE, false) >= 0) { if (led_set_func(TPACPI_LED_MICMUTE, false) >= 0 &&
if (spec->num_adc_nids > 1 && !spec->dyn_adc_switch) snd_hda_gen_add_micmute_led(codec,
codec_dbg(codec, update_tpacpi_micmute) > 0)
"Skipping micmute LED control due to several ADCs");
else {
spec->cap_sync_hook = update_tpacpi_micmute_led;
removefunc = false; removefunc = false;
} }
}
}
if (led_set_func && (action == HDA_FIXUP_ACT_FREE || removefunc)) { if (led_set_func && (action == HDA_FIXUP_ACT_FREE || removefunc)) {
symbol_put(tpacpi_led_set); symbol_put(tpacpi_led_set);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment