public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* [RFC -tip] x86,apic - set cpu_has_apic for discrete apic
@ 2009-07-11 21:29 Cyrill Gorcunov
  2009-07-12  0:41 ` Maciej W. Rozycki
  0 siblings, 1 reply; 5+ messages in thread
From: Cyrill Gorcunov @ 2009-07-11 21:29 UTC (permalink / raw)
  To: Ingo Molnar, Maciej W. Rozycki
  Cc: H. Peter Anvin, Thomas Gleixner, Yinghai Lu, LKML

In case of discrete apic (due to hardware or firmware reason)
cpuid may not retrieve cpu_has_apic bit. So for SMP
compiled kernels instead of long check we may set "fake"
cpu_has_apic bit and check only the bit in further code
flow.

Signed-off-by: Cyrill Gorcunov <gorcunov@openvz.org>
---

Please review carefully.

 arch/x86/kernel/apic/apic.c |   14 ++++++++++++++
 1 file changed, 14 insertions(+)

Index: linux-2.6.git/arch/x86/kernel/apic/apic.c
=====================================================================
--- linux-2.6.git.orig/arch/x86/kernel/apic/apic.c
+++ linux-2.6.git/arch/x86/kernel/apic/apic.c
@@ -1003,6 +1003,20 @@ int __init verify_local_APIC(void)
 	unsigned int reg0, reg1;
 
 	/*
+	 * For discrete APIC case cpu_has_apic bit could not
+	 * be retrieved via cpuid instruction. Same time
+	 * we rely on this bit (mostly for SMP compiled
+	 * kernel) and instead of checking the long condition
+	 * below all the time we do check for plain cpu_has_apic.
+	 *
+	 * At this moment all the checks are passed and we've
+	 * already complained if there was a BIOS bug. This place
+	 * should be safe for such a trick. --cvg
+	 */
+	if (smp_found_config && !cpu_has_apic && !disable_apic)
+		set_cpu_cap(&boot_cpu_data, X86_FEATURE_APIC);
+
+	/*
 	 * The version register is read-only in a real APIC.
 	 */
 	reg0 = apic_read(APIC_LVR);

^ permalink raw reply	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2009-07-12  6:34 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2009-07-11 21:29 [RFC -tip] x86,apic - set cpu_has_apic for discrete apic Cyrill Gorcunov
2009-07-12  0:41 ` Maciej W. Rozycki
2009-07-12  5:52   ` Cyrill Gorcunov
2009-07-12  6:31     ` Maciej W. Rozycki
2009-07-12  6:34       ` Cyrill Gorcunov

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox