diff options
Diffstat (limited to 'arch/x86/kernel/acpi/boot.c')
| -rw-r--r-- | arch/x86/kernel/acpi/boot.c | 40 | 
1 files changed, 14 insertions, 26 deletions
| diff --git a/arch/x86/kernel/acpi/boot.c b/arch/x86/kernel/acpi/boot.c index 90d84c3eee53..931ced8ca345 100644 --- a/arch/x86/kernel/acpi/boot.c +++ b/arch/x86/kernel/acpi/boot.c @@ -176,15 +176,10 @@ static int acpi_register_lapic(int id, u32 acpiid, u8 enabled)  		return -EINVAL;  	} -	if (!enabled) { -		++disabled_cpus; -		return -EINVAL; -	} -  	if (boot_cpu_physical_apicid != -1U) -		ver = apic_version[boot_cpu_physical_apicid]; +		ver = boot_cpu_apic_version; -	cpu = generic_processor_info(id, ver); +	cpu = __generic_processor_info(id, ver, enabled);  	if (cpu >= 0)  		early_per_cpu(x86_cpu_to_acpiid, cpu) = acpiid; @@ -238,6 +233,10 @@ acpi_parse_lapic(struct acpi_subtable_header * header, const unsigned long end)  	acpi_table_print_madt_entry(header); +	/* Ignore invalid ID */ +	if (processor->id == 0xff) +		return 0; +  	/*  	 * We need to register disabled CPU as well to permit  	 * counting disabled CPUs. This allows us to size @@ -282,6 +281,8 @@ acpi_parse_lapic_addr_ovr(struct acpi_subtable_header * header,  	if (BAD_MADT_ENTRY(lapic_addr_ovr, end))  		return -EINVAL; +	acpi_table_print_madt_entry(header); +  	acpi_lapic_addr = lapic_addr_ovr->address;  	return 0; @@ -453,6 +454,7 @@ static void __init acpi_sci_ioapic_setup(u8 bus_irq, u16 polarity, u16 trigger,  		polarity = acpi_sci_flags & ACPI_MADT_POLARITY_MASK;  	mp_override_legacy_irq(bus_irq, polarity, trigger, gsi); +	acpi_penalize_sci_irq(bus_irq, trigger, polarity);  	/*  	 * stash over-ride to indicate we've been here @@ -705,7 +707,7 @@ static void __init acpi_set_irq_model_ioapic(void)  #ifdef CONFIG_ACPI_HOTPLUG_CPU  #include <acpi/processor.h> -static void acpi_map_cpu2node(acpi_handle handle, int cpu, int physid) +int acpi_map_cpu2node(acpi_handle handle, int cpu, int physid)  {  #ifdef CONFIG_ACPI_NUMA  	int nid; @@ -716,6 +718,7 @@ static void acpi_map_cpu2node(acpi_handle handle, int cpu, int physid)  		numa_set_node(cpu, nid);  	}  #endif +	return 0;  }  int acpi_map_cpu(acpi_handle handle, phys_cpuid_t physid, int *pcpu) @@ -998,21 +1001,6 @@ static int __init acpi_parse_madt_lapic_entries(void)  	if (!boot_cpu_has(X86_FEATURE_APIC))  		return -ENODEV; -	/* -	 * Note that the LAPIC address is obtained from the MADT (32-bit value) -	 * and (optionally) overridden by a LAPIC_ADDR_OVR entry (64-bit value). -	 */ - -	count = acpi_table_parse_madt(ACPI_MADT_TYPE_LOCAL_APIC_OVERRIDE, -				      acpi_parse_lapic_addr_ovr, 0); -	if (count < 0) { -		printk(KERN_ERR PREFIX -		       "Error parsing LAPIC address override entry\n"); -		return count; -	} - -	register_lapic_address(acpi_lapic_addr); -  	count = acpi_table_parse_madt(ACPI_MADT_TYPE_LOCAL_SAPIC,  				      acpi_parse_sapic, MAX_LOCAL_APIC); @@ -1031,8 +1019,8 @@ static int __init acpi_parse_madt_lapic_entries(void)  			return ret;  		} -		x2count = madt_proc[0].count; -		count = madt_proc[1].count; +		count = madt_proc[0].count; +		x2count = madt_proc[1].count;  	}  	if (!count && !x2count) {  		printk(KERN_ERR PREFIX "No LAPIC entries present\n"); @@ -1513,7 +1501,7 @@ void __init acpi_boot_table_init(void)  	 * If acpi_disabled, bail out  	 */  	if (acpi_disabled) -		return;  +		return;  	/*  	 * Initialize the ACPI boot-time table parser. |