x86, VisWS: turn into generic arch, update asm-x86/mach-visws/mach_apicdef.h
authorIngo Molnar <mingo@elte.hu>
Thu, 10 Jul 2008 13:12:05 +0000 (15:12 +0200)
committerIngo Molnar <mingo@elte.hu>
Thu, 10 Jul 2008 16:55:37 +0000 (18:55 +0200)
update asm-x86/mach-visws/mach_apicdef.h to the generic version.

This should work fine as VISWS has a standard local APIC and thus
its mach_apicdef.h copy is just an ancient version of the generic code.

Signed-off-by: Ingo Molnar <mingo@elte.hu>
include/asm-x86/mach-visws/mach_apicdef.h

index 826cfa97d778f1684b911012f3d5a8d053124901..e4b29ba37de604894bae11681a9236bd64c041e7 100644 (file)
@@ -1,12 +1,24 @@
 #ifndef __ASM_MACH_APICDEF_H
 #define __ASM_MACH_APICDEF_H
 
-#define         APIC_ID_MASK            (0xF<<24)
+#include <asm/apic.h>
 
-static inline unsigned get_apic_id(unsigned long x)
+#ifdef CONFIG_X86_64
+#define        APIC_ID_MASK            (0xFFu<<24)
+#define GET_APIC_ID(x)          (((x)>>24)&0xFFu)
+#define        SET_APIC_ID(x)          (((x)<<24))
+#else
+#define                APIC_ID_MASK            (0xF<<24)
+static inline unsigned get_apic_id(unsigned long x) 
 {
-               return (((x)>>24)&0xF);
-}
-#define         GET_APIC_ID(x)  get_apic_id(x)
+       unsigned int ver = GET_APIC_VERSION(apic_read(APIC_LVR));
+       if (APIC_XAPIC(ver))
+               return (((x)>>24)&0xFF);
+       else
+               return (((x)>>24)&0xF);
+} 
+
+#define                GET_APIC_ID(x)  get_apic_id(x)
+#endif
 
 #endif