|
|
@@ -924,7 +924,9 @@ static int lineevent_create(struct gpio_device *gdev, void __user *ip)
|
|
|
}
|
|
|
|
|
|
/* This is just wrong: we don't look for events on output lines */
|
|
|
- if (lflags & GPIOHANDLE_REQUEST_OUTPUT) {
|
|
|
+ if ((lflags & GPIOHANDLE_REQUEST_OUTPUT) ||
|
|
|
+ (lflags & GPIOHANDLE_REQUEST_OPEN_DRAIN) ||
|
|
|
+ (lflags & GPIOHANDLE_REQUEST_OPEN_SOURCE)) {
|
|
|
ret = -EINVAL;
|
|
|
goto out_free_label;
|
|
|
}
|
|
|
@@ -938,10 +940,6 @@ static int lineevent_create(struct gpio_device *gdev, void __user *ip)
|
|
|
|
|
|
if (lflags & GPIOHANDLE_REQUEST_ACTIVE_LOW)
|
|
|
set_bit(FLAG_ACTIVE_LOW, &desc->flags);
|
|
|
- if (lflags & GPIOHANDLE_REQUEST_OPEN_DRAIN)
|
|
|
- set_bit(FLAG_OPEN_DRAIN, &desc->flags);
|
|
|
- if (lflags & GPIOHANDLE_REQUEST_OPEN_SOURCE)
|
|
|
- set_bit(FLAG_OPEN_SOURCE, &desc->flags);
|
|
|
|
|
|
ret = gpiod_direction_input(desc);
|
|
|
if (ret)
|