diff options
author | Benjamin Herrenschmidt <benh@kernel.crashing.org> | 2007-12-20 23:39:32 -0500 |
---|---|---|
committer | Josh Boyer <jwboyer@linux.vnet.ibm.com> | 2007-12-23 14:14:22 -0500 |
commit | ee41eea947ebe2f1f627fafe0e429b5dcaaab944 (patch) | |
tree | edbd01b730cf1e8c2f836cd281ab7d5b0ad39557 | |
parent | d23f5099297c0f017ba4fb165dc9879bda11f9ce (diff) |
[POWERPC] 4xx: Add mfspr/mtspr inline macros to 4xx bootwrapper
The 4xx bootwrapper occasionally needs to access SPR registers,
this adds mfspr/mtspr wrappers to it.
Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Signed-off-by: Josh Boyer <jwboyer@linux.vnet.ibm.com>
-rw-r--r-- | arch/powerpc/boot/reg.h | 8 |
1 files changed, 8 insertions, 0 deletions
diff --git a/arch/powerpc/boot/reg.h b/arch/powerpc/boot/reg.h index d3cd9ee98afb..9c2c9978e0eb 100644 --- a/arch/powerpc/boot/reg.h +++ b/arch/powerpc/boot/reg.h | |||
@@ -16,6 +16,14 @@ static inline u32 mfpvr(void) | |||
16 | return pvr; | 16 | return pvr; |
17 | } | 17 | } |
18 | 18 | ||
19 | #define __stringify_1(x) #x | ||
20 | #define __stringify(x) __stringify_1(x) | ||
21 | |||
22 | #define mfspr(rn) ({unsigned long rval; \ | ||
23 | asm volatile("mfspr %0," __stringify(rn) \ | ||
24 | : "=r" (rval)); rval; }) | ||
25 | #define mtspr(rn, v) asm volatile("mtspr " __stringify(rn) ",%0" : : "r" (v)) | ||
26 | |||
19 | register void *__stack_pointer asm("r1"); | 27 | register void *__stack_pointer asm("r1"); |
20 | #define get_sp() (__stack_pointer) | 28 | #define get_sp() (__stack_pointer) |
21 | 29 | ||