diff options
-rw-r--r-- | arch/ia64/include/asm/acpi.h | 5 | ||||
-rw-r--r-- | arch/x86/include/asm/acpi.h | 5 | ||||
-rw-r--r-- | drivers/acpi/acpi_processor.c | 2 |
3 files changed, 11 insertions, 1 deletions
diff --git a/arch/ia64/include/asm/acpi.h b/arch/ia64/include/asm/acpi.h index 75dc59a793d6..a1d91ab4c5ef 100644 --- a/arch/ia64/include/asm/acpi.h +++ b/arch/ia64/include/asm/acpi.h | |||
@@ -40,6 +40,11 @@ extern int acpi_lapic; | |||
40 | #define acpi_noirq 0 /* ACPI always enabled on IA64 */ | 40 | #define acpi_noirq 0 /* ACPI always enabled on IA64 */ |
41 | #define acpi_pci_disabled 0 /* ACPI PCI always enabled on IA64 */ | 41 | #define acpi_pci_disabled 0 /* ACPI PCI always enabled on IA64 */ |
42 | #define acpi_strict 1 /* no ACPI spec workarounds on IA64 */ | 42 | #define acpi_strict 1 /* no ACPI spec workarounds on IA64 */ |
43 | |||
44 | static inline bool acpi_has_cpu_in_madt(void) | ||
45 | { | ||
46 | return !!acpi_lapic; | ||
47 | } | ||
43 | #endif | 48 | #endif |
44 | #define acpi_processor_cstate_check(x) (x) /* no idle limits on IA64 :) */ | 49 | #define acpi_processor_cstate_check(x) (x) /* no idle limits on IA64 :) */ |
45 | static inline void disable_acpi(void) { } | 50 | static inline void disable_acpi(void) { } |
diff --git a/arch/x86/include/asm/acpi.h b/arch/x86/include/asm/acpi.h index e06225eda635..0ab4f9fd2687 100644 --- a/arch/x86/include/asm/acpi.h +++ b/arch/x86/include/asm/acpi.h | |||
@@ -121,6 +121,11 @@ static inline void arch_acpi_set_pdc_bits(u32 *buf) | |||
121 | buf[2] &= ~(ACPI_PDC_C_C2C3_FFH); | 121 | buf[2] &= ~(ACPI_PDC_C_C2C3_FFH); |
122 | } | 122 | } |
123 | 123 | ||
124 | static inline bool acpi_has_cpu_in_madt(void) | ||
125 | { | ||
126 | return !!acpi_lapic; | ||
127 | } | ||
128 | |||
124 | #else /* !CONFIG_ACPI */ | 129 | #else /* !CONFIG_ACPI */ |
125 | 130 | ||
126 | #define acpi_lapic 0 | 131 | #define acpi_lapic 0 |
diff --git a/drivers/acpi/acpi_processor.c b/drivers/acpi/acpi_processor.c index 1c085742644f..1fdf5e07a1c7 100644 --- a/drivers/acpi/acpi_processor.c +++ b/drivers/acpi/acpi_processor.c | |||
@@ -268,7 +268,7 @@ static int acpi_processor_get_info(struct acpi_device *device) | |||
268 | pr->apic_id = apic_id; | 268 | pr->apic_id = apic_id; |
269 | 269 | ||
270 | cpu_index = acpi_map_cpuid(pr->apic_id, pr->acpi_id); | 270 | cpu_index = acpi_map_cpuid(pr->apic_id, pr->acpi_id); |
271 | if (!cpu0_initialized && !acpi_lapic) { | 271 | if (!cpu0_initialized && !acpi_has_cpu_in_madt()) { |
272 | cpu0_initialized = 1; | 272 | cpu0_initialized = 1; |
273 | /* Handle UP system running SMP kernel, with no LAPIC in MADT */ | 273 | /* Handle UP system running SMP kernel, with no LAPIC in MADT */ |
274 | if ((cpu_index == -1) && (num_online_cpus() == 1)) | 274 | if ((cpu_index == -1) && (num_online_cpus() == 1)) |