Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit e87cb470 authored by Alexey Khoroshilov's avatar Alexey Khoroshilov Committed by Mauro Carvalho Chehab
Browse files

[media] imon: fix usbdev leaks



imon_probe() does three usb_get_dev(), but there is no any
usb_put_dev() in the driver.

The patch adds usb_put_dev() to error paths, to imon_disconnect()
and to imon_probe() as far as usbdev is not saved anywhere.

Found by Linux Driver Verification project (linuxtesting.org).

Signed-off-by: default avatarAlexey Khoroshilov <khoroshilov@ispras.ru>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@osg.samsung.com>
parent 3bacc10c
Loading
Loading
Loading
Loading
+6 −0
Original line number Original line Diff line number Diff line
@@ -2283,6 +2283,7 @@ idev_setup_failed:
	usb_kill_urb(ictx->rx_urb_intf0);
	usb_kill_urb(ictx->rx_urb_intf0);
urb_submit_failed:
urb_submit_failed:
find_endpoint_failed:
find_endpoint_failed:
	usb_put_dev(ictx->usbdev_intf0);
	mutex_unlock(&ictx->lock);
	mutex_unlock(&ictx->lock);
	usb_free_urb(tx_urb);
	usb_free_urb(tx_urb);
tx_urb_alloc_failed:
tx_urb_alloc_failed:
@@ -2355,6 +2356,7 @@ urb_submit_failed:
		input_unregister_device(ictx->touch);
		input_unregister_device(ictx->touch);
touch_setup_failed:
touch_setup_failed:
find_endpoint_failed:
find_endpoint_failed:
	usb_put_dev(ictx->usbdev_intf1);
	mutex_unlock(&ictx->lock);
	mutex_unlock(&ictx->lock);
	usb_free_urb(rx_urb);
	usb_free_urb(rx_urb);
rx_urb_alloc_failed:
rx_urb_alloc_failed:
@@ -2468,11 +2470,13 @@ static int imon_probe(struct usb_interface *interface,
		 usbdev->bus->busnum, usbdev->devnum);
		 usbdev->bus->busnum, usbdev->devnum);


	mutex_unlock(&driver_lock);
	mutex_unlock(&driver_lock);
	usb_put_dev(usbdev);


	return 0;
	return 0;


fail:
fail:
	mutex_unlock(&driver_lock);
	mutex_unlock(&driver_lock);
	usb_put_dev(usbdev);
	dev_err(dev, "unable to register, err %d\n", ret);
	dev_err(dev, "unable to register, err %d\n", ret);


	return ret;
	return ret;
@@ -2512,6 +2516,7 @@ static void imon_disconnect(struct usb_interface *interface)
	if (ifnum == 0) {
	if (ifnum == 0) {
		ictx->dev_present_intf0 = false;
		ictx->dev_present_intf0 = false;
		usb_kill_urb(ictx->rx_urb_intf0);
		usb_kill_urb(ictx->rx_urb_intf0);
		usb_put_dev(ictx->usbdev_intf0);
		input_unregister_device(ictx->idev);
		input_unregister_device(ictx->idev);
		rc_unregister_device(ictx->rdev);
		rc_unregister_device(ictx->rdev);
		if (ictx->display_supported) {
		if (ictx->display_supported) {
@@ -2523,6 +2528,7 @@ static void imon_disconnect(struct usb_interface *interface)
	} else {
	} else {
		ictx->dev_present_intf1 = false;
		ictx->dev_present_intf1 = false;
		usb_kill_urb(ictx->rx_urb_intf1);
		usb_kill_urb(ictx->rx_urb_intf1);
		usb_put_dev(ictx->usbdev_intf1);
		if (ictx->display_type == IMON_DISPLAY_TYPE_VGA) {
		if (ictx->display_type == IMON_DISPLAY_TYPE_VGA) {
			input_unregister_device(ictx->touch);
			input_unregister_device(ictx->touch);
			del_timer_sync(&ictx->ttimer);
			del_timer_sync(&ictx->ttimer);