diff options
author | Tarun Kanti DebBarma <tarun.kanti@ti.com> | 2012-02-29 11:19:21 -0500 |
---|---|---|
committer | Tarun Kanti DebBarma <tarun.kanti@ti.com> | 2012-03-20 05:58:58 -0400 |
commit | 381a752f291763bd6971521fa44c76ad9e937f7b (patch) | |
tree | b8d934798fbc29b0bac9c81642eb24feec31f5af /drivers/gpio/gpio-omap.c | |
parent | 81b279d80a63628e580c71a31d30a8c3b3047ad4 (diff) |
gpio/omap: fix wakeup_en register update in _set_gpio_wakeup()
There are two ways through which wakeup_en register can be programmed
using gpiolib APIs as shown below. It is seen that in the second case
in _set_gpio_wakeup(), even though bank->suspend_wakeup is updated
correctly, its value is not programmed in wakeup_en register. Fix this.
irq_set_type()->gpio_irq_type()->_set_gpio_triggering()->set_gpio_trigger()
irq_set_wake()->gpio_wake_enable()->_set_gpio_wakeup()
Signed-off-by: Tarun Kanti DebBarma <tarun.kanti@ti.com>
Reviewed-by: Kevin Hilman <khilman@ti.com>
Signed-off-by: Kevin Hilman <khilman@ti.com>
Diffstat (limited to 'drivers/gpio/gpio-omap.c')
-rw-r--r-- | drivers/gpio/gpio-omap.c | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/drivers/gpio/gpio-omap.c b/drivers/gpio/gpio-omap.c index 7cbad8569268..1a144ac3b34e 100644 --- a/drivers/gpio/gpio-omap.c +++ b/drivers/gpio/gpio-omap.c | |||
@@ -511,6 +511,7 @@ static int _set_gpio_wakeup(struct gpio_bank *bank, int gpio, int enable) | |||
511 | else | 511 | else |
512 | bank->suspend_wakeup &= ~gpio_bit; | 512 | bank->suspend_wakeup &= ~gpio_bit; |
513 | 513 | ||
514 | __raw_writel(bank->suspend_wakeup, bank->base + bank->regs->wkup_en); | ||
514 | spin_unlock_irqrestore(&bank->lock, flags); | 515 | spin_unlock_irqrestore(&bank->lock, flags); |
515 | 516 | ||
516 | return 0; | 517 | return 0; |