IntelFsp2Pkg: FspSecCore support for X64
REF:https://bugzilla.tianocore.org/show_bug.cgi?id=3893 1.Added FspSecCore support for X64. 2.Bumped FSP header revision to 7 to indicate FSP 64bit is supported. 3.Corrected few typos. Cc: Chasel Chiu <chasel.chiu@intel.com> Cc: Nate DeSimone <nathaniel.l.desimone@intel.com> Cc: Star Zeng <star.zeng@intel.com> Cc: Ashraf Ali S <ashraf.ali.s@intel.com> Signed-off-by: Ted Kuo <ted.kuo@intel.com> Reviewed-by: Chasel Chiu <chasel.chiu@intel.com> Reviewed-by: Nate DeSimone <nathaniel.l.desimone@intel.com>
This commit is contained in:
76
IntelFsp2Pkg/FspSecCore/X64/FspApiEntryCommon.nasm
Normal file
76
IntelFsp2Pkg/FspSecCore/X64/FspApiEntryCommon.nasm
Normal file
@@ -0,0 +1,76 @@
|
||||
;; @file
|
||||
; Provide FSP API entry points.
|
||||
;
|
||||
; Copyright (c) 2022, Intel Corporation. All rights reserved.<BR>
|
||||
; SPDX-License-Identifier: BSD-2-Clause-Patent
|
||||
;;
|
||||
|
||||
SECTION .text
|
||||
|
||||
%include "PushPopRegsNasm.inc"
|
||||
|
||||
STACK_SAVED_RAX_OFFSET EQU 8 * 7 ; size of a general purpose register * rax index
|
||||
|
||||
;
|
||||
; Following functions will be provided in C
|
||||
;
|
||||
extern ASM_PFX(Loader2PeiSwitchStack)
|
||||
extern ASM_PFX(FspApiCallingCheck)
|
||||
|
||||
;
|
||||
; Following functions will be provided in ASM
|
||||
;
|
||||
extern ASM_PFX(FspApiCommonContinue)
|
||||
extern ASM_PFX(AsmGetFspInfoHeader)
|
||||
|
||||
;----------------------------------------------------------------------------
|
||||
; FspApiCommon API
|
||||
;
|
||||
; This is the FSP API common entry point to resume the FSP execution
|
||||
;
|
||||
;----------------------------------------------------------------------------
|
||||
global ASM_PFX(FspApiCommon)
|
||||
ASM_PFX(FspApiCommon):
|
||||
;
|
||||
; RAX holds the API index
|
||||
;
|
||||
|
||||
;
|
||||
; Stack must be ready
|
||||
;
|
||||
push rax
|
||||
add rsp, 8
|
||||
cmp rax, [rsp - 8]
|
||||
jz FspApiCommon1
|
||||
mov rax, 08000000000000003h
|
||||
jmp exit
|
||||
|
||||
FspApiCommon1:
|
||||
;
|
||||
; Verify the calling condition
|
||||
;
|
||||
PUSHA_64
|
||||
mov rdx, rcx ; move ApiParam to rdx
|
||||
mov rcx, rax ; move ApiIdx to rcx
|
||||
call ASM_PFX(FspApiCallingCheck)
|
||||
cmp rax, 0
|
||||
jz FspApiCommon2
|
||||
mov [rsp + STACK_SAVED_RAX_OFFSET], rax
|
||||
POPA_64
|
||||
exit:
|
||||
ret
|
||||
|
||||
FspApiCommon2:
|
||||
POPA_64
|
||||
cmp rax, 3 ; FspMemoryInit API
|
||||
jz FspApiCommon3
|
||||
|
||||
cmp rax, 6 ; FspMultiPhaseSiInitApiIndex API
|
||||
jz FspApiCommon3
|
||||
|
||||
call ASM_PFX(AsmGetFspInfoHeader)
|
||||
jmp ASM_PFX(Loader2PeiSwitchStack)
|
||||
|
||||
FspApiCommon3:
|
||||
jmp ASM_PFX(FspApiCommonContinue)
|
||||
|
Reference in New Issue
Block a user