;; @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 | |
sub rsp, 0x28 | |
call ASM_PFX(FspApiCallingCheck) | |
add rsp, 0x28 | |
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 | |
cmp rax, 8 ; FspMultiPhaseMemInitApiIndex API | |
jz FspApiCommon3 | |
call ASM_PFX(AsmGetFspInfoHeader) | |
jmp ASM_PFX(Loader2PeiSwitchStack) | |
FspApiCommon3: | |
jmp ASM_PFX(FspApiCommonContinue) | |