|
@@ -12,40 +12,6 @@
|
|
|
#include <acpi/processor.h>
|
|
|
#include <asm/acpi.h>
|
|
|
|
|
|
-static void init_intel_pdc(struct acpi_processor *pr, struct cpuinfo_x86 *c)
|
|
|
-{
|
|
|
- u32 *buf = (u32 *)pr->pdc->pointer->buffer.pointer;
|
|
|
-
|
|
|
- buf[2] |= ACPI_PDC_C_CAPABILITY_SMP;
|
|
|
-
|
|
|
- if (cpu_has(c, X86_FEATURE_EST))
|
|
|
- buf[2] |= ACPI_PDC_EST_CAPABILITY_SWSMP;
|
|
|
-
|
|
|
- if (cpu_has(c, X86_FEATURE_ACPI))
|
|
|
- buf[2] |= ACPI_PDC_T_FFH;
|
|
|
-
|
|
|
- /*
|
|
|
- * If mwait/monitor is unsupported, C2/C3_FFH will be disabled
|
|
|
- */
|
|
|
- if (!cpu_has(c, X86_FEATURE_MWAIT))
|
|
|
- buf[2] &= ~(ACPI_PDC_C_C2C3_FFH);
|
|
|
-
|
|
|
- return;
|
|
|
-}
|
|
|
-
|
|
|
-
|
|
|
-/* Initialize _PDC data based on the CPU vendor */
|
|
|
-void arch_acpi_processor_init_pdc(struct acpi_processor *pr)
|
|
|
-{
|
|
|
- struct cpuinfo_x86 *c = &cpu_data(pr->id);
|
|
|
-
|
|
|
- init_intel_pdc(pr, c);
|
|
|
-
|
|
|
- return;
|
|
|
-}
|
|
|
-
|
|
|
-EXPORT_SYMBOL(arch_acpi_processor_init_pdc);
|
|
|
-
|
|
|
void arch_acpi_processor_cleanup_pdc(struct acpi_processor *pr)
|
|
|
{
|
|
|
if (pr->pdc) {
|