Commit 52128a7a authored by Thomas Gleixner's avatar Thomas Gleixner
Browse files

x86/cpu/topology: Make the APIC mismatch warnings complete



Detect all possible combinations of mismatch right in the CPUID evaluation
code.

Signed-off-by: default avatarThomas Gleixner <tglx@linutronix.de>
Tested-by: default avatarMichael Kelley <mhklinux@outlook.com>
Tested-by: default avatarSohil Mehta <sohil.mehta@intel.com>
Link: https://lore.kernel.org/r/20240212154638.867699078@linutronix.de

parent bcccdf8b
Loading
Loading
Loading
Loading
+2 −3
Original line number Diff line number Diff line
@@ -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,
+2 −13
Original line number Diff line number Diff line
@@ -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))
+12 −0
Original line number Diff line number Diff line
@@ -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;