blob: 5901b09fc96a356b1aa8d07a96c8efa3bfc9f6a6 [file] [log] [blame]
Russell Kinga09e64f2008-08-05 16:14:15 +01001/*
2 * arch/arm/mach-shark/include/mach/entry-macro.S
3 *
4 * Low-level IRQ helper macros for Shark platform
5 *
6 * This file is licensed under the terms of the GNU General Public
7 * License version 2. This program is licensed "as is" without any
8 * warranty of any kind, whether express or implied.
9 */
Russell Kinga09e64f2008-08-05 16:14:15 +010010 .macro get_irqnr_preamble, base, tmp
Russell King2342aa22011-06-26 10:04:15 +010011 mov \base, #0xe0000000
Russell Kinga09e64f2008-08-05 16:14:15 +010012 .endm
13
Russell Kinga09e64f2008-08-05 16:14:15 +010014 .macro get_irqnr_and_base, irqnr, irqstat, base, tmp
Russell Kinga09e64f2008-08-05 16:14:15 +010015
16 mov \irqstat, #0x0C
Russell King2342aa22011-06-26 10:04:15 +010017 strb \irqstat, [\base, #0x20] @outb(0x0C, 0x20) /* Poll command */
18 ldrb \irqnr, [\base, #0x20] @irq = inb(0x20) & 7
Russell Kinga09e64f2008-08-05 16:14:15 +010019 and \irqstat, \irqnr, #0x80
20 teq \irqstat, #0
21 beq 43f
22 and \irqnr, \irqnr, #7
23 teq \irqnr, #2
24 bne 44f
2543: mov \irqstat, #0x0C
Russell King2342aa22011-06-26 10:04:15 +010026 strb \irqstat, [\base, #0xa0] @outb(0x0C, 0xA0) /* Poll command */
27 ldrb \irqnr, [\base, #0xa0] @irq = (inb(0xA0) & 7) + 8
Russell Kinga09e64f2008-08-05 16:14:15 +010028 and \irqstat, \irqnr, #0x80
29 teq \irqstat, #0
30 beq 44f
31 and \irqnr, \irqnr, #7
32 add \irqnr, \irqnr, #8
3344: teq \irqstat, #0
34 .endm
35