ASoC: tlv320aic31xx: Fix jack detection after suspend
The tlv320aic31xx driver relies on regcache_sync() to restore the register contents after going to _BIAS_OFF, for example during system suspend. This does not work for the jack detection configuration since that is configured via the same register that status is read back from so the register is volatile and not cached. This can also cause issues during init if the jack detection ends up getting set up before the CODEC is initially brought out of _BIAS_OFF, we will reset the CODEC and resync the cache as part of that process. Fix this by explicitly reapplying the jack detection configuration after resyncing the register cache during power on. This issue was found by an engineer working off-list on a product kernel, I just wrote up the upstream fix. Signed-off-by: Mark Brown <broonie@kernel.org> Link: https://lore.kernel.org/r/20210723180200.25105-1-broonie@kernel.org Cc: stable@vger.kernel.org
This commit is contained in:
Родитель
5434d0dc56
Коммит
2c39ca6885
|
@ -35,6 +35,9 @@
|
|||
|
||||
#include "tlv320aic31xx.h"
|
||||
|
||||
static int aic31xx_set_jack(struct snd_soc_component *component,
|
||||
struct snd_soc_jack *jack, void *data);
|
||||
|
||||
static const struct reg_default aic31xx_reg_defaults[] = {
|
||||
{ AIC31XX_CLKMUX, 0x00 },
|
||||
{ AIC31XX_PLLPR, 0x11 },
|
||||
|
@ -1256,6 +1259,13 @@ static int aic31xx_power_on(struct snd_soc_component *component)
|
|||
return ret;
|
||||
}
|
||||
|
||||
/*
|
||||
* The jack detection configuration is in the same register
|
||||
* that is used to report jack detect status so is volatile
|
||||
* and not covered by the cache sync, restore it separately.
|
||||
*/
|
||||
aic31xx_set_jack(component, aic31xx->jack, NULL);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
|
Загрузка…
Ссылка в новой задаче