]> git.baikalelectronics.ru Git - kernel.git/commit
pinctrl: intel: Initialize GPIO properly when used through irqchip
authorMika Westerberg <mika.westerberg@linux.intel.com>
Wed, 29 Nov 2017 13:25:44 +0000 (16:25 +0300)
committerLinus Walleij <linus.walleij@linaro.org>
Sat, 2 Dec 2017 12:11:04 +0000 (13:11 +0100)
commit0856b7078687d6bb77e40d336d955c0c17820ee7
tree502fb86ed46af18efabcaaf42c245ccc57fc8762
parent03575ad15817dc448e588f8218b359c2160cddc4
pinctrl: intel: Initialize GPIO properly when used through irqchip

When a GPIO is requested using gpiod_get_* APIs the intel pinctrl driver
switches the pin to GPIO mode and makes sure interrupts are routed to
the GPIO hardware instead of IOAPIC. However, if the GPIO is used
directly through irqchip, as is the case with many I2C-HID devices where
I2C core automatically configures interrupt for the device, the pin is
not initialized as GPIO. Instead we rely that the BIOS configures the
pin accordingly which seems not to be the case at least in Asus X540NA
SKU3 with Focaltech touchpad.

When the pin is not properly configured it might result weird behaviour
like interrupts suddenly stop firing completely and the touchpad stops
responding to user input.

Fix this by properly initializing the pin to GPIO mode also when it is
used directly through irqchip.

Fixes: 303a3961afcd ("pinctrl: intel: Add Intel Sunrisepoint pin controller and GPIO support")
Reported-by: Daniel Drake <drake@endlessm.com>
Reported-and-tested-by: Chris Chiu <chiu@endlessm.com>
Signed-off-by: Mika Westerberg <mika.westerberg@linux.intel.com>
Cc: stable@vger.kernel.org
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
drivers/pinctrl/intel/pinctrl-intel.c