hda/cs8904: Fix jack detection after resume

Takashi Iwai tiwai at suse.de
Tue Jan 4 16:33:33 CET 2022


On Fri, 31 Dec 2021 14:44:32 +0100,
Christian A. Ehrhardt wrote:
> 
> 
> Hi,
> 
> while debugging something different, I found the following
> jack detection related bug in the cs8904 driver on my DELL
> Inspirion 3501:
> - Plug in a headset, play some sound to make sure that
>   the headset is detected.
> - Stop the sound, wait for the codec to go into suspend (30s
>   should be plenty enough time)
> - Unplug the headset while the codec is in suspend.
> - Try to play sound on the internal speakers. Notice that
>   the the driver still thinks the headset is connected. As a result
>   there is no sound on the internal speakers.
> 
> AFAICS the bug was introduced by the following commit:
> | commit 424e531b47f83da87490464c5bf633dfb624fe6a
> | Author: Stefan Binding <sbinding at opensource.cirrus.com>
> | Date:   Fri Aug 27 12:02:51 2021 +0100
> | 
> |     ALSA: hda/cs8409: Ensure Type Detection is only run on startup when
> |     necessary
> 
> The bug is with the hp_jack_in and mic_jack_in flags that are used
> to determine if jack detection should be run etc. These flags
> are cleared in the suspend path. This prevents a status change from
> being detected after resume as hp_jack_in is cleared by suspend and
> there is no jack due to the unplug of the headset.
> 
> This status change was never reported to the HDA core, though.
> On suspend this is not done, only hd_jack_in is cleared and on
> resume the driver thinks that there is no change the needs reporting.
> 
> Proposed fix below, please consider inclusion.
> 
>      regards   Christian
> 
> >From 1dcf34c1d1c6c4852a86ec3ae189afa5d90ea09c Mon Sep 17 00:00:00 2001
> From: "Christian A. Ehrhardt" <lk at c--e.de>
> Date: Fri, 31 Dec 2021 12:13:48 +0100
> Subject: [PATCH 2/2] ALSA: hda/cs8409: Fix Jack detection after resume
> 
> The suspend code unconditionally sets ->hp_jack_in and ->mic_jack_in
> to zero but without reporting this status change to the HDA core.
> To compensate for this, always assume a status change on the
> first unsol event after boot or resume.
> 
> Fixes:	424e531b47f8 ("ALSA: hda/cs8409: Ensure Type Detection is only run on startup when necessary")
> Signed-off-by: Christian A. Ehrhardt <lk at c--e.de>

Thanks, applied now.


Takashi


More information about the Alsa-devel mailing list