summaryrefslogtreecommitdiffstats
path: root/sound
diff options
context:
space:
mode:
authorMark Brown <broonie@kernel.org>2022-04-20 20:34:53 +0100
committerMark Brown <broonie@kernel.org>2022-04-25 13:58:15 +0100
commit2fbe467bcbfc760a08f08475eea6bbd4c2874319 (patch)
treed6f2bffd09814adbe40b1c86dec5d5dc6460a906 /sound
parent87c18514bb8477563a61f50b4285da156296edc4 (diff)
downloadlinux-2fbe467bcbfc760a08f08475eea6bbd4c2874319.tar.gz
linux-2fbe467bcbfc760a08f08475eea6bbd4c2874319.tar.bz2
linux-2fbe467bcbfc760a08f08475eea6bbd4c2874319.zip
ASoC: max98090: Reject invalid values in custom control put()
The max98090 driver has a custom put function for some controls which can only be updated in certain circumstances which makes no effort to validate that input is suitable for the control, allowing out of spec values to be written to the hardware and presented to userspace. Fix this by returning an error when invalid values are written. Signed-off-by: Mark Brown <broonie@kernel.org> Link: https://lore.kernel.org/r/20220420193454.2647908-1-broonie@kernel.org Signed-off-by: Mark Brown <broonie@kernel.org>
Diffstat (limited to 'sound')
-rw-r--r--sound/soc/codecs/max98090.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/sound/soc/codecs/max98090.c b/sound/soc/codecs/max98090.c
index b45ec35cd63c..6d9261346842 100644
--- a/sound/soc/codecs/max98090.c
+++ b/sound/soc/codecs/max98090.c
@@ -413,6 +413,9 @@ static int max98090_put_enab_tlv(struct snd_kcontrol *kcontrol,
val = (val >> mc->shift) & mask;
+ if (sel < 0 || sel > mc->max)
+ return -EINVAL;
+
*select = sel;
/* Setting a volume is only valid if it is already On */