|
@@ -1346,25 +1346,9 @@ static void __ref remove_cpu_from_maps(int cpu)
|
|
|
numa_remove_cpu(cpu);
|
|
|
}
|
|
|
|
|
|
-int native_cpu_disable(void)
|
|
|
+void cpu_disable_common(void)
|
|
|
{
|
|
|
int cpu = smp_processor_id();
|
|
|
-
|
|
|
- /*
|
|
|
- * Perhaps use cpufreq to drop frequency, but that could go
|
|
|
- * into generic code.
|
|
|
- *
|
|
|
- * We won't take down the boot processor on i386 due to some
|
|
|
- * interrupts only being able to be serviced by the BSP.
|
|
|
- * Especially so if we're not using an IOAPIC -zwane
|
|
|
- */
|
|
|
- if (cpu == 0)
|
|
|
- return -EBUSY;
|
|
|
-
|
|
|
- if (nmi_watchdog == NMI_LOCAL_APIC)
|
|
|
- stop_apic_nmi_watchdog(NULL);
|
|
|
- clear_local_APIC();
|
|
|
-
|
|
|
/*
|
|
|
* HACK:
|
|
|
* Allow any queued timer interrupts to get serviced
|
|
@@ -1382,6 +1366,28 @@ int native_cpu_disable(void)
|
|
|
remove_cpu_from_maps(cpu);
|
|
|
unlock_vector_lock();
|
|
|
fixup_irqs(cpu_online_map);
|
|
|
+}
|
|
|
+
|
|
|
+int native_cpu_disable(void)
|
|
|
+{
|
|
|
+ int cpu = smp_processor_id();
|
|
|
+
|
|
|
+ /*
|
|
|
+ * Perhaps use cpufreq to drop frequency, but that could go
|
|
|
+ * into generic code.
|
|
|
+ *
|
|
|
+ * We won't take down the boot processor on i386 due to some
|
|
|
+ * interrupts only being able to be serviced by the BSP.
|
|
|
+ * Especially so if we're not using an IOAPIC -zwane
|
|
|
+ */
|
|
|
+ if (cpu == 0)
|
|
|
+ return -EBUSY;
|
|
|
+
|
|
|
+ if (nmi_watchdog == NMI_LOCAL_APIC)
|
|
|
+ stop_apic_nmi_watchdog(NULL);
|
|
|
+ clear_local_APIC();
|
|
|
+
|
|
|
+ cpu_disable_common();
|
|
|
return 0;
|
|
|
}
|
|
|
|