ASoC: max98090: fix deadlock in max98090_dapm_put_enum_double()
authorTzung-Bi Shih <tzungbi@google.com>
Fri, 17 Jan 2020 07:38:14 +0000 (15:38 +0800)
committerMark Brown <broonie@kernel.org>
Tue, 21 Jan 2020 17:15:20 +0000 (17:15 +0000)
Commit 62d5ae4cafb7 ("ASoC: max98090: save and restore SHDN when
changing sensitive registers SHDN bit") uses dapm_mutex to protect SHDN
bit.  However, snd_soc_dapm_put_enum_double() in
max98090_dapm_put_enum_double() acquires the dapm_mutex again which
cause a deadlock.

Use snd_soc_dapm_put_enum_double_locked() instead to fix the deadlock.

Fixes: 62d5ae4cafb7 ("ASoC: max98090: save and restore SHDN when changing sensitive registers SHDN bit")
Signed-off-by: Tzung-Bi Shih <tzungbi@google.com>
Link: https://lore.kernel.org/r/20200117073814.82441-4-tzungbi@google.com
Signed-off-by: Mark Brown <broonie@kernel.org>
sound/soc/codecs/max98090.c

index c01ce4a3f86da5202a94bed86f38d6e6fc8ca0fd..0313e1183167da6729c5c5218685a5155cf2c3cc 100644 (file)
@@ -88,7 +88,7 @@ static int max98090_dapm_put_enum_double(struct snd_kcontrol *kcontrol,
        int ret;
 
        max98090_shdn_save(max98090);
-       ret = snd_soc_dapm_put_enum_double(kcontrol, ucontrol);
+       ret = snd_soc_dapm_put_enum_double_locked(kcontrol, ucontrol);
        max98090_shdn_restore(max98090);
 
        return ret;