Commit 2f46205b authored by Sudeep Holla's avatar Sudeep Holla Committed by Linus Walleij

gpio: pl061: add support for wakeup configuration

The PL061 supports interrupts and those can be wakeup interrupts. We
need to provide support for configuring those interrupts as wakeup
sources.

This patch adds irq_set_wake callback for PL061 so that GPIO interrupts
can be configured as wakeup.

Cc: Linus Walleij <linus.walleij@linaro.org>
Cc: Alexandre Courbot <gnurou@gmail.com>
Signed-off-by: default avatarSudeep Holla <sudeep.holla@arm.com>
Signed-off-by: default avatarLinus Walleij <linus.walleij@linaro.org>
parent 3773c195
...@@ -14,6 +14,7 @@ ...@@ -14,6 +14,7 @@
#include <linux/module.h> #include <linux/module.h>
#include <linux/io.h> #include <linux/io.h>
#include <linux/ioport.h> #include <linux/ioport.h>
#include <linux/interrupt.h>
#include <linux/irq.h> #include <linux/irq.h>
#include <linux/irqchip/chained_irq.h> #include <linux/irqchip/chained_irq.h>
#include <linux/bitops.h> #include <linux/bitops.h>
...@@ -269,12 +270,20 @@ static void pl061_irq_ack(struct irq_data *d) ...@@ -269,12 +270,20 @@ static void pl061_irq_ack(struct irq_data *d)
spin_unlock(&chip->lock); spin_unlock(&chip->lock);
} }
static int pl061_irq_set_wake(struct irq_data *d, unsigned int state)
{
struct gpio_chip *gc = irq_data_get_irq_chip_data(d);
return irq_set_irq_wake(gc->irq_parent, state);
}
static struct irq_chip pl061_irqchip = { static struct irq_chip pl061_irqchip = {
.name = "pl061", .name = "pl061",
.irq_ack = pl061_irq_ack, .irq_ack = pl061_irq_ack,
.irq_mask = pl061_irq_mask, .irq_mask = pl061_irq_mask,
.irq_unmask = pl061_irq_unmask, .irq_unmask = pl061_irq_unmask,
.irq_set_type = pl061_irq_type, .irq_set_type = pl061_irq_type,
.irq_set_wake = pl061_irq_set_wake,
}; };
static int pl061_probe(struct amba_device *adev, const struct amba_id *id) static int pl061_probe(struct amba_device *adev, const struct amba_id *id)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment