aboutsummaryrefslogtreecommitdiffstats
path: root/arch/arm/mach-vexpress
diff options
context:
space:
mode:
authorRussell King <rmk+kernel@arm.linux.org.uk>2010-12-03 06:09:48 -0500
committerRussell King <rmk+kernel@arm.linux.org.uk>2010-12-20 10:09:08 -0500
commit05c74a6cbcfb416286a947668ba32f63d99fe74a (patch)
tree96f4dd3d5cbc67b14b93e9630f4f02becaa1a66a /arch/arm/mach-vexpress
parentaec66ba1f75c2030cf66f5a21d1c81aa83aa5d95 (diff)
ARM: SMP: consolidate the common parts of smp_prepare_cpus()
There is a certain amount of smp_prepare_cpus() which doesn't belong in the platform support code - that is, code which is invariant to the SMP implementation. Move this code into arch/arm/kernel/smp.c, and add a platform_ prefix to the original function. Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
Diffstat (limited to 'arch/arm/mach-vexpress')
-rw-r--r--arch/arm/mach-vexpress/platsmp.c43
1 files changed, 10 insertions, 33 deletions
diff --git a/arch/arm/mach-vexpress/platsmp.c b/arch/arm/mach-vexpress/platsmp.c
index b5a758683668..a0341d14ff2a 100644
--- a/arch/arm/mach-vexpress/platsmp.c
+++ b/arch/arm/mach-vexpress/platsmp.c
@@ -17,7 +17,6 @@
17#include <linux/io.h> 17#include <linux/io.h>
18 18
19#include <asm/cacheflush.h> 19#include <asm/cacheflush.h>
20#include <asm/localtimer.h>
21#include <asm/smp_scu.h> 20#include <asm/smp_scu.h>
22#include <asm/unified.h> 21#include <asm/unified.h>
23 22
@@ -136,20 +135,10 @@ void __init smp_init_cpus(void)
136 set_cpu_possible(i, true); 135 set_cpu_possible(i, true);
137} 136}
138 137
139void __init smp_prepare_cpus(unsigned int max_cpus) 138void __init platform_smp_prepare_cpus(unsigned int max_cpus)
140{ 139{
141 unsigned int ncores = num_possible_cpus();
142 unsigned int cpu = smp_processor_id();
143 int i; 140 int i;
144 141
145 smp_store_cpu_info(cpu);
146
147 /*
148 * are we trying to boot more cores than exist?
149 */
150 if (max_cpus > ncores)
151 max_cpus = ncores;
152
153 /* 142 /*
154 * Initialise the present map, which describes the set of CPUs 143 * Initialise the present map, which describes the set of CPUs
155 * actually populated at the present time. 144 * actually populated at the present time.
@@ -157,27 +146,15 @@ void __init smp_prepare_cpus(unsigned int max_cpus)
157 for (i = 0; i < max_cpus; i++) 146 for (i = 0; i < max_cpus; i++)
158 set_cpu_present(i, true); 147 set_cpu_present(i, true);
159 148
149 scu_enable(scu_base_addr());
150
160 /* 151 /*
161 * Initialise the SCU if there are more than one CPU and let 152 * Write the address of secondary startup into the
162 * them know where to start. 153 * system-wide flags register. The boot monitor waits
154 * until it receives a soft interrupt, and then the
155 * secondary CPU branches to this address.
163 */ 156 */
164 if (max_cpus > 1) { 157 writel(~0, MMIO_P2V(V2M_SYS_FLAGSCLR));
165 /* 158 writel(BSYM(virt_to_phys(vexpress_secondary_startup)),
166 * Enable the local timer or broadcast device for the 159 MMIO_P2V(V2M_SYS_FLAGSSET));
167 * boot CPU, but only if we have more than one CPU.
168 */
169 percpu_timer_setup();
170
171 scu_enable(scu_base_addr());
172
173 /*
174 * Write the address of secondary startup into the
175 * system-wide flags register. The boot monitor waits
176 * until it receives a soft interrupt, and then the
177 * secondary CPU branches to this address.
178 */
179 writel(~0, MMIO_P2V(V2M_SYS_FLAGSCLR));
180 writel(BSYM(virt_to_phys(vexpress_secondary_startup)),
181 MMIO_P2V(V2M_SYS_FLAGSSET));
182 }
183} 160}