提交 105765f4 编写于 作者: B Benjamin Herrenschmidt

powerpc/smp: Don't expose per-cpu "cpu_state" array

Instead, keep it static, expose an accessor and use that from
the PowerMac code. Avoids easy namespace collisions and will
make it easier to consolidate with other implementations.
Signed-off-by: NBenjamin Herrenschmidt <benh@kernel.crashing.org>
上级 734796f1
...@@ -45,7 +45,7 @@ extern void migrate_irqs(void); ...@@ -45,7 +45,7 @@ extern void migrate_irqs(void);
int generic_cpu_disable(void); int generic_cpu_disable(void);
void generic_cpu_die(unsigned int cpu); void generic_cpu_die(unsigned int cpu);
void generic_mach_cpu_die(void); void generic_mach_cpu_die(void);
DECLARE_PER_CPU(int, cpu_state); void generic_set_cpu_dead(unsigned int cpu);
#endif #endif
#ifdef CONFIG_PPC64 #ifdef CONFIG_PPC64
......
...@@ -305,7 +305,7 @@ void __devinit smp_prepare_boot_cpu(void) ...@@ -305,7 +305,7 @@ void __devinit smp_prepare_boot_cpu(void)
#ifdef CONFIG_HOTPLUG_CPU #ifdef CONFIG_HOTPLUG_CPU
/* State of each CPU during hotplug phases */ /* State of each CPU during hotplug phases */
DEFINE_PER_CPU(int, cpu_state) = { 0 }; static DEFINE_PER_CPU(int, cpu_state) = { 0 };
int generic_cpu_disable(void) int generic_cpu_disable(void)
{ {
...@@ -348,6 +348,11 @@ void generic_mach_cpu_die(void) ...@@ -348,6 +348,11 @@ void generic_mach_cpu_die(void)
while (__get_cpu_var(cpu_state) != CPU_UP_PREPARE) while (__get_cpu_var(cpu_state) != CPU_UP_PREPARE)
cpu_relax(); cpu_relax();
} }
void generic_set_cpu_dead(unsigned int cpu)
{
per_cpu(cpu_state, cpu) = CPU_DEAD;
}
#endif #endif
int __cpuinit __cpu_up(unsigned int cpu) int __cpuinit __cpu_up(unsigned int cpu)
......
...@@ -920,10 +920,12 @@ static int smp_core99_cpu_disable(void) ...@@ -920,10 +920,12 @@ static int smp_core99_cpu_disable(void)
static void pmac_cpu_die(void) static void pmac_cpu_die(void)
{ {
int cpu = smp_processor_id();
local_irq_disable(); local_irq_disable();
idle_task_exit(); idle_task_exit();
printk(KERN_DEBUG "CPU%d offline\n", smp_processor_id()); pr_debug("CPU%d offline\n", cpu);
__get_cpu_var(cpu_state) = CPU_DEAD; generic_set_cpu_dead(cpu);
smp_wmb(); smp_wmb();
mb(); mb();
low_cpu_die(); low_cpu_die();
...@@ -933,6 +935,8 @@ static void pmac_cpu_die(void) ...@@ -933,6 +935,8 @@ static void pmac_cpu_die(void)
static void pmac_cpu_die(void) static void pmac_cpu_die(void)
{ {
int cpu = smp_processor_id();
local_irq_disable(); local_irq_disable();
idle_task_exit(); idle_task_exit();
...@@ -942,8 +946,8 @@ static void pmac_cpu_die(void) ...@@ -942,8 +946,8 @@ static void pmac_cpu_die(void)
* on core99 platforms for now ... * on core99 platforms for now ...
*/ */
printk(KERN_INFO "CPU#%d offline\n", smp_processor_id()); printk(KERN_INFO "CPU#%d offline\n", cpu);
__get_cpu_var(cpu_state) = CPU_DEAD; generic_set_cpu_dead(cpu);
smp_wmb(); smp_wmb();
/* /*
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册