mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-12-04 09:34:12 +08:00
cbb88db76a
In usX2Y_In04_init(), a new urb is firstly created through usb_alloc_urb() and saved to 'usX2Y->In04urb'. Then, a buffer is allocated through kmalloc() and saved to 'usX2Y->In04Buf'. If the allocation of the buffer fails, the error code ENOMEM is returned after usb_free_urb(), which frees the created urb. However, the urb is actually freed at card->private_free callback, i.e., snd_usX2Y_card_private_free(). So the free operation here leads to a double free bug. To fix the above issue, simply remove usb_free_urb(). Signed-off-by: Wenwen Wang <wang6495@umn.edu> Signed-off-by: Takashi Iwai <tiwai@suse.de> |
||
---|---|---|
.. | ||
Makefile | ||
us122l.c | ||
us122l.h | ||
usb_stream.c | ||
usb_stream.h | ||
usbus428ctldefs.h | ||
usbusx2y.c | ||
usbusx2y.h | ||
usbusx2yaudio.c | ||
usx2y.h | ||
usx2yhwdeppcm.c | ||
usx2yhwdeppcm.h | ||
usX2Yhwdep.c | ||
usX2Yhwdep.h |