diff options
author | Russell King <rmk+kernel@armlinux.org.uk> | 2019-04-08 12:46:53 -0700 |
---|---|---|
committer | Linus Walleij <linus.walleij@linaro.org> | 2019-04-11 15:13:33 +0200 |
commit | e6818d29ea1591b3e37d9cf635dc9dbca1a398ae (patch) | |
tree | 1ef23ddc4fa32e9455da5e4ba2bb9a7916aba87b /drivers/gpio/gpio-rc5t583.c | |
parent | 4779a066e71dee0784e09eeebb57dcd56cb7c7f6 (diff) | |
download | linux-e6818d29ea1591b3e37d9cf635dc9dbca1a398ae.tar.bz2 |
gpio: gpio-omap: configure edge detection for level IRQs for idle wakeup
The GPIO block can enter idle independently of the CPU power management
calls via smart-idle. When the GPIO block enters idle, level detection
stops working due to clocks being shut off, and an alternative form of
edge detection is used. However, this needs the edge detection
registers set to mark the appropriate edges.
Arrange to configure the edge detection enables along with the level
detection to ensure that any transition to active interrupt state that
occurs while the block is idle is detected as a wake-up event.
Since we enable the edge detection when configuring the IRQ, both
omap2_gpio_enable_level_quirk() nor omap2_gpio_disable_level_quirk()
become redundant, which also means OMAP_GPIO_QUIRK_IDLE_REMOVE_TRIGGER
can be removed. This can be now done without regressions as patch
"gpio: gpio-omap: fix level interrupt idling" allows level interrupts
to idle on omap4 without a workaround.
Cc: Aaro Koskinen <aaro.koskinen@iki.fi>
Cc: Grygorii Strashko <grygorii.strashko@ti.com>
Cc: Keerthy <j-keerthy@ti.com>
Cc: Peter Ujfalusi <peter.ujfalusi@ti.com>
Cc: Tero Kristo <t-kristo@ti.com>
Signed-off-by: Russell King <rmk+kernel@armlinux.org.uk>
[tony@atomide.com: update description for the fix dependency]
Signed-off-by: Tony Lindgren <tony@atomide.com>
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
Diffstat (limited to 'drivers/gpio/gpio-rc5t583.c')
0 files changed, 0 insertions, 0 deletions