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)) |
