aboutsummaryrefslogtreecommitdiff
path: root/arch/arm/mach-vt8500/include/mach/entry-macro.S
blob: 367d1b55fb9a08696e240831e68eb83dfbea7f61 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
/*
 * arch/arm/mach-vt8500/include/mach/entry-macro.S
 *
 * Low-level IRQ helper macros for VIA VT8500
 *
 * 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.
 */

	.macro  get_irqnr_preamble, base, tmp
	@ physical 0xd8140000 is virtual 0xf8140000
	mov	\base, #0xf8000000
	orr	\base, \base, #0x00140000
	.endm

	.macro	get_irqnr_and_base, irqnr, irqstat, base, tmp
	ldr	\irqnr, [\base]
	cmp	\irqnr, #63 @ may be false positive, check interrupt status
	bne	1001f
	ldr	\irqstat, [\base, #0x84]
	ands	\irqstat, #0x80000000
	moveq	\irqnr, #0
1001:
	.endm