ALSA: hda: Fix a regression in Capture Switch mixer read
authorTakashi Iwai <tiwai@suse.de>
Mon, 31 May 2021 18:06:33 +0000 (20:06 +0200)
committerTakashi Iwai <tiwai@suse.de>
Mon, 31 May 2021 18:07:47 +0000 (20:07 +0200)
commit08a4b904a2a90246aadd6aa2e4f26abca9037385
treea05feae5c55b4f87773a1468aa76c31b273bf453
parent4ad7935df6a566225c3d51900bde8f2f0f8b6de3
ALSA: hda: Fix a regression in Capture Switch mixer read

The recent commit to drop the HDA-specific mute-LED control,
e65bf99718b5 ("ALSA: HDA - remove the custom implementation for the
audio LED trigger"), caused a regression on the mixer element read for
"Capture Switch" when it's built from bind controls.  The function
create_bind_cap_vol_ctl() creates the snd_kcontrol_new object directly
via snd_hda_gen_add_kctl() instead of add_control().  Although the
commit above added a workaround for the SNDRV_CTL_ACCESS_READWRITE in
add_control() as default, this code path fell out from the radar.  As
a result, now the driver gives -EPERM error because of the lack of the
proper access bit at reading "Capture Switch" element value.

Fix the regression by setting the access bit properly.

Fixes: e65bf99718b5 ("ALSA: HDA - remove the custom implementation for the audio LED trigger")
BugLink: https://bugzilla.opensuse.org/show_bug.cgi?id=1186634
Link: https://lore.kernel.org/r/20210531180633.27831-1-tiwai@suse.de
Signed-off-by: Takashi Iwai <tiwai@suse.de>
sound/pci/hda/hda_generic.c