mirror of
https://github.com/alsa-project/alsa-lib.git
synced 2026-05-30 21:38:11 -04:00
topology: decoder: fix wrong sizeof for enum control allocation in dapm
The tplg_calloc() call for enum control in the dapm widget kcontrol decode loop used sizeof(*mt) (mixer template) instead of sizeof(*et) (enum template). On 64-bit systems, snd_tplg_mixer_template is 72 bytes while snd_tplg_enum_template is 80 bytes, causing an 8-byte heap buffer overflow when the enum fields (texts, values pointers) were written past the allocated block. This resulted in heap corruption and e.g. glibc malloc hit an assert. Closes: https://github.com/alsa-project/alsa-lib/pull/501 Signed-off-by: Kai Vehmanen <kai.vehmanen@linux.intel.com> Signed-off-by: Jaroslav Kysela <perex@perex.cz>
This commit is contained in:
parent
3592e5c781
commit
eebca4c0b0
1 changed files with 1 additions and 1 deletions
|
|
@ -983,7 +983,7 @@ next:
|
|||
bin, size2);
|
||||
break;
|
||||
case SND_SOC_TPLG_TYPE_ENUM:
|
||||
et = tplg_calloc(&heap, sizeof(*mt));
|
||||
et = tplg_calloc(&heap, sizeof(*et));
|
||||
if (et == NULL) {
|
||||
err = -ENOMEM;
|
||||
goto retval;
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue