Prev: [RFC][PATCH] PM: Avoid losing wakeup events during suspend
Next: audit_tree: sleep inside atomic
From: Jiri Slaby on 21 Jun 2010 11:10 Stanse found that in snd_usb_parse_audio_endpoints, there is a dangling pointer dereference. When snd_usb_parse_audio_format fails, fp is freed, and continue invoked. On the next loop, there is "fp && fp->altsetting == 1 && fp->channels == 1" test, but fp is set from the last iteration (but is bogus) and thus ilegally dereferenced. Set fp to NULL before "continue". Signed-off-by: Jiri Slaby <jslaby(a)suse.cz> Cc: Daniel Mack <daniel(a)caiaq.de> Cc: Clemens Ladisch <clemens(a)ladisch.de> Cc: Takashi Iwai <tiwai(a)suse.de> --- sound/usb/endpoint.c | 1 + 1 files changed, 1 insertions(+), 0 deletions(-) diff --git a/sound/usb/endpoint.c b/sound/usb/endpoint.c index 9593b91..6f6596c 100644 --- a/sound/usb/endpoint.c +++ b/sound/usb/endpoint.c @@ -427,6 +427,7 @@ int snd_usb_parse_audio_endpoints(struct snd_usb_audio *chip, int iface_no) if (snd_usb_parse_audio_format(chip, fp, format, fmt, stream, alts) < 0) { kfree(fp->rate_table); kfree(fp); + fp = NULL; continue; } -- 1.7.1 -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo(a)vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/
|
Pages: 1 Prev: [RFC][PATCH] PM: Avoid losing wakeup events during suspend Next: audit_tree: sleep inside atomic |