mirror of https://github.com/acidanthera/audk.git
OvmfPkg: Copy Main.asm from UefiCpuPkg to OvmfPkg's ResetVector
RFC: https://bugzilla.tianocore.org/show_bug.cgi?id=3429 Previously OvmfPkg/ResetVector uses the Main.asm in UefiCpuPkg/ReseteVector/Vtf0. In this Main.asm there is only Main16 entry point. This patch-set is to introduce Intel TDX into Ovmf. Main32 entry point is needed in Main.asm by Intel TDX. To reduce the complexity of Main.asm in UefiCpuPkg, OvmfPkg create its own Main.asm to meet the requirement of Intel TDX. This Main.asm is an unmodified copy (so no functional change) and the actual changes for tdx come as incremental patches. UefiCpuPkg/ResetVector/Vtf0/main.asm -> OvmfPkg/ResetVector/Main.asm Cc: Ard Biesheuvel <ardb+tianocore@kernel.org> Cc: Jordan Justen <jordan.l.justen@intel.com> Cc: Gerd Hoffmann <kraxel@redhat.com> Cc: Brijesh Singh <brijesh.singh@amd.com> Cc: Erdem Aktas <erdemaktas@google.com> Cc: James Bottomley <jejb@linux.ibm.com> Cc: Jiewen Yao <jiewen.yao@intel.com> Cc: Tom Lendacky <thomas.lendacky@amd.com> Acked-by: Gerd Hoffmann <kraxel@redhat.com> Signed-off-by: Min Xu <min.m.xu@intel.com> Reviewed-by: Jiewen Yao <jiewen.yao@intel.com>
This commit is contained in:
parent
6254037223
commit
f079e9b450
|
@ -0,0 +1,103 @@
|
|||
;------------------------------------------------------------------------------
|
||||
; @file
|
||||
; Main routine of the pre-SEC code up through the jump into SEC
|
||||
;
|
||||
; Copyright (c) 2008 - 2009, Intel Corporation. All rights reserved.<BR>
|
||||
; SPDX-License-Identifier: BSD-2-Clause-Patent
|
||||
;
|
||||
;------------------------------------------------------------------------------
|
||||
|
||||
|
||||
BITS 16
|
||||
|
||||
;
|
||||
; Modified: EBX, ECX, EDX, EBP
|
||||
;
|
||||
; @param[in,out] RAX/EAX Initial value of the EAX register
|
||||
; (BIST: Built-in Self Test)
|
||||
; @param[in,out] DI 'BP': boot-strap processor, or
|
||||
; 'AP': application processor
|
||||
; @param[out] RBP/EBP Address of Boot Firmware Volume (BFV)
|
||||
; @param[out] DS Selector allowing flat access to all addresses
|
||||
; @param[out] ES Selector allowing flat access to all addresses
|
||||
; @param[out] FS Selector allowing flat access to all addresses
|
||||
; @param[out] GS Selector allowing flat access to all addresses
|
||||
; @param[out] SS Selector allowing flat access to all addresses
|
||||
;
|
||||
; @return None This routine jumps to SEC and does not return
|
||||
;
|
||||
Main16:
|
||||
OneTimeCall EarlyInit16
|
||||
|
||||
;
|
||||
; Transition the processor from 16-bit real mode to 32-bit flat mode
|
||||
;
|
||||
OneTimeCall TransitionFromReal16To32BitFlat
|
||||
|
||||
BITS 32
|
||||
|
||||
;
|
||||
; Search for the Boot Firmware Volume (BFV)
|
||||
;
|
||||
OneTimeCall Flat32SearchForBfvBase
|
||||
|
||||
;
|
||||
; EBP - Start of BFV
|
||||
;
|
||||
|
||||
;
|
||||
; Search for the SEC entry point
|
||||
;
|
||||
OneTimeCall Flat32SearchForSecEntryPoint
|
||||
|
||||
;
|
||||
; ESI - SEC Core entry point
|
||||
; EBP - Start of BFV
|
||||
;
|
||||
|
||||
%ifdef ARCH_IA32
|
||||
|
||||
;
|
||||
; Restore initial EAX value into the EAX register
|
||||
;
|
||||
mov eax, esp
|
||||
|
||||
;
|
||||
; Jump to the 32-bit SEC entry point
|
||||
;
|
||||
jmp esi
|
||||
|
||||
%else
|
||||
|
||||
;
|
||||
; Transition the processor from 32-bit flat mode to 64-bit flat mode
|
||||
;
|
||||
OneTimeCall Transition32FlatTo64Flat
|
||||
|
||||
BITS 64
|
||||
|
||||
;
|
||||
; Some values were calculated in 32-bit mode. Make sure the upper
|
||||
; 32-bits of 64-bit registers are zero for these values.
|
||||
;
|
||||
mov rax, 0x00000000ffffffff
|
||||
and rsi, rax
|
||||
and rbp, rax
|
||||
and rsp, rax
|
||||
|
||||
;
|
||||
; RSI - SEC Core entry point
|
||||
; RBP - Start of BFV
|
||||
;
|
||||
|
||||
;
|
||||
; Restore initial EAX value into the RAX register
|
||||
;
|
||||
mov rax, rsp
|
||||
|
||||
;
|
||||
; Jump to the 64-bit SEC entry point
|
||||
;
|
||||
jmp rsi
|
||||
|
||||
%endif
|
Loading…
Reference in New Issue