ASoC: Fix soc-cache buffer overflow bug
Make sure we stay within the cache boundaries when updating the register cache. Signed-off-by: Dimitris Papastamos <dp@opensource.wolfsonmicro.com> Acked-by: Liam Girdwood <lrg@slimlogic.co.uk> Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
This commit is contained in:
parent
0b25ad0571
commit
fa6d529389
1 changed files with 3 additions and 2 deletions
|
@ -203,7 +203,8 @@ static int snd_soc_8_16_write(struct snd_soc_codec *codec, unsigned int reg,
|
||||||
data[1] = (value >> 8) & 0xff;
|
data[1] = (value >> 8) & 0xff;
|
||||||
data[2] = value & 0xff;
|
data[2] = value & 0xff;
|
||||||
|
|
||||||
if (!snd_soc_codec_volatile_register(codec, reg))
|
if (!snd_soc_codec_volatile_register(codec, reg)
|
||||||
|
&& reg < codec->driver->reg_cache_size)
|
||||||
reg_cache[reg] = value;
|
reg_cache[reg] = value;
|
||||||
|
|
||||||
if (codec->cache_only) {
|
if (codec->cache_only) {
|
||||||
|
|
Loading…
Reference in a new issue