Skip to content

Commit 632108e

Browse files
haaeeintiwai
authored andcommitted
ALSA: usb-audio: Fix NULL pointer dereference in snd_usb_mixer_controls_badd
In snd_usb_create_streams(), for UAC version 3 devices, the Interface Association Descriptor (IAD) is retrieved via usb_ifnum_to_if(). If this call fails, a fallback routine attempts to obtain the IAD from the next interface and sets a BADD profile. However, snd_usb_mixer_controls_badd() assumes that the IAD retrieved from usb_ifnum_to_if() is always valid, without performing a NULL check. This can lead to a NULL pointer dereference when usb_ifnum_to_if() fails to find the interface descriptor. This patch adds a NULL pointer check after calling usb_ifnum_to_if() in snd_usb_mixer_controls_badd() to prevent the dereference. This issue was discovered by syzkaller, which triggered the bug by sending a crafted USB device descriptor. Fixes: 17156f2 ("ALSA: usb: add UAC3 BADD profiles support") Signed-off-by: Haein Lee <lhi0729@kaist.ac.kr> Link: https://patch.msgid.link/vwhzmoba9j2f.vwhzmob9u9e2.g6@dooray.com Signed-off-by: Takashi Iwai <tiwai@suse.de>
1 parent 05a1fc5 commit 632108e

1 file changed

Lines changed: 2 additions & 0 deletions

File tree

sound/usb/mixer.c

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -3086,6 +3086,8 @@ static int snd_usb_mixer_controls_badd(struct usb_mixer_interface *mixer,
30863086
int i;
30873087

30883088
assoc = usb_ifnum_to_if(dev, ctrlif)->intf_assoc;
3089+
if (!assoc)
3090+
return -EINVAL;
30893091

30903092
/* Detect BADD capture/playback channels from AS EP descriptors */
30913093
for (i = 0; i < assoc->bInterfaceCount; i++) {

0 commit comments

Comments
 (0)