alistair23-linux/drivers/pinctrl/intel
Hans de Goede 04a5bebd77 pinctrl: baytrail: Do not clear IRQ flags on direct-irq enabled pins
[ Upstream commit a23680594d ]

Suspending Goodix touchscreens requires changing the interrupt pin to
output before sending them a power-down command. Followed by wiggling
the interrupt pin to wake the device up, after which it is put back
in input mode.

On Bay Trail devices with a Goodix touchscreen direct-irq mode is used
in combination with listing the pin as a normal GpioIo resource.

This works fine, until the goodix driver gets rmmod-ed and then insmod-ed
again. In this case byt_gpio_disable_free() calls
byt_gpio_clear_triggering() which clears the IRQ flags and after that the
(direct) IRQ no longer triggers.

This commit fixes this by adding a check for the BYT_DIRECT_IRQ_EN flag
to byt_gpio_clear_triggering().

Note that byt_gpio_clear_triggering() only gets called from
byt_gpio_disable_free() for direct-irq enabled pins, as these are excluded
from the irq_valid mask by byt_init_irq_valid_mask().

Signed-off-by: Hans de Goede <hdegoede@redhat.com>
Acked-by: Mika Westerberg <mika.westerberg@linux.intel.com>
Reviewed-by: Linus Walleij <linus.walleij@linaro.org>
Signed-off-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
2020-02-24 08:36:27 +01:00
..
Kconfig
Makefile
pinctrl-baytrail.c pinctrl: baytrail: Do not clear IRQ flags on direct-irq enabled pins 2020-02-24 08:36:27 +01:00
pinctrl-broxton.c
pinctrl-cannonlake.c
pinctrl-cedarfork.c
pinctrl-cherryview.c
pinctrl-denverton.c
pinctrl-geminilake.c
pinctrl-icelake.c
pinctrl-intel.c
pinctrl-intel.h
pinctrl-lewisburg.c pinctrl: lewisburg: Update pin list according to v1.1v6 2020-01-17 19:48:50 +01:00
pinctrl-merrifield.c
pinctrl-sunrisepoint.c pinctrl: sunrisepoint: Add missing Interrupt Status register offset 2020-01-29 16:45:27 +01:00