diff options
Diffstat (limited to 'arch/arm/mach-dove/irq.c')
| -rw-r--r-- | arch/arm/mach-dove/irq.c | 36 | 
1 files changed, 36 insertions, 0 deletions
diff --git a/arch/arm/mach-dove/irq.c b/arch/arm/mach-dove/irq.c index bc4344aa100..4a5a7aedcb7 100644 --- a/arch/arm/mach-dove/irq.c +++ b/arch/arm/mach-dove/irq.c @@ -108,6 +108,38 @@ static int __initdata gpio2_irqs[4] = {  	0,  }; +#ifdef CONFIG_MULTI_IRQ_HANDLER +/* + * Compiling with both non-DT and DT support enabled, will + * break asm irq handler used by non-DT boards. Therefore, + * we provide a C-style irq handler even for non-DT boards, + * if MULTI_IRQ_HANDLER is set. + */ + +static void __iomem *dove_irq_base = IRQ_VIRT_BASE; + +static asmlinkage void +__exception_irq_entry dove_legacy_handle_irq(struct pt_regs *regs) +{ +	u32 stat; + +	stat = readl_relaxed(dove_irq_base + IRQ_CAUSE_LOW_OFF); +	stat &= readl_relaxed(dove_irq_base + IRQ_MASK_LOW_OFF); +	if (stat) { +		unsigned int hwirq = __fls(stat); +		handle_IRQ(hwirq, regs); +		return; +	} +	stat = readl_relaxed(dove_irq_base + IRQ_CAUSE_HIGH_OFF); +	stat &= readl_relaxed(dove_irq_base + IRQ_MASK_HIGH_OFF); +	if (stat) { +		unsigned int hwirq = 32 + __fls(stat); +		handle_IRQ(hwirq, regs); +		return; +	} +} +#endif +  void __init dove_init_irq(void)  {  	int i; @@ -115,6 +147,10 @@ void __init dove_init_irq(void)  	orion_irq_init(0, IRQ_VIRT_BASE + IRQ_MASK_LOW_OFF);  	orion_irq_init(32, IRQ_VIRT_BASE + IRQ_MASK_HIGH_OFF); +#ifdef CONFIG_MULTI_IRQ_HANDLER +	set_handle_irq(dove_legacy_handle_irq); +#endif +  	/*  	 * Initialize gpiolib for GPIOs 0-71.  	 */  | 
