mirror of https://github.com/acidanthera/audk.git
IntelFsp2Pkg: Improvement of supporting null UPD pointer in FSP-T
REF:https://bugzilla.tianocore.org/show_bug.cgi?id=4114 1.Use xmm5 slot 1 and xmm6 slot 3 to save ucode status and UPD pointer respectively in TempRamInitApi in IA32 FspSecCoreT. 2.Correct inappropriate description in the return value of AsmGetFspInfoHeader. 3.Replace hardcoded offset value 0x1C with FSP_HEADER_IMGBASE_OFFSET in FspHeler.nasm. 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> Cc: Chinni B Duggapu <chinni.b.duggapu@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:
parent
c8fb724046
commit
3182843f3b
|
@ -594,37 +594,38 @@ ASM_PFX(TempRamInitApi):
|
||||||
SAVE_EAX
|
SAVE_EAX
|
||||||
SAVE_EDX
|
SAVE_EDX
|
||||||
|
|
||||||
|
CALL_EBP ASM_PFX(LoadUpdPointerToECX) ; ECX for UPD param
|
||||||
|
SAVE_ECX ; save UPD param to slot 3 in xmm6
|
||||||
|
|
||||||
;
|
;
|
||||||
; Sec Platform Init
|
; Sec Platform Init
|
||||||
;
|
;
|
||||||
CALL_EBP ASM_PFX(LoadUpdPointerToECX) ; ECX for UPD param
|
|
||||||
CALL_MMX ASM_PFX(SecPlatformInit)
|
CALL_MMX ASM_PFX(SecPlatformInit)
|
||||||
cmp eax, 0
|
cmp eax, 0
|
||||||
jnz TempRamInitExit
|
jnz TempRamInitExit
|
||||||
|
|
||||||
; Load microcode
|
; Load microcode
|
||||||
LOAD_ESP
|
LOAD_ESP
|
||||||
CALL_EBP ASM_PFX(LoadUpdPointerToECX) ; ECX for UPD param
|
LOAD_ECX
|
||||||
CALL_MMX ASM_PFX(LoadMicrocodeDefault)
|
CALL_MMX ASM_PFX(LoadMicrocodeDefault)
|
||||||
SXMMN xmm6, 3, eax ;Save microcode return status in ECX-SLOT 3 in xmm6.
|
SAVE_UCODE_STATUS ; Save microcode return status in slot 1 in xmm5.
|
||||||
;@note If return value eax is not 0, microcode did not load, but continue and attempt to boot.
|
;@note If return value eax is not 0, microcode did not load, but continue and attempt to boot.
|
||||||
|
|
||||||
; Call Sec CAR Init
|
; Call Sec CAR Init
|
||||||
LOAD_ESP
|
LOAD_ESP
|
||||||
CALL_EBP ASM_PFX(LoadUpdPointerToECX) ; ECX for UPD param
|
LOAD_ECX
|
||||||
CALL_MMX ASM_PFX(SecCarInit)
|
CALL_MMX ASM_PFX(SecCarInit)
|
||||||
cmp eax, 0
|
cmp eax, 0
|
||||||
jnz TempRamInitExit
|
jnz TempRamInitExit
|
||||||
|
|
||||||
LOAD_ESP
|
LOAD_ESP
|
||||||
CALL_EBP ASM_PFX(LoadUpdPointerToECX) ; ECX for UPD param
|
LOAD_ECX
|
||||||
mov edi, ecx ; Save UPD param to EDI for later code use
|
mov edi, ecx ; Save UPD param to EDI for later code use
|
||||||
CALL_MMX ASM_PFX(EstablishStackFsp)
|
CALL_MMX ASM_PFX(EstablishStackFsp)
|
||||||
cmp eax, 0
|
cmp eax, 0
|
||||||
jnz TempRamInitExit
|
jnz TempRamInitExit
|
||||||
|
|
||||||
LXMMN xmm6, eax, 3 ;Restore microcode status if no CAR init error from ECX-SLOT 3 in xmm6.
|
LOAD_UCODE_STATUS ; Restore microcode status if no CAR init error from slot 1 in xmm5.
|
||||||
SXMMN xmm6, 3, edi ;Save FSP-T UPD parameter pointer in ECX-SLOT 3 in xmm6.
|
|
||||||
|
|
||||||
TempRamInitExit:
|
TempRamInitExit:
|
||||||
mov bl, al ; save al data in bl
|
mov bl, al ; save al data in bl
|
||||||
|
|
|
@ -7,6 +7,8 @@
|
||||||
|
|
||||||
SECTION .text
|
SECTION .text
|
||||||
|
|
||||||
|
FSP_HEADER_IMGBASE_OFFSET EQU 1Ch
|
||||||
|
|
||||||
global ASM_PFX(FspInfoHeaderRelativeOff)
|
global ASM_PFX(FspInfoHeaderRelativeOff)
|
||||||
ASM_PFX(FspInfoHeaderRelativeOff):
|
ASM_PFX(FspInfoHeaderRelativeOff):
|
||||||
DD 0x12345678 ; This value must be patched by the build script
|
DD 0x12345678 ; This value must be patched by the build script
|
||||||
|
@ -14,7 +16,7 @@ ASM_PFX(FspInfoHeaderRelativeOff):
|
||||||
global ASM_PFX(AsmGetFspBaseAddress)
|
global ASM_PFX(AsmGetFspBaseAddress)
|
||||||
ASM_PFX(AsmGetFspBaseAddress):
|
ASM_PFX(AsmGetFspBaseAddress):
|
||||||
call ASM_PFX(AsmGetFspInfoHeader)
|
call ASM_PFX(AsmGetFspInfoHeader)
|
||||||
add eax, 0x1C
|
add eax, FSP_HEADER_IMGBASE_OFFSET
|
||||||
mov eax, dword [eax]
|
mov eax, dword [eax]
|
||||||
ret
|
ret
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
||||||
;
|
;
|
||||||
; Copyright (c) 2015 - 2019, Intel Corporation. All rights reserved.<BR>
|
; Copyright (c) 2015 - 2022, Intel Corporation. All rights reserved.<BR>
|
||||||
; SPDX-License-Identifier: BSD-2-Clause-Patent
|
; SPDX-License-Identifier: BSD-2-Clause-Patent
|
||||||
;
|
;
|
||||||
; Abstract:
|
; Abstract:
|
||||||
|
@ -16,21 +16,21 @@
|
||||||
;
|
;
|
||||||
; Define SSE macros using SSE 4.1 instructions
|
; Define SSE macros using SSE 4.1 instructions
|
||||||
; args 1:XMM, 2:IDX, 3:REG
|
; args 1:XMM, 2:IDX, 3:REG
|
||||||
%macro SXMMN 3
|
%macro SXMMN 3
|
||||||
pinsrd %1, %3, (%2 & 3)
|
pinsrd %1, %3, (%2 & 3)
|
||||||
%endmacro
|
%endmacro
|
||||||
|
|
||||||
;
|
;
|
||||||
;args 1:XMM, 2:REG, 3:IDX
|
;args 1:XMM, 2:REG, 3:IDX
|
||||||
;
|
;
|
||||||
%macro LXMMN 3
|
%macro LXMMN 3
|
||||||
pextrd %2, %1, (%3 & 3)
|
pextrd %2, %1, (%3 & 3)
|
||||||
%endmacro
|
%endmacro
|
||||||
%else
|
%else
|
||||||
;
|
;
|
||||||
; Define SSE macros using SSE 2 instructions
|
; Define SSE macros using SSE 2 instructions
|
||||||
; args 1:XMM, 2:IDX, 3:REG
|
; args 1:XMM, 2:IDX, 3:REG
|
||||||
%macro SXMMN 3
|
%macro SXMMN 3
|
||||||
pinsrw %1, %3, (%2 & 3) * 2
|
pinsrw %1, %3, (%2 & 3) * 2
|
||||||
ror %3, 16
|
ror %3, 16
|
||||||
pinsrw %1, %3, (%2 & 3) * 2 + 1
|
pinsrw %1, %3, (%2 & 3) * 2 + 1
|
||||||
|
@ -38,19 +38,19 @@
|
||||||
%endmacro
|
%endmacro
|
||||||
|
|
||||||
;
|
;
|
||||||
;args 1:XMM, 2:REG, 3:IDX
|
;args 1:XMM, 2:REG, 3:IDX
|
||||||
;
|
;
|
||||||
%macro LXMMN 3
|
%macro LXMMN 3
|
||||||
pshufd %1, %1, ((0E4E4E4h >> (%3 * 2)) & 0FFh)
|
pshufd %1, %1, ((0E4E4E4h >> (%3 * 2)) & 0FFh)
|
||||||
movd %2, %1
|
movd %2, %1
|
||||||
pshufd %1, %1, ((0E4E4E4h >> (%3 * 2 + (%3 & 1) * 4)) & 0FFh)
|
pshufd %1, %1, ((0E4E4E4h >> (%3 * 2 + (%3 & 1) * 4)) & 0FFh)
|
||||||
%endmacro
|
%endmacro
|
||||||
%endif
|
%endif
|
||||||
|
|
||||||
;
|
;
|
||||||
; XMM7 to save/restore EBP, EBX, ESI, EDI
|
; XMM7 to save/restore EBP - slot 0, EBX - slot 1, ESI - slot 2, EDI - slot 3
|
||||||
;
|
;
|
||||||
%macro SAVE_REGS 0
|
%macro SAVE_REGS 0
|
||||||
SXMMN xmm7, 0, ebp
|
SXMMN xmm7, 0, ebp
|
||||||
SXMMN xmm7, 1, ebx
|
SXMMN xmm7, 1, ebx
|
||||||
SXMMN xmm7, 2, esi
|
SXMMN xmm7, 2, esi
|
||||||
|
@ -67,63 +67,67 @@
|
||||||
%endmacro
|
%endmacro
|
||||||
|
|
||||||
;
|
;
|
||||||
; XMM6 to save/restore EAX, EDX, ECX, ESP
|
; XMM6 to save/restore ESP - slot 0, EAX - slot 1, EDX - slot 2, ECX - slot 3
|
||||||
;
|
;
|
||||||
%macro LOAD_EAX 0
|
%macro LOAD_ESP 0
|
||||||
LXMMN xmm6, eax, 1
|
movd esp, xmm6
|
||||||
%endmacro
|
%endmacro
|
||||||
|
|
||||||
%macro SAVE_EAX 0
|
%macro SAVE_ESP 0
|
||||||
SXMMN xmm6, 1, eax
|
|
||||||
%endmacro
|
|
||||||
|
|
||||||
%macro LOAD_EDX 0
|
|
||||||
LXMMN xmm6, edx, 2
|
|
||||||
%endmacro
|
|
||||||
|
|
||||||
%macro SAVE_EDX 0
|
|
||||||
SXMMN xmm6, 2, edx
|
|
||||||
%endmacro
|
|
||||||
|
|
||||||
%macro SAVE_ECX 0
|
|
||||||
SXMMN xmm6, 3, ecx
|
|
||||||
%endmacro
|
|
||||||
|
|
||||||
%macro LOAD_ECX 0
|
|
||||||
LXMMN xmm6, ecx, 3
|
|
||||||
%endmacro
|
|
||||||
|
|
||||||
%macro SAVE_ESP 0
|
|
||||||
SXMMN xmm6, 0, esp
|
SXMMN xmm6, 0, esp
|
||||||
%endmacro
|
%endmacro
|
||||||
|
|
||||||
%macro LOAD_ESP 0
|
%macro LOAD_EAX 0
|
||||||
movd esp, xmm6
|
LXMMN xmm6, eax, 1
|
||||||
%endmacro
|
%endmacro
|
||||||
|
|
||||||
|
%macro SAVE_EAX 0
|
||||||
|
SXMMN xmm6, 1, eax
|
||||||
|
%endmacro
|
||||||
|
|
||||||
|
%macro LOAD_EDX 0
|
||||||
|
LXMMN xmm6, edx, 2
|
||||||
|
%endmacro
|
||||||
|
|
||||||
|
%macro SAVE_EDX 0
|
||||||
|
SXMMN xmm6, 2, edx
|
||||||
|
%endmacro
|
||||||
|
|
||||||
|
%macro LOAD_ECX 0
|
||||||
|
LXMMN xmm6, ecx, 3
|
||||||
|
%endmacro
|
||||||
|
|
||||||
|
%macro SAVE_ECX 0
|
||||||
|
SXMMN xmm6, 3, ecx
|
||||||
|
%endmacro
|
||||||
|
|
||||||
;
|
;
|
||||||
; XMM5 for calling stack
|
; XMM5 slot 0 for calling stack
|
||||||
; arg 1:Entry
|
; arg 1:Entry
|
||||||
%macro CALL_XMM 1
|
%macro CALL_XMM 1
|
||||||
mov esi, %%ReturnAddress
|
mov esi, %%ReturnAddress
|
||||||
pslldq xmm5, 4
|
SXMMN xmm5, 0, esi
|
||||||
%ifdef USE_SSE41_FLAG
|
|
||||||
pinsrd xmm5, esi, 0
|
|
||||||
%else
|
|
||||||
pinsrw xmm5, esi, 0
|
|
||||||
ror esi, 16
|
|
||||||
pinsrw xmm5, esi, 1
|
|
||||||
%endif
|
|
||||||
mov esi, %1
|
mov esi, %1
|
||||||
jmp esi
|
jmp esi
|
||||||
%%ReturnAddress:
|
%%ReturnAddress:
|
||||||
%endmacro
|
%endmacro
|
||||||
|
|
||||||
%macro RET_XMM 0
|
%macro RET_XMM 0
|
||||||
movd esi, xmm5
|
LXMMN xmm5, esi, 0
|
||||||
psrldq xmm5, 4
|
|
||||||
jmp esi
|
jmp esi
|
||||||
%endmacro
|
%endmacro
|
||||||
|
|
||||||
|
;
|
||||||
|
; XMM5 slot 1 for uCode status
|
||||||
|
;
|
||||||
|
%macro LOAD_UCODE_STATUS 0
|
||||||
|
LXMMN xmm5, eax, 1
|
||||||
|
%endmacro
|
||||||
|
|
||||||
|
%macro SAVE_UCODE_STATUS 0
|
||||||
|
SXMMN xmm5, 1, eax
|
||||||
|
%endmacro
|
||||||
|
|
||||||
%macro ENABLE_SSE 0
|
%macro ENABLE_SSE 0
|
||||||
;
|
;
|
||||||
; Initialize floating point units
|
; Initialize floating point units
|
||||||
|
|
|
@ -79,7 +79,7 @@ AsmGetFspBaseAddress (
|
||||||
/**
|
/**
|
||||||
This interface gets FspInfoHeader pointer
|
This interface gets FspInfoHeader pointer
|
||||||
|
|
||||||
@return FSP binary base address.
|
@return FSP info header.
|
||||||
|
|
||||||
**/
|
**/
|
||||||
UINTN
|
UINTN
|
||||||
|
|
|
@ -7,10 +7,12 @@
|
||||||
DEFAULT REL
|
DEFAULT REL
|
||||||
SECTION .text
|
SECTION .text
|
||||||
|
|
||||||
|
FSP_HEADER_IMGBASE_OFFSET EQU 1Ch
|
||||||
|
|
||||||
global ASM_PFX(AsmGetFspBaseAddress)
|
global ASM_PFX(AsmGetFspBaseAddress)
|
||||||
ASM_PFX(AsmGetFspBaseAddress):
|
ASM_PFX(AsmGetFspBaseAddress):
|
||||||
call ASM_PFX(AsmGetFspInfoHeader)
|
call ASM_PFX(AsmGetFspInfoHeader)
|
||||||
add rax, 0x1C
|
add rax, FSP_HEADER_IMGBASE_OFFSET
|
||||||
mov eax, [rax]
|
mov eax, [rax]
|
||||||
ret
|
ret
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue