summaryrefslogtreecommitdiff
path: root/drivers/pinctrl/stm32/pinctrl-stm32f429.c
diff options
context:
space:
mode:
authorMika Westerberg <mika.westerberg@linux.intel.com>2017-11-29 16:25:44 +0300
committerLinus Walleij <linus.walleij@linaro.org>2017-12-02 13:11:04 +0100
commitf5a26acf0162477af6ee4c11b4fb9cffe5d3e257 (patch)
tree502fb86ed46af18efabcaaf42c245ccc57fc8762 /drivers/pinctrl/stm32/pinctrl-stm32f429.c
parent13f9d59cef91a027bb338fc79b564fafa7680cd8 (diff)
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: 7981c0015af2 ("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>
Diffstat (limited to 'drivers/pinctrl/stm32/pinctrl-stm32f429.c')
0 files changed, 0 insertions, 0 deletions