gpiolib: don't allow userspace to set values of input lines
authorBartosz Golaszewski <brgl@bgdev.pl>
Mon, 16 Jul 2018 08:34:23 +0000 (10:34 +0200)
committerLinus Walleij <linus.walleij@linaro.org>
Mon, 16 Jul 2018 13:38:52 +0000 (15:38 +0200)
User space can currently both read and set values of input lines using
the character device. This was not allowed by the old sysfs interface
nor is it a correct behavior.

Check the first descriptor in the set for the OUT flag when asked to
set values and return -EPERM if the line is input.

Signed-off-by: Bartosz Golaszewski <brgl@bgdev.pl>
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
drivers/gpio/gpiolib.c

index 2e2a6f8..c507cd3 100644 (file)
@@ -449,7 +449,13 @@ static long linehandle_ioctl(struct file *filep, unsigned int cmd,
 
                return 0;
        } else if (cmd == GPIOHANDLE_SET_LINE_VALUES_IOCTL) {
-               /* TODO: check if descriptors are really output */
+               /*
+                * All line descriptors were created at once with the same
+                * flags so just check if the first one is really output.
+                */
+               if (!test_bit(FLAG_IS_OUT, &lh->descs[0]->flags))
+                       return -EPERM;
+
                if (copy_from_user(&ghd, ip, sizeof(ghd)))
                        return -EFAULT;