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