[media] lirc_imon: do not leave imon_probe() with mutex held
Commitaf8a819a25
("[media] lirc_imon: simplify error handling code") lost mutex_unlock(&context->ctx_lock), so imon_probe() exits with the context->ctx_lock mutex acquired. The patch adds mutex_unlock(&context->ctx_lock) back. Found by Linux Driver Verification project (linuxtesting.org). Fixes:af8a819a25
("[media] lirc_imon: simplify error handling code") Signed-off-by: Alexey Khoroshilov <khoroshilov@ispras.ru> Signed-off-by: Mauro Carvalho Chehab <mchehab@osg.samsung.com>
This commit is contained in:
parent
18349f4009
commit
b833d0df94
|
@ -885,12 +885,14 @@ static int imon_probe(struct usb_interface *interface,
|
||||||
vendor, product, ifnum, usbdev->bus->busnum, usbdev->devnum);
|
vendor, product, ifnum, usbdev->bus->busnum, usbdev->devnum);
|
||||||
|
|
||||||
/* Everything went fine. Just unlock and return retval (with is 0) */
|
/* Everything went fine. Just unlock and return retval (with is 0) */
|
||||||
|
mutex_unlock(&context->ctx_lock);
|
||||||
goto driver_unlock;
|
goto driver_unlock;
|
||||||
|
|
||||||
unregister_lirc:
|
unregister_lirc:
|
||||||
lirc_unregister_driver(driver->minor);
|
lirc_unregister_driver(driver->minor);
|
||||||
|
|
||||||
free_tx_urb:
|
free_tx_urb:
|
||||||
|
mutex_unlock(&context->ctx_lock);
|
||||||
usb_free_urb(tx_urb);
|
usb_free_urb(tx_urb);
|
||||||
|
|
||||||
free_rx_urb:
|
free_rx_urb:
|
||||||
|
|
Loading…
Reference in New Issue