diff options
author | Kai-Heng Feng <kai.heng.feng@canonical.com> | 2021-03-25 17:59:13 +0100 |
---|---|---|
committer | Takashi Iwai <tiwai@suse.de> | 2021-03-26 09:10:33 +0100 |
commit | 44609fc01f280d6b4067262ecbb00e3128d718ae (patch) | |
tree | 7bca7809ed4ff63c53706b5bc8059ba85d6bbcf4 /sound/usb/mixer_quirks.c | |
parent | ALSA: usb-audio: Carve out connector value checking into a helper (diff) | |
download | linux-44609fc01f280d6b4067262ecbb00e3128d718ae.tar.xz linux-44609fc01f280d6b4067262ecbb00e3128d718ae.zip |
ALSA: usb-audio: Check connector value on resume
Rear Mic on Lenovo P620 cannot record after S3, despite that there's no
error and the other two functions of the USB audio, Line In and Line
Out, work just fine.
The mic starts to work again after running userspace app like "alsactl
store". Following the lead, the evidence shows that as soon as connector
status is queried, the mic can work again.
So also check connector value on resume to "wake up" the USB audio to
make it functional.
This can be device specific, however I think this generic approach may
benefit more than one device.
Now the resume callback checks connector, and a new callback,
reset_resume, to also restore switches and volumes.
Suggested-by: Takashi Iwai <tiwai@suse.de>
Signed-off-by: Kai-Heng Feng <kai.heng.feng@canonical.com>
Link: https://lore.kernel.org/r/20210325165918.22593-2-kai.heng.feng@canonical.com
Signed-off-by: Takashi Iwai <tiwai@suse.de>
Diffstat (limited to 'sound/usb/mixer_quirks.c')
-rw-r--r-- | sound/usb/mixer_quirks.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/sound/usb/mixer_quirks.c b/sound/usb/mixer_quirks.c index 5b77e8140ba6..e64cd4b11fc6 100644 --- a/sound/usb/mixer_quirks.c +++ b/sound/usb/mixer_quirks.c @@ -151,7 +151,7 @@ static int add_single_ctl_with_resume(struct usb_mixer_interface *mixer, *listp = list; list->mixer = mixer; list->id = id; - list->resume = resume; + list->reset_resume = resume; kctl = snd_ctl_new1(knew, list); if (!kctl) { kfree(list); |