]> git.ipfire.org Git - people/teissler/ipfire-2.x.git/blobdiff - src/patches/suse-2.6.27.31/patches.arch/x2APIC_PATCH_25_1_of_41_4c9961d56ec20c27ec5d02e49fd7427748312741
Imported linux-2.6.27.39 suse/xen patches.
[people/teissler/ipfire-2.x.git] / src / patches / suse-2.6.27.31 / patches.arch / x2APIC_PATCH_25_1_of_41_4c9961d56ec20c27ec5d02e49fd7427748312741
diff --git a/src/patches/suse-2.6.27.31/patches.arch/x2APIC_PATCH_25_1_of_41_4c9961d56ec20c27ec5d02e49fd7427748312741 b/src/patches/suse-2.6.27.31/patches.arch/x2APIC_PATCH_25_1_of_41_4c9961d56ec20c27ec5d02e49fd7427748312741
deleted file mode 100644 (file)
index bc6826c..0000000
+++ /dev/null
@@ -1,233 +0,0 @@
-From: Yinghai Lu <yhlu.kernel@gmail.com>
-Subject: x86: make read_apic_id return final apicid
-References: fate #303948 and fate #303984
-Patch-Mainline: queued for .28
-Commit-ID: 4c9961d56ec20c27ec5d02e49fd7427748312741
-
-Signed-off-by: Thomas Renninger <trenn@suse.de>
-
-also remove GET_APIC_ID when read_apic_id is used.
-
-need to apply after
-       [PATCH] x86: mach_apicdef.h need to include before smp.h
-
-Signed-off-by: Yinghai Lu <yhlu.kernel@gmail.com>
-Cc: Suresh Siddha <suresh.b.siddha@intel.com>
-Signed-off-by: Ingo Molnar <mingo@elte.hu>
-
----
- arch/x86/kernel/acpi/boot.c                 |    2 +-
- arch/x86/kernel/apic_32.c                   |    4 ++--
- arch/x86/kernel/apic_64.c                   |    6 +++---
- arch/x86/kernel/genapic_flat_64.c           |    2 +-
- arch/x86/kernel/io_apic_32.c                |    5 ++---
- arch/x86/kernel/io_apic_64.c                |    4 ++--
- arch/x86/kernel/smpboot.c                   |    6 +++---
- include/asm-x86/mach-default/mach_apic.h    |    2 +-
- include/asm-x86/mach-default/mach_apicdef.h |    3 +--
- include/asm-x86/mach-es7000/mach_apic.h     |    2 +-
- include/asm-x86/smp.h                       |   11 ++++++++---
- 11 files changed, 25 insertions(+), 22 deletions(-)
-
---- a/arch/x86/kernel/acpi/boot.c
-+++ b/arch/x86/kernel/acpi/boot.c
-@@ -775,7 +775,7 @@ static void __init acpi_register_lapic_a
-       set_fixmap_nocache(FIX_APIC_BASE, address);
-       if (boot_cpu_physical_apicid == -1U) {
--              boot_cpu_physical_apicid  = GET_APIC_ID(read_apic_id());
-+              boot_cpu_physical_apicid  = read_apic_id();
- #ifdef CONFIG_X86_32
-               apic_version[boot_cpu_physical_apicid] =
-                        GET_APIC_VERSION(apic_read(APIC_LVR));
---- a/arch/x86/kernel/apic_32.c
-+++ b/arch/x86/kernel/apic_32.c
-@@ -1211,7 +1211,7 @@ void __init init_apic_mappings(void)
-        * default configuration (or the MP table is broken).
-        */
-       if (boot_cpu_physical_apicid == -1U)
--              boot_cpu_physical_apicid = GET_APIC_ID(read_apic_id());
-+              boot_cpu_physical_apicid = read_apic_id();
- }
-@@ -1248,7 +1248,7 @@ int __init APIC_init_uniprocessor(void)
-        * might be zero if read from MP tables. Get it from LAPIC.
-        */
- #ifdef CONFIG_CRASH_DUMP
--      boot_cpu_physical_apicid = GET_APIC_ID(read_apic_id());
-+      boot_cpu_physical_apicid = read_apic_id();
- #endif
-       physid_set_mask_of_physid(boot_cpu_physical_apicid, &phys_cpu_present_map);
---- a/arch/x86/kernel/apic_64.c
-+++ b/arch/x86/kernel/apic_64.c
-@@ -1062,7 +1062,7 @@ void __init early_init_lapic_mapping(voi
-        * Fetch the APIC ID of the BSP in case we have a
-        * default configuration (or the MP table is broken).
-        */
--      boot_cpu_physical_apicid = GET_APIC_ID(read_apic_id());
-+      boot_cpu_physical_apicid = read_apic_id();
- }
- /**
-@@ -1071,7 +1071,7 @@ void __init early_init_lapic_mapping(voi
- void __init init_apic_mappings(void)
- {
-       if (x2apic) {
--              boot_cpu_physical_apicid = GET_APIC_ID(read_apic_id());
-+              boot_cpu_physical_apicid = read_apic_id();
-               return;
-       }
-@@ -1094,7 +1094,7 @@ void __init init_apic_mappings(void)
-        * Fetch the APIC ID of the BSP in case we have a
-        * default configuration (or the MP table is broken).
-        */
--      boot_cpu_physical_apicid = GET_APIC_ID(read_apic_id());
-+      boot_cpu_physical_apicid = read_apic_id();
- }
- /*
---- a/arch/x86/kernel/genapic_flat_64.c
-+++ b/arch/x86/kernel/genapic_flat_64.c
-@@ -101,7 +101,7 @@ static unsigned int read_xapic_id(void)
- {
-       unsigned int id;
--      id = GET_XAPIC_ID(apic_read(APIC_ID));
-+      id = GET_APIC_ID(apic_read(APIC_ID));
-       return id;
- }
---- a/arch/x86/kernel/io_apic_32.c
-+++ b/arch/x86/kernel/io_apic_32.c
-@@ -1490,7 +1490,7 @@ void /*__init*/ print_local_APIC(void *d
-               smp_processor_id(), hard_smp_processor_id());
-       v = apic_read(APIC_ID);
-       printk(KERN_INFO "... APIC ID:      %08x (%01x)\n", v,
--                      GET_APIC_ID(read_apic_id()));
-+                      GET_APIC_ID(v));
-       v = apic_read(APIC_LVR);
-       printk(KERN_INFO "... APIC VERSION: %08x\n", v);
-       ver = GET_APIC_VERSION(v);
-@@ -1698,8 +1698,7 @@ void disable_IO_APIC(void)
-               entry.dest_mode       = 0; /* Physical */
-               entry.delivery_mode   = dest_ExtINT; /* ExtInt */
-               entry.vector          = 0;
--              entry.dest.physical.physical_dest =
--                                      GET_APIC_ID(read_apic_id());
-+              entry.dest.physical.physical_dest = read_apic_id();
-               /*
-                * Add it to the IO-APIC irq-routing table:
---- a/arch/x86/kernel/io_apic_64.c
-+++ b/arch/x86/kernel/io_apic_64.c
-@@ -1245,7 +1245,7 @@ void __apicdebuginit print_local_APIC(vo
-       printk("\n" KERN_DEBUG "printing local APIC contents on CPU#%d/%d:\n",
-               smp_processor_id(), hard_smp_processor_id());
-       v = apic_read(APIC_ID);
--      printk(KERN_INFO "... APIC ID:      %08x (%01x)\n", v, GET_APIC_ID(read_apic_id()));
-+      printk(KERN_INFO "... APIC ID:      %08x (%01x)\n", v, read_apic_id());
-       v = apic_read(APIC_LVR);
-       printk(KERN_INFO "... APIC VERSION: %08x\n", v);
-       ver = GET_APIC_VERSION(v);
-@@ -1438,7 +1438,7 @@ void disable_IO_APIC(void)
-               entry.dest_mode       = 0; /* Physical */
-               entry.delivery_mode   = dest_ExtINT; /* ExtInt */
-               entry.vector          = 0;
--              entry.dest          = GET_APIC_ID(read_apic_id());
-+              entry.dest            = read_apic_id();
-               /*
-                * Add it to the IO-APIC irq-routing table:
---- a/arch/x86/kernel/smpboot.c
-+++ b/arch/x86/kernel/smpboot.c
-@@ -211,7 +211,7 @@ static void __cpuinit smp_callin(void)
-       /*
-        * (This works even if the APIC is not enabled.)
-        */
--      phys_id = GET_APIC_ID(read_apic_id());
-+      phys_id = read_apic_id();
-       cpuid = smp_processor_id();
-       if (cpu_isset(cpuid, cpu_callin_map)) {
-               panic("%s: phys CPU#%d, CPU#%d already present??\n", __func__,
-@@ -1181,9 +1181,9 @@ void __init native_smp_prepare_cpus(unsi
-       }
-       preempt_disable();
--      if (GET_APIC_ID(read_apic_id()) != boot_cpu_physical_apicid) {
-+      if (read_apic_id() != boot_cpu_physical_apicid) {
-               panic("Boot APIC ID in local APIC unexpected (%d vs %d)",
--                   GET_APIC_ID(read_apic_id()), boot_cpu_physical_apicid);
-+                   read_apic_id(), boot_cpu_physical_apicid);
-               /* Or can we switch back to PIC here? */
-       }
-       preempt_enable();
---- a/include/asm-x86/mach-default/mach_apicdef.h
-+++ b/include/asm-x86/mach-default/mach_apicdef.h
-@@ -5,9 +5,8 @@
- #ifdef CONFIG_X86_64
- #define       APIC_ID_MASK            (0xFFu<<24)
--#define GET_APIC_ID(x)          (x)
-+#define GET_APIC_ID(x)                (((x)>>24) & 0xFFu)
- #define       SET_APIC_ID(x)          (((x)<<24))
--#define GET_XAPIC_ID(x)               (((x) >> 24) & 0xFFu)
- #else
- #define               APIC_ID_MASK            (0xF<<24)
- static inline unsigned get_apic_id(unsigned long x) 
---- a/include/asm-x86/mach-default/mach_apic.h
-+++ b/include/asm-x86/mach-default/mach_apic.h
-@@ -56,7 +56,7 @@ static inline void init_apic_ldr(void)
- static inline int apic_id_registered(void)
- {
--      return physid_isset(GET_APIC_ID(read_apic_id()), phys_cpu_present_map);
-+      return physid_isset(read_apic_id(), phys_cpu_present_map);
- }
- static inline unsigned int cpu_mask_to_apicid(cpumask_t cpumask)
---- a/include/asm-x86/mach-es7000/mach_apic.h
-+++ b/include/asm-x86/mach-es7000/mach_apic.h
-@@ -141,7 +141,7 @@ static inline void setup_portio_remap(vo
- extern unsigned int boot_cpu_physical_apicid;
- static inline int check_phys_apicid_present(int cpu_physical_apicid)
- {
--      boot_cpu_physical_apicid = GET_APIC_ID(read_apic_id());
-+      boot_cpu_physical_apicid = read_apic_id();
-       return (1);
- }
---- a/include/asm-x86/smp.h
-+++ b/include/asm-x86/smp.h
-@@ -172,9 +172,14 @@ static inline int logical_smp_processor_
-       return GET_APIC_LOGICAL_ID(*(u32 *)(APIC_BASE + APIC_LDR));
- }
-+#include <mach_apicdef.h>
- static inline unsigned int read_apic_id(void)
- {
--      return *(u32 *)(APIC_BASE + APIC_ID);
-+      unsigned int reg;
-+
-+      reg = *(u32 *)(APIC_BASE + APIC_ID);
-+
-+      return GET_APIC_ID(reg);
- }
- #endif
-@@ -182,11 +187,11 @@ static inline unsigned int read_apic_id(
- # if defined(APIC_DEFINITION) || defined(CONFIG_X86_64)
- extern int hard_smp_processor_id(void);
- # else
--#  include <mach_apicdef.h>
-+#include <mach_apicdef.h>
- static inline int hard_smp_processor_id(void)
- {
-       /* we don't want to mark this access volatile - bad code generation */
--      return GET_APIC_ID(read_apic_id());
-+      return read_apic_id();
- }
- # endif /* APIC_DEFINITION */