Commit 1eca42b4 authored by Dmitry Eremin-Solenikov's avatar Dmitry Eremin-Solenikov Committed by Russell King

ARM: 8231/1: sa1100: introduce irqdomains support

Use irqdomains to manage both system and GPIO interrupts on SA1100 SoC
family. This opens path to further cleanup and unification in sa1100 IRQ
drivers.
Signed-off-by: default avatarDmitry Eremin-Solenikov <dbaryshkov@gmail.com>
Tested-by: default avatarLinus Walleij <linus.walleij@linaro.org>
Signed-off-by: default avatarRussell King <rmk+kernel@arm.linux.org.uk>
parent 18f3aec3
...@@ -702,6 +702,7 @@ config ARCH_SA1100 ...@@ -702,6 +702,7 @@ config ARCH_SA1100
select CPU_SA1100 select CPU_SA1100
select GENERIC_CLOCKEVENTS select GENERIC_CLOCKEVENTS
select HAVE_IDE select HAVE_IDE
select IRQ_DOMAIN
select ISA select ISA
select MULTI_IRQ_HANDLER select MULTI_IRQ_HANDLER
select NEED_MACH_MEMORY_H select NEED_MACH_MEMORY_H
......
...@@ -14,6 +14,7 @@ ...@@ -14,6 +14,7 @@
#include <linux/interrupt.h> #include <linux/interrupt.h>
#include <linux/io.h> #include <linux/io.h>
#include <linux/irq.h> #include <linux/irq.h>
#include <linux/irqdomain.h>
#include <linux/ioport.h> #include <linux/ioport.h>
#include <linux/syscore_ops.h> #include <linux/syscore_ops.h>
...@@ -106,6 +107,23 @@ static struct irq_chip sa1100_low_gpio_chip = { ...@@ -106,6 +107,23 @@ static struct irq_chip sa1100_low_gpio_chip = {
.irq_set_wake = sa1100_low_gpio_wake, .irq_set_wake = sa1100_low_gpio_wake,
}; };
static int sa1100_low_gpio_irqdomain_map(struct irq_domain *d,
unsigned int irq, irq_hw_number_t hwirq)
{
irq_set_chip_and_handler(irq, &sa1100_low_gpio_chip,
handle_edge_irq);
set_irq_flags(irq, IRQF_VALID | IRQF_PROBE);
return 0;
}
static struct irq_domain_ops sa1100_low_gpio_irqdomain_ops = {
.map = sa1100_low_gpio_irqdomain_map,
.xlate = irq_domain_xlate_onetwocell,
};
static struct irq_domain *sa1100_low_gpio_irqdomain;
/* /*
* IRQ11 (GPIO11 through 27) handler. We enter here with the * IRQ11 (GPIO11 through 27) handler. We enter here with the
* irq_controller_lock held, and IRQs disabled. Decode the IRQ * irq_controller_lock held, and IRQs disabled. Decode the IRQ
...@@ -187,6 +205,23 @@ static struct irq_chip sa1100_high_gpio_chip = { ...@@ -187,6 +205,23 @@ static struct irq_chip sa1100_high_gpio_chip = {
.irq_set_wake = sa1100_high_gpio_wake, .irq_set_wake = sa1100_high_gpio_wake,
}; };
static int sa1100_high_gpio_irqdomain_map(struct irq_domain *d,
unsigned int irq, irq_hw_number_t hwirq)
{
irq_set_chip_and_handler(irq, &sa1100_high_gpio_chip,
handle_edge_irq);
set_irq_flags(irq, IRQF_VALID | IRQF_PROBE);
return 0;
}
static struct irq_domain_ops sa1100_high_gpio_irqdomain_ops = {
.map = sa1100_high_gpio_irqdomain_map,
.xlate = irq_domain_xlate_onetwocell,
};
static struct irq_domain *sa1100_high_gpio_irqdomain;
/* /*
* We don't need to ACK IRQs on the SA1100 unless they're GPIOs * We don't need to ACK IRQs on the SA1100 unless they're GPIOs
* this is for internal IRQs i.e. from IRQ LCD to RTCAlrm. * this is for internal IRQs i.e. from IRQ LCD to RTCAlrm.
...@@ -224,6 +259,23 @@ static struct irq_chip sa1100_normal_chip = { ...@@ -224,6 +259,23 @@ static struct irq_chip sa1100_normal_chip = {
.irq_set_wake = sa1100_set_wake, .irq_set_wake = sa1100_set_wake,
}; };
static int sa1100_normal_irqdomain_map(struct irq_domain *d,
unsigned int irq, irq_hw_number_t hwirq)
{
irq_set_chip_and_handler(irq, &sa1100_normal_chip,
handle_level_irq);
set_irq_flags(irq, IRQF_VALID);
return 0;
}
static struct irq_domain_ops sa1100_normal_irqdomain_ops = {
.map = sa1100_normal_irqdomain_map,
.xlate = irq_domain_xlate_onetwocell,
};
static struct irq_domain *sa1100_normal_irqdomain;
static struct resource irq_resource = static struct resource irq_resource =
DEFINE_RES_MEM_NAMED(0x90050000, SZ_64K, "irqs"); DEFINE_RES_MEM_NAMED(0x90050000, SZ_64K, "irqs");
...@@ -311,8 +363,6 @@ sa1100_handle_irq(struct pt_regs *regs) ...@@ -311,8 +363,6 @@ sa1100_handle_irq(struct pt_regs *regs)
void __init sa1100_init_irq(void) void __init sa1100_init_irq(void)
{ {
unsigned int irq;
request_resource(&iomem_resource, &irq_resource); request_resource(&iomem_resource, &irq_resource);
/* disable all IRQs */ /* disable all IRQs */
...@@ -332,23 +382,17 @@ void __init sa1100_init_irq(void) ...@@ -332,23 +382,17 @@ void __init sa1100_init_irq(void)
*/ */
ICCR = 1; ICCR = 1;
for (irq = IRQ_GPIO0; irq <= IRQ_GPIO10; irq++) { sa1100_low_gpio_irqdomain = irq_domain_add_legacy(NULL,
irq_set_chip_and_handler(irq, &sa1100_low_gpio_chip, 11, IRQ_GPIO0, 0,
handle_edge_irq); &sa1100_low_gpio_irqdomain_ops, NULL);
set_irq_flags(irq, IRQF_VALID | IRQF_PROBE);
}
for (irq = IRQ_LCD; irq <= IRQ_RTCAlrm; irq++) { sa1100_normal_irqdomain = irq_domain_add_legacy(NULL,
irq_set_chip_and_handler(irq, &sa1100_normal_chip, 20, IRQ_LCD, 12,
handle_level_irq); &sa1100_normal_irqdomain_ops, NULL);
set_irq_flags(irq, IRQF_VALID);
}
for (irq = IRQ_GPIO11; irq <= IRQ_GPIO27; irq++) { sa1100_high_gpio_irqdomain = irq_domain_add_legacy(NULL,
irq_set_chip_and_handler(irq, &sa1100_high_gpio_chip, 17, IRQ_GPIO11, 11,
handle_edge_irq); &sa1100_high_gpio_irqdomain_ops, NULL);
set_irq_flags(irq, IRQF_VALID | IRQF_PROBE);
}
/* /*
* Install handler for GPIO 11-27 edge detect interrupts * Install handler for GPIO 11-27 edge detect interrupts
......
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