On Mon, Jan 28, 2013 at 2:11 AM, Ingo Molnar <mi...@kernel.org> wrote: > >> HP has systems that work with x2apic phys mode and BIOS set >> ACPI_FADT_APIC_PHYSICAL in FADT table, and all cpuid < 255, >> the spec requires BIOS only put system on xapic mode. Kernel > > Which spec? > >> will set to x2apic logical mode instead of x2apic phys mode. > > Which has exactly what bad effect on users of these systems? > > You left out the most important information from the changelog: > why do users care, what good does the patch do?
please check you are happy with this: --- From: Stoney Wang <song-bo.w...@hp.com> Subject: [PATCH] x86, apic: Check fadt x2apic phys in x2apic_phys_probe() HP has systems that only work with x2apic phys mode and BIOS set ACPI_FADT_APIC_PHYSICAL in FADT table. But all apicid < 255, according to x2apic-spec, chapter 2.9, BIOS need to pass the control to the OS with xapic mode. Kernel will set apic driver wrong to x2apic cluster instead of x2apic phys. The user will have to append nox2apic in boot command line to stay xapic mode, or append x2apic_phys to switch to x2apic phys mode. That is kernel bug about handling fadt phys bit. Current code handle x2apic as: 1. When BIOS set x2apic mode: When user specify x2apic_phys, or FADT indicates PHYSICAL. During madt oem check, apic driver is set correctly to x2apic phys driver. 2. When BIOS does NOT set x2apic mode: When user specify x2apic_phys, or FADT indicates PHYSICAL. During madt oem check, apic driver is set with xapic logical or xapic phys driver at first. Later enable_IR_x2apic() will enable x2apic_mode. After that, x2apic_phys_probe() will install right x2apic phys driver when user specify x2apic_phys, but will skip and let x2apic_cluster_probe to take over to install wrong apic driver (x2apic cluster) when FADT indicates PHYSICAL, because x2apic_phys_probe does not check FADT PHYSICAL. Fix that by adding check x2apic_fadt_phys in x2apic_phys_probe(). [ changelog, and simplify code - Yinghai Lu ] Signed-off-by: Stoney Wang <song-bo.w...@hp.com> Signed-off-by: Yinghai Lu <ying...@kernel.org> --- -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/