x86/cpu/topology: Make the APIC mismatch warnings complete
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
This commit is contained in:
parent
bcccdf8b30
commit
52128a7a21
@ -46,16 +46,15 @@ extern void x86_32_probe_apic(void);
|
|||||||
static inline void x86_32_probe_apic(void) { }
|
static inline void x86_32_probe_apic(void) { }
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef CONFIG_X86_LOCAL_APIC
|
extern u32 cpuid_to_apicid[];
|
||||||
|
|
||||||
|
#ifdef CONFIG_X86_LOCAL_APIC
|
||||||
extern int apic_verbosity;
|
extern int apic_verbosity;
|
||||||
extern int local_apic_timer_c2_ok;
|
extern int local_apic_timer_c2_ok;
|
||||||
|
|
||||||
extern bool apic_is_disabled;
|
extern bool apic_is_disabled;
|
||||||
extern unsigned int lapic_timer_period;
|
extern unsigned int lapic_timer_period;
|
||||||
|
|
||||||
extern u32 cpuid_to_apicid[];
|
|
||||||
|
|
||||||
extern enum apic_intr_mode_id apic_intr_mode;
|
extern enum apic_intr_mode_id apic_intr_mode;
|
||||||
enum apic_intr_mode_id {
|
enum apic_intr_mode_id {
|
||||||
APIC_PIC,
|
APIC_PIC,
|
||||||
|
@ -1716,22 +1716,11 @@ static void generic_identify(struct cpuinfo_x86 *c)
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
static void update_package_map(struct cpuinfo_x86 *c)
|
||||||
* 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)
|
|
||||||
{
|
{
|
||||||
#ifdef CONFIG_SMP
|
#ifdef CONFIG_SMP
|
||||||
unsigned int cpu = smp_processor_id();
|
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_package_map(c->topo.pkg_id, cpu));
|
||||||
BUG_ON(topology_update_die_map(c->topo.die_id, cpu));
|
BUG_ON(topology_update_die_map(c->topo.die_id, cpu));
|
||||||
#else
|
#else
|
||||||
@ -1923,7 +1912,7 @@ void identify_secondary_cpu(struct cpuinfo_x86 *c)
|
|||||||
#ifdef CONFIG_X86_32
|
#ifdef CONFIG_X86_32
|
||||||
enable_sep_cpu();
|
enable_sep_cpu();
|
||||||
#endif
|
#endif
|
||||||
validate_apic_and_package_id(c);
|
update_package_map(c);
|
||||||
x86_spec_ctrl_setup_ap();
|
x86_spec_ctrl_setup_ap();
|
||||||
update_srbds_msr();
|
update_srbds_msr();
|
||||||
if (boot_cpu_has_bug(X86_BUG_GDS))
|
if (boot_cpu_has_bug(X86_BUG_GDS))
|
||||||
|
@ -177,6 +177,18 @@ void cpu_parse_topology(struct cpuinfo_x86 *c)
|
|||||||
|
|
||||||
parse_topology(&tscan, false);
|
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++) {
|
for (dom = TOPO_SMT_DOMAIN; dom < TOPO_MAX_DOMAIN; dom++) {
|
||||||
if (tscan.dom_shifts[dom] == x86_topo_system.dom_shifts[dom])
|
if (tscan.dom_shifts[dom] == x86_topo_system.dom_shifts[dom])
|
||||||
continue;
|
continue;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user