mirror of
https://github.com/followmsi/android_kernel_google_msm.git
synced 2024-11-06 23:17:41 +00:00
MIPS: Octeon: Clean up SMP CPU numbering.
Also number offline CPUs that could potentially be brought on-line later. Signed-off-by: David Daney <ddaney@caviumnetworks.com> To: linux-mips@linux-mips.org Patchwork: https://patchwork.linux-mips.org/patch/1489/ Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
This commit is contained in:
parent
7d9eee6e52
commit
edfcbb8cac
1 changed files with 30 additions and 7 deletions
|
@ -3,7 +3,7 @@
|
||||||
* License. See the file "COPYING" in the main directory of this archive
|
* License. See the file "COPYING" in the main directory of this archive
|
||||||
* for more details.
|
* for more details.
|
||||||
*
|
*
|
||||||
* Copyright (C) 2004-2008 Cavium Networks
|
* Copyright (C) 2004-2008, 2009, 2010 Cavium Networks
|
||||||
*/
|
*/
|
||||||
#include <linux/cpu.h>
|
#include <linux/cpu.h>
|
||||||
#include <linux/init.h>
|
#include <linux/init.h>
|
||||||
|
@ -102,24 +102,47 @@ static void octeon_smp_setup(void)
|
||||||
const int coreid = cvmx_get_core_num();
|
const int coreid = cvmx_get_core_num();
|
||||||
int cpus;
|
int cpus;
|
||||||
int id;
|
int id;
|
||||||
|
|
||||||
int core_mask = octeon_get_boot_coremask();
|
int core_mask = octeon_get_boot_coremask();
|
||||||
|
#ifdef CONFIG_HOTPLUG_CPU
|
||||||
|
unsigned int num_cores = cvmx_octeon_num_cores();
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* The present CPUs are initially just the boot cpu (CPU 0). */
|
||||||
|
for (id = 0; id < NR_CPUS; id++) {
|
||||||
|
set_cpu_possible(id, id == 0);
|
||||||
|
set_cpu_present(id, id == 0);
|
||||||
|
}
|
||||||
|
|
||||||
cpus_clear(cpu_possible_map);
|
|
||||||
__cpu_number_map[coreid] = 0;
|
__cpu_number_map[coreid] = 0;
|
||||||
__cpu_logical_map[0] = coreid;
|
__cpu_logical_map[0] = coreid;
|
||||||
cpu_set(0, cpu_possible_map);
|
|
||||||
|
|
||||||
|
/* The present CPUs get the lowest CPU numbers. */
|
||||||
cpus = 1;
|
cpus = 1;
|
||||||
for (id = 0; id < 16; id++) {
|
for (id = 0; id < NR_CPUS; id++) {
|
||||||
if ((id != coreid) && (core_mask & (1 << id))) {
|
if ((id != coreid) && (core_mask & (1 << id))) {
|
||||||
cpu_set(cpus, cpu_possible_map);
|
set_cpu_possible(cpus, true);
|
||||||
|
set_cpu_present(cpus, true);
|
||||||
__cpu_number_map[id] = cpus;
|
__cpu_number_map[id] = cpus;
|
||||||
__cpu_logical_map[cpus] = id;
|
__cpu_logical_map[cpus] = id;
|
||||||
cpus++;
|
cpus++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
cpu_present_map = cpu_possible_map;
|
|
||||||
|
#ifdef CONFIG_HOTPLUG_CPU
|
||||||
|
/*
|
||||||
|
* The possible CPUs are all those present on the chip. We
|
||||||
|
* will assign CPU numbers for possible cores as well. Cores
|
||||||
|
* are always consecutively numberd from 0.
|
||||||
|
*/
|
||||||
|
for (id = 0; id < num_cores && id < NR_CPUS; id++) {
|
||||||
|
if (!(core_mask & (1 << id))) {
|
||||||
|
set_cpu_possible(cpus, true);
|
||||||
|
__cpu_number_map[id] = cpus;
|
||||||
|
__cpu_logical_map[cpus] = id;
|
||||||
|
cpus++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
octeon_smp_hotplug_setup();
|
octeon_smp_hotplug_setup();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue