Commit de6aec24 authored by Thomas Gleixner's avatar Thomas Gleixner

x86/mm/numa: Move early mptable evaluation into common code

There is no reason to have the early mptable evaluation conditionally
invoked only from the AMD numa topology code.

Make it explicit and invoke it from setup_arch() right after the
corresponding ACPI init call. Remove the pointless wrapper and invoke
x86_init::mpparse::early_parse_smp_config() directly.
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/20240212154639.931761608@linutronix.de

parent dcb76008
...@@ -46,11 +46,6 @@ extern int smp_found_config; ...@@ -46,11 +46,6 @@ extern int smp_found_config;
# define smp_found_config 0 # define smp_found_config 0
#endif #endif
static inline void early_get_smp_config(void)
{
x86_init.mpparse.early_parse_smp_cfg();
}
#ifdef CONFIG_X86_MPPARSE #ifdef CONFIG_X86_MPPARSE
extern void e820__memblock_alloc_reserved_mpc_new(void); extern void e820__memblock_alloc_reserved_mpc_new(void);
extern int enable_update_mptable; extern int enable_update_mptable;
......
...@@ -1088,7 +1088,9 @@ void __init setup_arch(char **cmdline_p) ...@@ -1088,7 +1088,9 @@ void __init setup_arch(char **cmdline_p)
early_platform_quirks(); early_platform_quirks();
/* Some platforms need the APIC registered for NUMA configuration */
early_acpi_boot_init(); early_acpi_boot_init();
x86_init.mpparse.early_parse_smp_cfg();
x86_flattree_get_config(); x86_flattree_get_config();
......
...@@ -161,13 +161,6 @@ int __init amd_numa_init(void) ...@@ -161,13 +161,6 @@ int __init amd_numa_init(void)
*/ */
cores = topology_get_domain_size(TOPO_CORE_DOMAIN); cores = topology_get_domain_size(TOPO_CORE_DOMAIN);
/*
* Scan MPTABLE to map the local APIC and ensure that the boot CPU
* APIC ID is valid. This is required because on pre ACPI/SRAT
* systems IO-APICs are mapped before the boot CPU.
*/
early_get_smp_config();
apicid = boot_cpu_physical_apicid; apicid = boot_cpu_physical_apicid;
if (apicid > 0) if (apicid > 0)
pr_info("BSP APIC ID: %02x\n", apicid); pr_info("BSP APIC ID: %02x\n", apicid);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment