diff options
author | Mark Brown <broonie@kernel.org> | 2022-06-03 14:39:37 +0200 |
---|---|---|
committer | Mark Brown <broonie@kernel.org> | 2022-06-06 13:31:27 +0200 |
commit | 8259610c2ec01c5cbfb61882ae176aabacac9c19 (patch) | |
tree | 6747990319526f59317d3b154e211f9e4cf0b4c0 /sound/soc/codecs/es8328.c | |
parent | ASoC: wm8962: Fix suspend while playing music (diff) | |
download | linux-8259610c2ec01c5cbfb61882ae176aabacac9c19.tar.xz linux-8259610c2ec01c5cbfb61882ae176aabacac9c19.zip |
ASoC: es8328: Fix event generation for deemphasis control
Currently the put() method for the deemphasis control returns 0 when a new
value is written to the control even if the value changed, meaning events
are not generated. Fix this, skip the work of updating the value when it is
unchanged and then return 1 after having done so.
Signed-off-by: Mark Brown <broonie@kernel.org>
Link: https://lore.kernel.org/r/20220603123937.4013603-1-broonie@kernel.org
Signed-off-by: Mark Brown <broonie@kernel.org>
Diffstat (limited to 'sound/soc/codecs/es8328.c')
-rw-r--r-- | sound/soc/codecs/es8328.c | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/sound/soc/codecs/es8328.c b/sound/soc/codecs/es8328.c index 3f00ead97006..dd53dfd87b04 100644 --- a/sound/soc/codecs/es8328.c +++ b/sound/soc/codecs/es8328.c @@ -161,13 +161,16 @@ static int es8328_put_deemph(struct snd_kcontrol *kcontrol, if (deemph > 1) return -EINVAL; + if (es8328->deemph == deemph) + return 0; + ret = es8328_set_deemph(component); if (ret < 0) return ret; es8328->deemph = deemph; - return 0; + return 1; } |