diff options
author | Thierry Reding <treding@nvidia.com> | 2017-11-07 13:15:48 -0500 |
---|---|---|
committer | Linus Walleij <linus.walleij@linaro.org> | 2017-11-08 08:07:20 -0500 |
commit | c7a0aa59524c5bb20bebaca360f7c5faaec6b806 (patch) | |
tree | d4eec845e9b4a22a2596e45fd5438e6b8f89b0c3 | |
parent | f0fbe7bce733561b76a5b55c5f4625888acd3792 (diff) |
gpio: Move irq_handler to struct gpio_irq_chip
In order to consolidate the multiple ways to associate an IRQ chip with
a GPIO chip, move more fields into the new struct gpio_irq_chip.
Signed-off-by: Thierry Reding <treding@nvidia.com>
Acked-by: Grygorii Strashko <grygorii.strashko@ti.com>
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
-rw-r--r-- | drivers/gpio/gpiolib.c | 4 | ||||
-rw-r--r-- | include/linux/gpio/driver.h | 11 |
2 files changed, 10 insertions, 5 deletions
diff --git a/drivers/gpio/gpiolib.c b/drivers/gpio/gpiolib.c index 9ee75a45ba37..dafbca12c4ca 100644 --- a/drivers/gpio/gpiolib.c +++ b/drivers/gpio/gpiolib.c | |||
@@ -1646,7 +1646,7 @@ static int gpiochip_irq_map(struct irq_domain *d, unsigned int irq, | |||
1646 | * category than their parents, so it won't report false recursion. | 1646 | * category than their parents, so it won't report false recursion. |
1647 | */ | 1647 | */ |
1648 | irq_set_lockdep_class(irq, chip->lock_key); | 1648 | irq_set_lockdep_class(irq, chip->lock_key); |
1649 | irq_set_chip_and_handler(irq, chip->irq.chip, chip->irq_handler); | 1649 | irq_set_chip_and_handler(irq, chip->irq.chip, chip->irq.handler); |
1650 | /* Chips that use nested thread handlers have them marked */ | 1650 | /* Chips that use nested thread handlers have them marked */ |
1651 | if (chip->irq_nested) | 1651 | if (chip->irq_nested) |
1652 | irq_set_nested_thread(irq, 1); | 1652 | irq_set_nested_thread(irq, 1); |
@@ -1820,7 +1820,7 @@ int gpiochip_irqchip_add_key(struct gpio_chip *gpiochip, | |||
1820 | } | 1820 | } |
1821 | 1821 | ||
1822 | gpiochip->irq.chip = irqchip; | 1822 | gpiochip->irq.chip = irqchip; |
1823 | gpiochip->irq_handler = handler; | 1823 | gpiochip->irq.handler = handler; |
1824 | gpiochip->irq_default_type = type; | 1824 | gpiochip->irq_default_type = type; |
1825 | gpiochip->to_irq = gpiochip_to_irq; | 1825 | gpiochip->to_irq = gpiochip_to_irq; |
1826 | gpiochip->lock_key = lock_key; | 1826 | gpiochip->lock_key = lock_key; |
diff --git a/include/linux/gpio/driver.h b/include/linux/gpio/driver.h index c5dfa8c0b829..864f507e859b 100644 --- a/include/linux/gpio/driver.h +++ b/include/linux/gpio/driver.h | |||
@@ -47,6 +47,14 @@ struct gpio_irq_chip { | |||
47 | const struct irq_domain_ops *domain_ops; | 47 | const struct irq_domain_ops *domain_ops; |
48 | 48 | ||
49 | /** | 49 | /** |
50 | * @handler: | ||
51 | * | ||
52 | * The IRQ handler to use (often a predefined IRQ core function) for | ||
53 | * GPIO IRQs, provided by GPIO driver. | ||
54 | */ | ||
55 | irq_flow_handler_t handler; | ||
56 | |||
57 | /** | ||
50 | * @parent_handler: | 58 | * @parent_handler: |
51 | * | 59 | * |
52 | * The interrupt handler for the GPIO chip's parent interrupts, may be | 60 | * The interrupt handler for the GPIO chip's parent interrupts, may be |
@@ -132,8 +140,6 @@ static inline struct gpio_irq_chip *to_gpio_irq_chip(struct irq_chip *chip) | |||
132 | * safely. | 140 | * safely. |
133 | * @bgpio_dir: shadowed direction register for generic GPIO to clear/set | 141 | * @bgpio_dir: shadowed direction register for generic GPIO to clear/set |
134 | * direction safely. | 142 | * direction safely. |
135 | * @irq_handler: the irq handler to use (often a predefined irq core function) | ||
136 | * for GPIO IRQs, provided by GPIO driver | ||
137 | * @irq_default_type: default IRQ triggering type applied during GPIO driver | 143 | * @irq_default_type: default IRQ triggering type applied during GPIO driver |
138 | * initialization, provided by GPIO driver | 144 | * initialization, provided by GPIO driver |
139 | * @irq_chained_parent: GPIO IRQ chip parent/bank linux irq number, | 145 | * @irq_chained_parent: GPIO IRQ chip parent/bank linux irq number, |
@@ -214,7 +220,6 @@ struct gpio_chip { | |||
214 | * With CONFIG_GPIOLIB_IRQCHIP we get an irqchip inside the gpiolib | 220 | * With CONFIG_GPIOLIB_IRQCHIP we get an irqchip inside the gpiolib |
215 | * to handle IRQs for most practical cases. | 221 | * to handle IRQs for most practical cases. |
216 | */ | 222 | */ |
217 | irq_flow_handler_t irq_handler; | ||
218 | unsigned int irq_default_type; | 223 | unsigned int irq_default_type; |
219 | unsigned int irq_chained_parent; | 224 | unsigned int irq_chained_parent; |
220 | bool irq_nested; | 225 | bool irq_nested; |