[media] dib0700: Fix memory leak during initialization
Reported by kmemleak. Signed-off-by: Jean Delvare <khali@linux-fr.org> Cc: Mauro Carvalho Chehab <mchehab@infradead.org> Cc: Devin Heitmueller <dheitmueller@kernellabs.com> Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
This commit is contained in:
Родитель
3ef7675948
Коммит
d3db22e10b
|
@ -679,6 +679,7 @@ static void dib0700_rc_urb_completion(struct urb *purb)
|
|||
deb_info("%s()\n", __func__);
|
||||
if (d->rc_dev == NULL) {
|
||||
/* This will occur if disable_rc_polling=1 */
|
||||
kfree(purb->transfer_buffer);
|
||||
usb_free_urb(purb);
|
||||
return;
|
||||
}
|
||||
|
@ -687,6 +688,7 @@ static void dib0700_rc_urb_completion(struct urb *purb)
|
|||
|
||||
if (purb->status < 0) {
|
||||
deb_info("discontinuing polling\n");
|
||||
kfree(purb->transfer_buffer);
|
||||
usb_free_urb(purb);
|
||||
return;
|
||||
}
|
||||
|
@ -781,8 +783,11 @@ int dib0700_rc_setup(struct dvb_usb_device *d)
|
|||
dib0700_rc_urb_completion, d);
|
||||
|
||||
ret = usb_submit_urb(purb, GFP_ATOMIC);
|
||||
if (ret)
|
||||
if (ret) {
|
||||
err("rc submit urb failed\n");
|
||||
kfree(purb->transfer_buffer);
|
||||
usb_free_urb(purb);
|
||||
}
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
|
Загрузка…
Ссылка в новой задаче