blob: ed313c52a8a42591cfc3e38e3576986bd77fe450 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/*
2 * include/asm-arm/arch-ixp4xx/entry-macro.S
3 *
4 * Low-level IRQ helper macros for IXP4xx-based platforms
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 Kingbe509722008-08-04 10:41:28 +010010#include <asm/arch/hardware.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070011
12 .macro disable_fiq
13 .endm
14
Dan Williamsf80dff92007-02-16 22:16:32 +010015 .macro get_irqnr_preamble, base, tmp
16 .endm
17
18 .macro arch_ret_to_user, tmp1, tmp2
19 .endm
20
Linus Torvalds1da177e2005-04-16 15:20:36 -070021 .macro get_irqnr_and_base, irqnr, irqstat, base, tmp
22 ldr \irqstat, =(IXP4XX_INTC_BASE_VIRT+IXP4XX_ICIP_OFFSET)
23 ldr \irqstat, [\irqstat] @ get interrupts
24 cmp \irqstat, #0
Kenneth Tan251b9282005-10-18 07:53:35 +010025 beq 1001f @ upper IRQ?
Linus Torvalds1da177e2005-04-16 15:20:36 -070026 clz \irqnr, \irqstat
27 mov \base, #31
Kenneth Tan251b9282005-10-18 07:53:35 +010028 sub \irqnr, \base, \irqnr
29 b 1002f @ lower IRQ being
30 @ handled
Linus Torvalds1da177e2005-04-16 15:20:36 -070031
321001:
33 /*
Ruslan V. Sushko45fba082007-04-06 15:00:31 +010034 * IXP465/IXP435 has an upper IRQ status register
Linus Torvalds1da177e2005-04-16 15:20:36 -070035 */
Ruslan V. Sushko45fba082007-04-06 15:00:31 +010036#if defined(CONFIG_CPU_IXP46X) || defined(CONFIG_CPU_IXP43X)
Linus Torvalds1da177e2005-04-16 15:20:36 -070037 ldr \irqstat, =(IXP4XX_INTC_BASE_VIRT+IXP4XX_ICIP2_OFFSET)
38 ldr \irqstat, [\irqstat] @ get upper interrupts
39 mov \irqnr, #63
40 clz \irqstat, \irqstat
41 cmp \irqstat, #32
42 subne \irqnr, \irqnr, \irqstat
Linus Torvalds1da177e2005-04-16 15:20:36 -070043#endif
Kenneth Tan251b9282005-10-18 07:53:35 +0100441002:
Linus Torvalds1da177e2005-04-16 15:20:36 -070045 .endm
46
47