Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 88812
b: refs/heads/master
c: e1a14d0
h: refs/heads/master
v: v3
  • Loading branch information
Glauber de Oliveira Costa authored and Ingo Molnar committed Apr 17, 2008
1 parent 9c48970 commit ec9e0c0
Show file tree
Hide file tree
Showing 2 changed files with 4 additions and 10 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 1161705bd66df0c80fa45e87190e456c02e6f145
refs/heads/master: e1a14d0c1391627d869c0f97bb5e2382bf36d8dc
12 changes: 3 additions & 9 deletions trunk/arch/x86/kernel/smpboot_32.c
Original file line number Diff line number Diff line change
Expand Up @@ -166,8 +166,6 @@ static void __cpuinit smp_callin(void)
cpu_set(cpuid, cpu_callin_map);
}

static int cpucount;

/*
* Activate a secondary processor.
*/
Expand Down Expand Up @@ -585,7 +583,6 @@ static int __cpuinit do_boot_cpu(int apicid, int cpu)
/* start_eip had better be page-aligned! */
start_eip = setup_trampoline();

++cpucount;
alternatives_smp_switch(1);

/* So we see what's up */
Expand Down Expand Up @@ -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_possible_map);
per_cpu(x86_cpu_to_apicid, cpu) = BAD_APICID;
cpucount--;
}

/* mark "stuck" area as not stuck */
Expand All @@ -672,7 +668,6 @@ void cpu_exit_clear(void)

idle_task_exit();

cpucount --;
cpu_uninit();
irq_ctx_exit(cpu);

Expand Down Expand Up @@ -795,7 +790,6 @@ static int __init smp_sanity_check(unsigned max_cpus)
return 0;
}


/*
* Cycle through the processors sending APIC IPIs to boot each.
*/
Expand Down Expand Up @@ -851,7 +845,7 @@ static void __init smp_boot_cpus(unsigned int max_cpus)

if (!check_apicid_present(bit))
continue;
if (max_cpus <= cpucount+1)
if (max_cpus <= cpus_weight(cpu_present_map))
continue;
/* Utterly temporary */
for (cpu = 0; cpu < NR_CPUS; cpu++)
Expand All @@ -878,7 +872,7 @@ static void __init smp_boot_cpus(unsigned int max_cpus)
bogosum += cpu_data(cpu).loops_per_jiffy;
printk(KERN_INFO
"Total of %d processors activated (%lu.%02lu BogoMIPS).\n",
cpucount+1,
cpus_weight(cpu_present_map),
bogosum/(500000/HZ),
(bogosum/(5000/HZ))%100);

Expand All @@ -892,7 +886,7 @@ static void __init smp_boot_cpus(unsigned int max_cpus)
* approved Athlon
*/
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");
else
tainted &= ~TAINT_UNSAFE_SMP;
Expand Down

0 comments on commit ec9e0c0

Please sign in to comment.