diff mbox series

ALSA: hda: prevent undefined shift in snd_hdac_ext_bus_get_link()

Message ID 20201103101807.GC1127762@mwanda (mailing list archive)
State New, archived
Headers show
Series ALSA: hda: prevent undefined shift in snd_hdac_ext_bus_get_link() | expand

Commit Message

Dan Carpenter Nov. 3, 2020, 10:18 a.m. UTC
This is harmless, but the "addr" comes from the user and it could lead
to a negative shift or to shift wrapping if it's too high.

Fixes: 0b00a5615dc4 ("ALSA: hdac_ext: add hdac extended controller")
Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com>
---
 sound/hda/ext/hdac_ext_controller.c | 2 ++
 1 file changed, 2 insertions(+)

Comments

Takashi Iwai Nov. 3, 2020, 1:12 p.m. UTC | #1
On Tue, 03 Nov 2020 11:18:07 +0100,
Dan Carpenter wrote:
> 
> This is harmless, but the "addr" comes from the user and it could lead
> to a negative shift or to shift wrapping if it's too high.
> 
> Fixes: 0b00a5615dc4 ("ALSA: hdac_ext: add hdac extended controller")
> Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com>

Thanks, applied.


Takashi
diff mbox series

Patch

diff --git a/sound/hda/ext/hdac_ext_controller.c b/sound/hda/ext/hdac_ext_controller.c
index 4d060d5b1db6..b0c0ef824d7d 100644
--- a/sound/hda/ext/hdac_ext_controller.c
+++ b/sound/hda/ext/hdac_ext_controller.c
@@ -148,6 +148,8 @@  struct hdac_ext_link *snd_hdac_ext_bus_get_link(struct hdac_bus *bus,
 		return NULL;
 	if (bus->idx != bus_idx)
 		return NULL;
+	if (addr < 0 || addr > 31)
+		return NULL;
 
 	list_for_each_entry(hlink, &bus->hlink_list, list) {
 		for (i = 0; i < HDA_MAX_CODECS; i++) {