提交 e1a14d0c 编写于 作者: G Glauber de Oliveira Costa 提交者: Ingo Molnar

x86: get rid of cpucount

weighting a map will do.
Signed-off-by: NGlauber Costa <gcosta@redhat.com>
Signed-off-by: NIngo Molnar <mingo@elte.hu>
上级 1161705b
...@@ -166,8 +166,6 @@ static void __cpuinit smp_callin(void) ...@@ -166,8 +166,6 @@ static void __cpuinit smp_callin(void)
cpu_set(cpuid, cpu_callin_map); cpu_set(cpuid, cpu_callin_map);
} }
static int cpucount;
/* /*
* Activate a secondary processor. * Activate a secondary processor.
*/ */
...@@ -585,7 +583,6 @@ static int __cpuinit do_boot_cpu(int apicid, int cpu) ...@@ -585,7 +583,6 @@ static int __cpuinit do_boot_cpu(int apicid, int cpu)
/* start_eip had better be page-aligned! */ /* start_eip had better be page-aligned! */
start_eip = setup_trampoline(); start_eip = setup_trampoline();
++cpucount;
alternatives_smp_switch(1); alternatives_smp_switch(1);
/* So we see what's up */ /* So we see what's up */
...@@ -656,7 +653,6 @@ static int __cpuinit do_boot_cpu(int apicid, int cpu) ...@@ -656,7 +653,6 @@ static int __cpuinit do_boot_cpu(int apicid, int cpu)
cpu_clear(cpu, cpu_initialized); /* was set by cpu_init() */ cpu_clear(cpu, cpu_initialized); /* was set by cpu_init() */
cpu_clear(cpu, cpu_possible_map); cpu_clear(cpu, cpu_possible_map);
per_cpu(x86_cpu_to_apicid, cpu) = BAD_APICID; per_cpu(x86_cpu_to_apicid, cpu) = BAD_APICID;
cpucount--;
} }
/* mark "stuck" area as not stuck */ /* mark "stuck" area as not stuck */
...@@ -672,7 +668,6 @@ void cpu_exit_clear(void) ...@@ -672,7 +668,6 @@ void cpu_exit_clear(void)
idle_task_exit(); idle_task_exit();
cpucount --;
cpu_uninit(); cpu_uninit();
irq_ctx_exit(cpu); irq_ctx_exit(cpu);
...@@ -795,7 +790,6 @@ static int __init smp_sanity_check(unsigned max_cpus) ...@@ -795,7 +790,6 @@ static int __init smp_sanity_check(unsigned max_cpus)
return 0; return 0;
} }
/* /*
* Cycle through the processors sending APIC IPIs to boot each. * Cycle through the processors sending APIC IPIs to boot each.
*/ */
...@@ -851,7 +845,7 @@ static void __init smp_boot_cpus(unsigned int max_cpus) ...@@ -851,7 +845,7 @@ static void __init smp_boot_cpus(unsigned int max_cpus)
if (!check_apicid_present(bit)) if (!check_apicid_present(bit))
continue; continue;
if (max_cpus <= cpucount+1) if (max_cpus <= cpus_weight(cpu_present_map))
continue; continue;
/* Utterly temporary */ /* Utterly temporary */
for (cpu = 0; cpu < NR_CPUS; cpu++) for (cpu = 0; cpu < NR_CPUS; cpu++)
...@@ -878,7 +872,7 @@ static void __init smp_boot_cpus(unsigned int max_cpus) ...@@ -878,7 +872,7 @@ static void __init smp_boot_cpus(unsigned int max_cpus)
bogosum += cpu_data(cpu).loops_per_jiffy; bogosum += cpu_data(cpu).loops_per_jiffy;
printk(KERN_INFO printk(KERN_INFO
"Total of %d processors activated (%lu.%02lu BogoMIPS).\n", "Total of %d processors activated (%lu.%02lu BogoMIPS).\n",
cpucount+1, cpus_weight(cpu_present_map),
bogosum/(500000/HZ), bogosum/(500000/HZ),
(bogosum/(5000/HZ))%100); (bogosum/(5000/HZ))%100);
...@@ -892,7 +886,7 @@ static void __init smp_boot_cpus(unsigned int max_cpus) ...@@ -892,7 +886,7 @@ static void __init smp_boot_cpus(unsigned int max_cpus)
* approved Athlon * approved Athlon
*/ */
if (tainted & TAINT_UNSAFE_SMP) { if (tainted & TAINT_UNSAFE_SMP) {
if (cpucount) if (cpus_weight(cpu_present_map))
printk (KERN_INFO "WARNING: This combination of AMD processors is not suitable for SMP.\n"); printk (KERN_INFO "WARNING: This combination of AMD processors is not suitable for SMP.\n");
else else
tainted &= ~TAINT_UNSAFE_SMP; tainted &= ~TAINT_UNSAFE_SMP;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册