/* * Low-level IRQ helper macros for TI DaVinci-based platforms * * Author: Kevin Hilman, MontaVista Software, Inc. <source@mvista.com> * * 2007 (c) MontaVista Software, Inc. This file is licensed under * the terms of the GNU General Public License version 2. This program * is licensed "as is" without any warranty of any kind, whether express * or implied. */ #include <mach/irqs.h> .macro get_irqnr_preamble, base, tmp ldr \base, =davinci_intc_base ldr \base, [\base] .endm .macro get_irqnr_and_base, irqnr, irqstat, base, tmp #if defined(CONFIG_AINTC) && defined(CONFIG_CP_INTC) ldr \tmp, =davinci_intc_type ldr \tmp, [\tmp] cmp \tmp, #DAVINCI_INTC_TYPE_CP_INTC beq 1001f #endif #if defined(CONFIG_AINTC) ldr \tmp, [\base, #0x14] movs \tmp, \tmp, lsr #2 sub \irqnr, \tmp, #1 b 1002f #endif #if defined(CONFIG_CP_INTC) 1001: ldr \irqnr, [\base, #0x80] /* get irq number */ and \irqnr, \irqnr, #0xff /* irq is in bits 0-9 */ mov \tmp, \irqnr, lsr #3 and \tmp, \tmp, #0xfc add \tmp, \tmp, #0x280 /* get the register offset */ ldr \irqstat, [\base, \tmp] /* get the intc status */ cmp \irqstat, #0x0 #endif 1002: .endm