gpio: free handles in fringe cases
authorLinus Walleij <linus.walleij@linaro.org>
Mon, 4 Jul 2016 11:13:04 +0000 (13:13 +0200)
committerLinus Walleij <linus.walleij@linaro.org>
Mon, 4 Jul 2016 14:54:36 +0000 (16:54 +0200)
If we fail when copying the ioctl() struct to userspace we still
need to clean up the cruft otherwise left behind or it will stay
around until the issuing process terminates the file handle.

Reported-by: Alexander Stein <alexander.stein@systec-electronic.com>
Acked-by: Alexander Stein <alexander.stein@systec-electronic.com>
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
drivers/gpio/gpiolib.c

index b195ec406ff4cea2625da4c8eaad89b4ca58d92e..69efe278f74d5e7d01c987e13116c2da0e63cbbf 100644 (file)
@@ -488,8 +488,10 @@ static int linehandle_create(struct gpio_device *gdev, void __user *ip)
        }
 
        handlereq.fd = fd;
-       if (copy_to_user(ip, &handlereq, sizeof(handlereq)))
-               return -EFAULT;
+       if (copy_to_user(ip, &handlereq, sizeof(handlereq))) {
+               ret = -EFAULT;
+               goto out_free_descs;
+       }
 
        dev_dbg(&gdev->dev, "registered chardev handle for %d lines\n",
                lh->numdescs);
@@ -784,8 +786,10 @@ static int lineevent_create(struct gpio_device *gdev, void __user *ip)
        }
 
        eventreq.fd = fd;
-       if (copy_to_user(ip, &eventreq, sizeof(eventreq)))
-               return -EFAULT;
+       if (copy_to_user(ip, &eventreq, sizeof(eventreq))) {
+               ret = -EFAULT;
+               goto out_free_irq;
+       }
 
        return 0;