forked from Minki/linux
fdd8b079e3
Symbols like SOFT_RESET are way too generic to be exported at large. To avoid this, let's move the mbus bridge register defines into a separate file and include it where needed. This affects mach-kirkwood, mach-loki, mach-mv78xx0 and mach-orion5x simultaneously as they all share code in plat-orion which relies on those defines. Some other defines have been moved to narrower scopes, or simply deleted when they had no user. This fixes compilation problem with mpt2sas on the above listed platforms. Signed-off-by: Nicolas Pitre <nico@marvell.com> Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
32 lines
844 B
ArmAsm
32 lines
844 B
ArmAsm
/*
|
|
* arch/arm/mach-orion5x/include/mach/entry-macro.S
|
|
*
|
|
* Low-level IRQ helper macros for Orion platforms
|
|
*
|
|
* 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/bridge-regs.h>
|
|
|
|
.macro disable_fiq
|
|
.endm
|
|
|
|
.macro arch_ret_to_user, tmp1, tmp2
|
|
.endm
|
|
|
|
.macro get_irqnr_preamble, base, tmp
|
|
ldr \base, =MAIN_IRQ_CAUSE
|
|
.endm
|
|
|
|
.macro get_irqnr_and_base, irqnr, irqstat, base, tmp
|
|
ldr \irqstat, [\base, #0] @ main cause
|
|
ldr \tmp, [\base, #(MAIN_IRQ_MASK - MAIN_IRQ_CAUSE)] @ main mask
|
|
mov \irqnr, #0 @ default irqnr
|
|
@ find cause bits that are unmasked
|
|
ands \irqstat, \irqstat, \tmp @ clear Z flag if any
|
|
clzne \irqnr, \irqstat @ calc irqnr
|
|
rsbne \irqnr, \irqnr, #31
|
|
.endm
|