diff options
author | Akira Takeuchi <takeuchi.akr@jp.panasonic.com> | 2010-10-27 12:28:55 -0400 |
---|---|---|
committer | David Howells <dhowells@redhat.com> | 2010-10-27 12:28:55 -0400 |
commit | 368dd5acd154b09c043cc4392a74da01599b37d5 (patch) | |
tree | dd94ae3d044f6e774dec2437613515bd6b46dacb /arch/mn10300/include/asm/irqflags.h | |
parent | 04157a6e7df99fd5ed64955233d6e00ab6613614 (diff) |
MN10300: And Panasonic AM34 subarch and implement SMP
Implement the Panasonic MN10300 AM34 CPU subarch and implement SMP support for
MN10300. Also implement support for the MN2WS0060 processor and the ASB2364
evaluation board which are AM34 based.
Signed-off-by: Akira Takeuchi <takeuchi.akr@jp.panasonic.com>
Signed-off-by: Kiyoshi Owada <owada.kiyoshi@jp.panasonic.com>
Signed-off-by: David Howells <dhowells@redhat.com>
Diffstat (limited to 'arch/mn10300/include/asm/irqflags.h')
-rw-r--r-- | arch/mn10300/include/asm/irqflags.h | 26 |
1 files changed, 23 insertions, 3 deletions
diff --git a/arch/mn10300/include/asm/irqflags.h b/arch/mn10300/include/asm/irqflags.h index b3ab2071354d..7a7ae12c7119 100644 --- a/arch/mn10300/include/asm/irqflags.h +++ b/arch/mn10300/include/asm/irqflags.h | |||
@@ -13,6 +13,9 @@ | |||
13 | #define _ASM_IRQFLAGS_H | 13 | #define _ASM_IRQFLAGS_H |
14 | 14 | ||
15 | #include <asm/cpu-regs.h> | 15 | #include <asm/cpu-regs.h> |
16 | #ifndef __ASSEMBLY__ | ||
17 | #include <linux/smp.h> | ||
18 | #endif | ||
16 | 19 | ||
17 | /* | 20 | /* |
18 | * interrupt control | 21 | * interrupt control |
@@ -60,11 +63,12 @@ static inline unsigned long arch_local_irq_save(void) | |||
60 | /* | 63 | /* |
61 | * we make sure arch_irq_enable() doesn't cause priority inversion | 64 | * we make sure arch_irq_enable() doesn't cause priority inversion |
62 | */ | 65 | */ |
63 | extern unsigned long __mn10300_irq_enabled_epsw; | 66 | extern unsigned long __mn10300_irq_enabled_epsw[]; |
64 | 67 | ||
65 | static inline void arch_local_irq_enable(void) | 68 | static inline void arch_local_irq_enable(void) |
66 | { | 69 | { |
67 | unsigned long tmp; | 70 | unsigned long tmp; |
71 | int cpu = raw_smp_processor_id(); | ||
68 | 72 | ||
69 | asm volatile( | 73 | asm volatile( |
70 | " mov epsw,%0 \n" | 74 | " mov epsw,%0 \n" |
@@ -72,8 +76,8 @@ static inline void arch_local_irq_enable(void) | |||
72 | " or %2,%0 \n" | 76 | " or %2,%0 \n" |
73 | " mov %0,epsw \n" | 77 | " mov %0,epsw \n" |
74 | : "=&d"(tmp) | 78 | : "=&d"(tmp) |
75 | : "i"(~EPSW_IM), "r"(__mn10300_irq_enabled_epsw) | 79 | : "i"(~EPSW_IM), "r"(__mn10300_irq_enabled_epsw[cpu]) |
76 | : "memory"); | 80 | : "memory", "cc"); |
77 | } | 81 | } |
78 | 82 | ||
79 | static inline void arch_local_irq_restore(unsigned long flags) | 83 | static inline void arch_local_irq_restore(unsigned long flags) |
@@ -105,6 +109,9 @@ static inline bool arch_irqs_disabled(void) | |||
105 | */ | 109 | */ |
106 | static inline void arch_safe_halt(void) | 110 | static inline void arch_safe_halt(void) |
107 | { | 111 | { |
112 | #ifdef CONFIG_SMP | ||
113 | arch_local_irq_enable(); | ||
114 | #else | ||
108 | asm volatile( | 115 | asm volatile( |
109 | " or %0,epsw \n" | 116 | " or %0,epsw \n" |
110 | " nop \n" | 117 | " nop \n" |
@@ -113,8 +120,21 @@ static inline void arch_safe_halt(void) | |||
113 | : | 120 | : |
114 | : "i"(EPSW_IE|EPSW_IM), "n"(&CPUM), "i"(CPUM_SLEEP) | 121 | : "i"(EPSW_IE|EPSW_IM), "n"(&CPUM), "i"(CPUM_SLEEP) |
115 | : "cc"); | 122 | : "cc"); |
123 | #endif | ||
116 | } | 124 | } |
117 | 125 | ||
126 | #define __sleep_cpu() \ | ||
127 | do { \ | ||
128 | asm volatile( \ | ||
129 | " bset %1,(%0)\n" \ | ||
130 | "1: btst %1,(%0)\n" \ | ||
131 | " bne 1b\n" \ | ||
132 | : \ | ||
133 | : "i"(&CPUM), "i"(CPUM_SLEEP) \ | ||
134 | : "cc" \ | ||
135 | ); \ | ||
136 | } while (0) | ||
137 | |||
118 | static inline void arch_local_cli(void) | 138 | static inline void arch_local_cli(void) |
119 | { | 139 | { |
120 | asm volatile( | 140 | asm volatile( |