x86/cpu/topology: Make the APIC mismatch warnings complete
authorThomas Gleixner <tglx@linutronix.de>
Tue, 13 Feb 2024 21:04:52 +0000 (22:04 +0100)
committerThomas Gleixner <tglx@linutronix.de>
Thu, 15 Feb 2024 21:07:39 +0000 (22:07 +0100)
Detect all possible combinations of mismatch right in the CPUID evaluation
code.

Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Tested-by: Michael Kelley <mhklinux@outlook.com>
Tested-by: Sohil Mehta <sohil.mehta@intel.com>
Link: https://lore.kernel.org/r/20240212154638.867699078@linutronix.de
arch/x86/include/asm/apic.h
arch/x86/kernel/cpu/common.c
arch/x86/kernel/cpu/topology_common.c

index 80d6383b825dac7e3bf09e63c73366ef3532bf64..6c5cffceaa1432e882dce4fc4759d73541105a79 100644 (file)
@@ -46,16 +46,15 @@ extern void x86_32_probe_apic(void);
 static inline void x86_32_probe_apic(void) { }
 #endif
 
-#ifdef CONFIG_X86_LOCAL_APIC
+extern u32 cpuid_to_apicid[];
 
+#ifdef CONFIG_X86_LOCAL_APIC
 extern int apic_verbosity;
 extern int local_apic_timer_c2_ok;
 
 extern bool apic_is_disabled;
 extern unsigned int lapic_timer_period;
 
-extern u32 cpuid_to_apicid[];
-
 extern enum apic_intr_mode_id apic_intr_mode;
 enum apic_intr_mode_id {
        APIC_PIC,
index 33064e661a2df171b088a273fe25e1a46fbe8176..b221e144c9fcae83facbcdca72dfe561ee523c89 100644 (file)
@@ -1716,22 +1716,11 @@ static void generic_identify(struct cpuinfo_x86 *c)
 #endif
 }
 
-/*
- * Validate that ACPI/mptables have the same information about the
- * effective APIC id and update the package map.
- */
-static void validate_apic_and_package_id(struct cpuinfo_x86 *c)
+static void update_package_map(struct cpuinfo_x86 *c)
 {
 #ifdef CONFIG_SMP
        unsigned int cpu = smp_processor_id();
-       u32 apicid;
 
-       apicid = apic->cpu_present_to_apicid(cpu);
-
-       if (apicid != c->topo.apicid) {
-               pr_err(FW_BUG "CPU%u: APIC id mismatch. Firmware: %x APIC: %x\n",
-                      cpu, apicid, c->topo.initial_apicid);
-       }
        BUG_ON(topology_update_package_map(c->topo.pkg_id, cpu));
        BUG_ON(topology_update_die_map(c->topo.die_id, cpu));
 #else
@@ -1923,7 +1912,7 @@ void identify_secondary_cpu(struct cpuinfo_x86 *c)
 #ifdef CONFIG_X86_32
        enable_sep_cpu();
 #endif
-       validate_apic_and_package_id(c);
+       update_package_map(c);
        x86_spec_ctrl_setup_ap();
        update_srbds_msr();
        if (boot_cpu_has_bug(X86_BUG_GDS))
index afea34d59598f1b858a139557fd4d742cef4d339..3876a3342fe9639413f885fc8b8b7595bccc8e55 100644 (file)
@@ -177,6 +177,18 @@ void cpu_parse_topology(struct cpuinfo_x86 *c)
 
        parse_topology(&tscan, false);
 
+       if (IS_ENABLED(CONFIG_X86_LOCAL_APIC)) {
+               if (c->topo.initial_apicid != c->topo.apicid) {
+                       pr_err(FW_BUG "CPU%4u: APIC ID mismatch. CPUID: 0x%04x APIC: 0x%04x\n",
+                              cpu, c->topo.initial_apicid, c->topo.apicid);
+               }
+
+               if (c->topo.apicid != cpuid_to_apicid[cpu]) {
+                       pr_err(FW_BUG "CPU%4u: APIC ID mismatch. Firmware: 0x%04x APIC: 0x%04x\n",
+                              cpu, cpuid_to_apicid[cpu], c->topo.apicid);
+               }
+       }
+
        for (dom = TOPO_SMT_DOMAIN; dom < TOPO_MAX_DOMAIN; dom++) {
                if (tscan.dom_shifts[dom] == x86_topo_system.dom_shifts[dom])
                        continue;