diff options
-rw-r--r-- | drivers/gpio/gpio-tegra.c | 21 |
1 files changed, 19 insertions, 2 deletions
diff --git a/drivers/gpio/gpio-tegra.c b/drivers/gpio/gpio-tegra.c index 414ad912232f..e3956359202c 100644 --- a/drivers/gpio/gpio-tegra.c +++ b/drivers/gpio/gpio-tegra.c | |||
@@ -72,6 +72,7 @@ struct tegra_gpio_bank { | |||
72 | u32 oe[4]; | 72 | u32 oe[4]; |
73 | u32 int_enb[4]; | 73 | u32 int_enb[4]; |
74 | u32 int_lvl[4]; | 74 | u32 int_lvl[4]; |
75 | u32 wake_enb[4]; | ||
75 | #endif | 76 | #endif |
76 | }; | 77 | }; |
77 | 78 | ||
@@ -333,15 +334,31 @@ static int tegra_gpio_suspend(struct device *dev) | |||
333 | bank->oe[p] = tegra_gpio_readl(GPIO_OE(gpio)); | 334 | bank->oe[p] = tegra_gpio_readl(GPIO_OE(gpio)); |
334 | bank->int_enb[p] = tegra_gpio_readl(GPIO_INT_ENB(gpio)); | 335 | bank->int_enb[p] = tegra_gpio_readl(GPIO_INT_ENB(gpio)); |
335 | bank->int_lvl[p] = tegra_gpio_readl(GPIO_INT_LVL(gpio)); | 336 | bank->int_lvl[p] = tegra_gpio_readl(GPIO_INT_LVL(gpio)); |
337 | |||
338 | /* Enable gpio irq for wake up source */ | ||
339 | tegra_gpio_writel(bank->wake_enb[p], | ||
340 | GPIO_INT_ENB(gpio)); | ||
336 | } | 341 | } |
337 | } | 342 | } |
338 | local_irq_restore(flags); | 343 | local_irq_restore(flags); |
339 | return 0; | 344 | return 0; |
340 | } | 345 | } |
341 | 346 | ||
342 | static int tegra_gpio_wake_enable(struct irq_data *d, unsigned int enable) | 347 | static int tegra_gpio_irq_set_wake(struct irq_data *d, unsigned int enable) |
343 | { | 348 | { |
344 | struct tegra_gpio_bank *bank = irq_data_get_irq_chip_data(d); | 349 | struct tegra_gpio_bank *bank = irq_data_get_irq_chip_data(d); |
350 | int gpio = d->hwirq; | ||
351 | u32 port, bit, mask; | ||
352 | |||
353 | port = GPIO_PORT(gpio); | ||
354 | bit = GPIO_BIT(gpio); | ||
355 | mask = BIT(bit); | ||
356 | |||
357 | if (enable) | ||
358 | bank->wake_enb[port] |= mask; | ||
359 | else | ||
360 | bank->wake_enb[port] &= ~mask; | ||
361 | |||
345 | return irq_set_irq_wake(bank->irq, enable); | 362 | return irq_set_irq_wake(bank->irq, enable); |
346 | } | 363 | } |
347 | #endif | 364 | #endif |
@@ -353,7 +370,7 @@ static struct irq_chip tegra_gpio_irq_chip = { | |||
353 | .irq_unmask = tegra_gpio_irq_unmask, | 370 | .irq_unmask = tegra_gpio_irq_unmask, |
354 | .irq_set_type = tegra_gpio_irq_set_type, | 371 | .irq_set_type = tegra_gpio_irq_set_type, |
355 | #ifdef CONFIG_PM_SLEEP | 372 | #ifdef CONFIG_PM_SLEEP |
356 | .irq_set_wake = tegra_gpio_wake_enable, | 373 | .irq_set_wake = tegra_gpio_irq_set_wake, |
357 | #endif | 374 | #endif |
358 | }; | 375 | }; |
359 | 376 | ||