aboutsummaryrefslogtreecommitdiffstats
path: root/arch/arm/kernel
diff options
context:
space:
mode:
authorLorenzo Pieralisi <lorenzo.pieralisi@arm.com>2012-11-08 13:05:56 -0500
committerLorenzo Pieralisi <lorenzo.pieralisi@arm.com>2012-11-19 10:44:33 -0500
commitcb8cf4f821044f140ea5b9c8d4f816f0c05fab44 (patch)
tree11868c21279511f8ce1536e52c42e952342304c5 /arch/arm/kernel
parent71db5bfec1349afcbfbd71268c01c658c357b4f3 (diff)
ARM: kernel: smp_setup_processor_id() updates
This patch applies some basic changes to the smp_setup_processor_id() ARM implementation to make the code that builds cpu_logical_map more uniform across the kernel. The function now prints the full extent of the boot CPU MPIDR[23:0] and initializes the cpu_logical_map for CPUs up to nr_cpu_ids. Signed-off-by: Lorenzo Pieralisi <lorenzo.pieralisi@arm.com> Acked-by: Nicolas Pitre <nico@linaro.org> Acked-by: Will Deacon <will.deacon@arm.com>
Diffstat (limited to 'arch/arm/kernel')
-rw-r--r--arch/arm/kernel/setup.c7
1 files changed, 4 insertions, 3 deletions
diff --git a/arch/arm/kernel/setup.c b/arch/arm/kernel/setup.c
index da1d1aa20ad9..4515bf6abee0 100644
--- a/arch/arm/kernel/setup.c
+++ b/arch/arm/kernel/setup.c
@@ -426,13 +426,14 @@ int __cpu_logical_map[NR_CPUS];
426void __init smp_setup_processor_id(void) 426void __init smp_setup_processor_id(void)
427{ 427{
428 int i; 428 int i;
429 u32 cpu = is_smp() ? read_cpuid_mpidr() & 0xff : 0; 429 u32 mpidr = is_smp() ? read_cpuid_mpidr() & MPIDR_HWID_BITMASK : 0;
430 u32 cpu = MPIDR_AFFINITY_LEVEL(mpidr, 0);
430 431
431 cpu_logical_map(0) = cpu; 432 cpu_logical_map(0) = cpu;
432 for (i = 1; i < NR_CPUS; ++i) 433 for (i = 1; i < nr_cpu_ids; ++i)
433 cpu_logical_map(i) = i == cpu ? 0 : i; 434 cpu_logical_map(i) = i == cpu ? 0 : i;
434 435
435 printk(KERN_INFO "Booting Linux on physical CPU %d\n", cpu); 436 printk(KERN_INFO "Booting Linux on physical CPU 0x%x\n", mpidr);
436} 437}
437 438
438static void __init setup_processor(void) 439static void __init setup_processor(void)