summaryrefslogtreecommitdiff
path: root/src/cpu/x86/sipi_vector.S
diff options
context:
space:
mode:
authorArthur Heymans <arthur@aheymans.xyz>2024-02-02 17:37:42 +0100
committerFelix Held <felix-coreboot@felixheld.de>2024-02-28 12:12:59 +0000
commit3cfcffe49c720bd5152d3a26ec744adbc4f12477 (patch)
tree3b454ac7b4c48097bcd4c82dbe70822a2dfe7970 /src/cpu/x86/sipi_vector.S
parentf45fcd1cf3ff801816ea5462a0f0f3208a585c3a (diff)
cpu/x86/(sipi|smm): Pass on CR3 from ramstage
To allow for more flexibility like generating page tables at runtime or page tables that are part of the ramstage, add a parameter to sipi_vector.S and smm_stub.S so that APs use the same page tables as the BSP during their initialization. Signed-off-by: Arthur Heymans <arthur@aheymans.xyz> Change-Id: I1250ea6f63c65228178ee66e06d988dadfcc2a37 Reviewed-on: https://review.coreboot.org/c/coreboot/+/80335 Reviewed-by: Patrick Rudolph <patrick.rudolph@9elements.com> Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Jérémy Compostella <jeremy.compostella@intel.com>
Diffstat (limited to 'src/cpu/x86/sipi_vector.S')
-rw-r--r--src/cpu/x86/sipi_vector.S4
1 files changed, 3 insertions, 1 deletions
diff --git a/src/cpu/x86/sipi_vector.S b/src/cpu/x86/sipi_vector.S
index 923e3987d0..b7d700fb39 100644
--- a/src/cpu/x86/sipi_vector.S
+++ b/src/cpu/x86/sipi_vector.S
@@ -38,6 +38,8 @@ msr_count:
.long 0
c_handler:
.long 0
+cr3:
+.long 0
ap_count:
.long 0
@@ -224,7 +226,7 @@ load_msr:
#if ENV_X86_64
/* entry64.inc preserves ebx, esi, edi, ebp */
- setup_longmode $(CONFIG_ARCH_X86_64_PGTBL_LOC)
+ setup_longmode cr3
movabs c_handler, %eax
call *%rax