mirror of https://github.com/acidanthera/audk.git
UefiCpuPkg/SmmRelocationLib: Rename global variables
This patch aims to rename global variables for clearer association with Smm Init, ensuring their names are distinct from those used in the PiSmmCpuDxeSmm Driver. Cc: Ray Ni <ray.ni@intel.com> Cc: Zeng Star <star.zeng@intel.com> Cc: Gerd Hoffmann <kraxel@redhat.com> Cc: Rahul Kumar <rahul1.kumar@intel.com> Signed-off-by: Jiaxin Wu <jiaxin.wu@intel.com> Reviewed-by: Ray Ni <ray.ni@intel.com>
This commit is contained in:
parent
51fcd2023b
commit
42e8fa84f7
|
@ -18,11 +18,11 @@ extern ASM_PFX(SmmInitHandler)
|
||||||
extern ASM_PFX(mRebasedFlag)
|
extern ASM_PFX(mRebasedFlag)
|
||||||
extern ASM_PFX(mSmmRelocationOriginalAddress)
|
extern ASM_PFX(mSmmRelocationOriginalAddress)
|
||||||
|
|
||||||
global ASM_PFX(gPatchSmmCr3)
|
global ASM_PFX(gPatchSmmInitCr3)
|
||||||
global ASM_PFX(gPatchSmmCr4)
|
global ASM_PFX(gPatchSmmInitCr4)
|
||||||
global ASM_PFX(gPatchSmmCr0)
|
global ASM_PFX(gPatchSmmInitCr0)
|
||||||
global ASM_PFX(gPatchSmmInitStack)
|
global ASM_PFX(gPatchSmmInitStack)
|
||||||
global ASM_PFX(gcSmiInitGdtr)
|
global ASM_PFX(gcSmmInitGdtr)
|
||||||
global ASM_PFX(gcSmmInitSize)
|
global ASM_PFX(gcSmmInitSize)
|
||||||
global ASM_PFX(gcSmmInitTemplate)
|
global ASM_PFX(gcSmmInitTemplate)
|
||||||
|
|
||||||
|
@ -83,7 +83,7 @@ CodeSeg64:
|
||||||
DB 0 ; BaseHigh
|
DB 0 ; BaseHigh
|
||||||
GDT_SIZE equ $ - NullSeg
|
GDT_SIZE equ $ - NullSeg
|
||||||
|
|
||||||
ASM_PFX(gcSmiInitGdtr):
|
ASM_PFX(gcSmmInitGdtr):
|
||||||
DW GDT_SIZE - 1
|
DW GDT_SIZE - 1
|
||||||
DD NullSeg
|
DD NullSeg
|
||||||
|
|
||||||
|
@ -100,18 +100,18 @@ ASM_PFX(SmmStartup):
|
||||||
and ebx, BIT20 ; extract NX capability bit
|
and ebx, BIT20 ; extract NX capability bit
|
||||||
shr ebx, 9 ; shift bit to IA32_EFER.NXE[BIT11] position
|
shr ebx, 9 ; shift bit to IA32_EFER.NXE[BIT11] position
|
||||||
mov eax, strict dword 0 ; source operand will be patched
|
mov eax, strict dword 0 ; source operand will be patched
|
||||||
ASM_PFX(gPatchSmmCr3):
|
ASM_PFX(gPatchSmmInitCr3):
|
||||||
mov cr3, eax
|
mov cr3, eax
|
||||||
o32 lgdt [cs:ebp + (ASM_PFX(gcSmiInitGdtr) - ASM_PFX(SmmStartup))]
|
o32 lgdt [cs:ebp + (ASM_PFX(gcSmmInitGdtr) - ASM_PFX(SmmStartup))]
|
||||||
mov eax, strict dword 0 ; source operand will be patched
|
mov eax, strict dword 0 ; source operand will be patched
|
||||||
ASM_PFX(gPatchSmmCr4):
|
ASM_PFX(gPatchSmmInitCr4):
|
||||||
mov cr4, eax
|
mov cr4, eax
|
||||||
mov ecx, 0xc0000080 ; IA32_EFER MSR
|
mov ecx, 0xc0000080 ; IA32_EFER MSR
|
||||||
rdmsr
|
rdmsr
|
||||||
or eax, ebx ; set NXE bit if NX is available
|
or eax, ebx ; set NXE bit if NX is available
|
||||||
wrmsr
|
wrmsr
|
||||||
mov eax, strict dword 0 ; source operand will be patched
|
mov eax, strict dword 0 ; source operand will be patched
|
||||||
ASM_PFX(gPatchSmmCr0):
|
ASM_PFX(gPatchSmmInitCr0):
|
||||||
mov di, PROTECT_MODE_DS
|
mov di, PROTECT_MODE_DS
|
||||||
mov cr0, eax
|
mov cr0, eax
|
||||||
jmp PROTECT_MODE_CS : dword @32bit
|
jmp PROTECT_MODE_CS : dword @32bit
|
||||||
|
|
|
@ -32,13 +32,13 @@
|
||||||
#include <Register/Intel/SmramSaveStateMap.h>
|
#include <Register/Intel/SmramSaveStateMap.h>
|
||||||
#include <Protocol/MmCpu.h>
|
#include <Protocol/MmCpu.h>
|
||||||
|
|
||||||
extern IA32_DESCRIPTOR gcSmiInitGdtr;
|
extern IA32_DESCRIPTOR gcSmmInitGdtr;
|
||||||
extern CONST UINT16 gcSmmInitSize;
|
extern CONST UINT16 gcSmmInitSize;
|
||||||
extern CONST UINT8 gcSmmInitTemplate[];
|
extern CONST UINT8 gcSmmInitTemplate[];
|
||||||
|
|
||||||
X86_ASSEMBLY_PATCH_LABEL gPatchSmmCr0;
|
X86_ASSEMBLY_PATCH_LABEL gPatchSmmInitCr0;
|
||||||
X86_ASSEMBLY_PATCH_LABEL gPatchSmmCr3;
|
X86_ASSEMBLY_PATCH_LABEL gPatchSmmInitCr3;
|
||||||
X86_ASSEMBLY_PATCH_LABEL gPatchSmmCr4;
|
X86_ASSEMBLY_PATCH_LABEL gPatchSmmInitCr4;
|
||||||
X86_ASSEMBLY_PATCH_LABEL gPatchSmmInitStack;
|
X86_ASSEMBLY_PATCH_LABEL gPatchSmmInitStack;
|
||||||
|
|
||||||
//
|
//
|
||||||
|
|
|
@ -24,7 +24,7 @@ EFI_PROCESSOR_INFORMATION *mProcessorInfo = NULL;
|
||||||
//
|
//
|
||||||
// IDT used during SMM Init
|
// IDT used during SMM Init
|
||||||
//
|
//
|
||||||
IA32_DESCRIPTOR gcSmiIdtr;
|
IA32_DESCRIPTOR gcSmmInitIdtr;
|
||||||
|
|
||||||
//
|
//
|
||||||
// Smbase for all CPUs
|
// Smbase for all CPUs
|
||||||
|
@ -120,7 +120,7 @@ SmmInitHandler (
|
||||||
//
|
//
|
||||||
// Update SMM IDT entries' code segment and load IDT
|
// Update SMM IDT entries' code segment and load IDT
|
||||||
//
|
//
|
||||||
AsmWriteIdtr (&gcSmiIdtr);
|
AsmWriteIdtr (&gcSmmInitIdtr);
|
||||||
ApicId = GetApicId ();
|
ApicId = GetApicId ();
|
||||||
|
|
||||||
for (Index = 0; Index < mNumberOfCpus; Index++) {
|
for (Index = 0; Index < mNumberOfCpus; Index++) {
|
||||||
|
@ -169,9 +169,9 @@ SmmRelocateBases (
|
||||||
//
|
//
|
||||||
// Patch ASM code template with current CR0, CR3, and CR4 values
|
// Patch ASM code template with current CR0, CR3, and CR4 values
|
||||||
//
|
//
|
||||||
PatchInstructionX86 (gPatchSmmCr0, AsmReadCr0 (), 4);
|
PatchInstructionX86 (gPatchSmmInitCr0, AsmReadCr0 (), 4);
|
||||||
PatchInstructionX86 (gPatchSmmCr3, AsmReadCr3 (), 4);
|
PatchInstructionX86 (gPatchSmmInitCr3, AsmReadCr3 (), 4);
|
||||||
PatchInstructionX86 (gPatchSmmCr4, AsmReadCr4 () & (~CR4_CET_ENABLE), 4);
|
PatchInstructionX86 (gPatchSmmInitCr4, AsmReadCr4 () & (~CR4_CET_ENABLE), 4);
|
||||||
|
|
||||||
U8Ptr = (UINT8 *)(UINTN)(SMM_DEFAULT_SMBASE + SMM_HANDLER_OFFSET);
|
U8Ptr = (UINT8 *)(UINTN)(SMM_DEFAULT_SMBASE + SMM_HANDLER_OFFSET);
|
||||||
CpuStatePtr = (SMRAM_SAVE_STATE_MAP *)(UINTN)(SMM_DEFAULT_SMBASE + SMRAM_SAVE_STATE_MAP_OFFSET);
|
CpuStatePtr = (SMRAM_SAVE_STATE_MAP *)(UINTN)(SMM_DEFAULT_SMBASE + SMRAM_SAVE_STATE_MAP_OFFSET);
|
||||||
|
@ -251,15 +251,15 @@ InitSmmIdt (
|
||||||
// There are 32 (not 255) entries in it since only processor
|
// There are 32 (not 255) entries in it since only processor
|
||||||
// generated exceptions will be handled.
|
// generated exceptions will be handled.
|
||||||
//
|
//
|
||||||
gcSmiIdtr.Limit = (sizeof (IA32_IDT_GATE_DESCRIPTOR) * 32) - 1;
|
gcSmmInitIdtr.Limit = (sizeof (IA32_IDT_GATE_DESCRIPTOR) * 32) - 1;
|
||||||
|
|
||||||
//
|
//
|
||||||
// Allocate for IDT.
|
// Allocate for IDT.
|
||||||
// sizeof (UINTN) is for the PEI Services Table pointer.
|
// sizeof (UINTN) is for the PEI Services Table pointer.
|
||||||
//
|
//
|
||||||
gcSmiIdtr.Base = (UINTN)AllocateZeroPool (gcSmiIdtr.Limit + 1 + sizeof (UINTN));
|
gcSmmInitIdtr.Base = (UINTN)AllocateZeroPool (gcSmmInitIdtr.Limit + 1 + sizeof (UINTN));
|
||||||
ASSERT (gcSmiIdtr.Base != 0);
|
ASSERT (gcSmmInitIdtr.Base != 0);
|
||||||
gcSmiIdtr.Base += sizeof (UINTN);
|
gcSmmInitIdtr.Base += sizeof (UINTN);
|
||||||
|
|
||||||
//
|
//
|
||||||
// Disable Interrupt, save InterruptState and save PEI IDT table
|
// Disable Interrupt, save InterruptState and save PEI IDT table
|
||||||
|
@ -272,17 +272,17 @@ InitSmmIdt (
|
||||||
// The PEI Services Table pointer will be stored in the sizeof (UINTN) bytes
|
// The PEI Services Table pointer will be stored in the sizeof (UINTN) bytes
|
||||||
// immediately preceding the IDT in memory.
|
// immediately preceding the IDT in memory.
|
||||||
//
|
//
|
||||||
PeiServices = (CONST EFI_PEI_SERVICES **)(*(UINTN *)(PeiIdtr.Base - sizeof (UINTN)));
|
PeiServices = (CONST EFI_PEI_SERVICES **)(*(UINTN *)(PeiIdtr.Base - sizeof (UINTN)));
|
||||||
(*(UINTN *)(gcSmiIdtr.Base - sizeof (UINTN))) = (UINTN)PeiServices;
|
(*(UINTN *)(gcSmmInitIdtr.Base - sizeof (UINTN))) = (UINTN)PeiServices;
|
||||||
|
|
||||||
//
|
//
|
||||||
// Load SMM temporary IDT table
|
// Load SMM temporary IDT table
|
||||||
//
|
//
|
||||||
AsmWriteIdtr (&gcSmiIdtr);
|
AsmWriteIdtr (&gcSmmInitIdtr);
|
||||||
|
|
||||||
//
|
//
|
||||||
// Setup SMM default exception handlers, SMM IDT table
|
// Setup SMM default exception handlers, SMM IDT table
|
||||||
// will be updated and saved in gcSmiIdtr
|
// will be updated and saved in gcSmmInitIdtr
|
||||||
//
|
//
|
||||||
Status = InitializeCpuExceptionHandlers (NULL);
|
Status = InitializeCpuExceptionHandlers (NULL);
|
||||||
ASSERT_EFI_ERROR (Status);
|
ASSERT_EFI_ERROR (Status);
|
||||||
|
|
|
@ -18,11 +18,11 @@ extern ASM_PFX(SmmInitHandler)
|
||||||
extern ASM_PFX(mRebasedFlag)
|
extern ASM_PFX(mRebasedFlag)
|
||||||
extern ASM_PFX(mSmmRelocationOriginalAddress)
|
extern ASM_PFX(mSmmRelocationOriginalAddress)
|
||||||
|
|
||||||
global ASM_PFX(gPatchSmmCr3)
|
global ASM_PFX(gPatchSmmInitCr3)
|
||||||
global ASM_PFX(gPatchSmmCr4)
|
global ASM_PFX(gPatchSmmInitCr4)
|
||||||
global ASM_PFX(gPatchSmmCr0)
|
global ASM_PFX(gPatchSmmInitCr0)
|
||||||
global ASM_PFX(gPatchSmmInitStack)
|
global ASM_PFX(gPatchSmmInitStack)
|
||||||
global ASM_PFX(gcSmiInitGdtr)
|
global ASM_PFX(gcSmmInitGdtr)
|
||||||
global ASM_PFX(gcSmmInitSize)
|
global ASM_PFX(gcSmmInitSize)
|
||||||
global ASM_PFX(gcSmmInitTemplate)
|
global ASM_PFX(gcSmmInitTemplate)
|
||||||
global ASM_PFX(gPatchRebasedFlagAddr32)
|
global ASM_PFX(gPatchRebasedFlagAddr32)
|
||||||
|
@ -84,7 +84,7 @@ CodeSeg64:
|
||||||
DB 0 ; BaseHigh
|
DB 0 ; BaseHigh
|
||||||
GDT_SIZE equ $ - NullSeg
|
GDT_SIZE equ $ - NullSeg
|
||||||
|
|
||||||
ASM_PFX(gcSmiInitGdtr):
|
ASM_PFX(gcSmmInitGdtr):
|
||||||
DW GDT_SIZE - 1
|
DW GDT_SIZE - 1
|
||||||
DQ NullSeg
|
DQ NullSeg
|
||||||
|
|
||||||
|
@ -100,11 +100,11 @@ ASM_PFX(SmmStartup):
|
||||||
cpuid
|
cpuid
|
||||||
mov ebx, edx ; rdmsr will change edx. keep it in ebx.
|
mov ebx, edx ; rdmsr will change edx. keep it in ebx.
|
||||||
mov eax, strict dword 0 ; source operand will be patched
|
mov eax, strict dword 0 ; source operand will be patched
|
||||||
ASM_PFX(gPatchSmmCr3):
|
ASM_PFX(gPatchSmmInitCr3):
|
||||||
mov cr3, eax
|
mov cr3, eax
|
||||||
o32 lgdt [cs:ebp + (ASM_PFX(gcSmiInitGdtr) - ASM_PFX(SmmStartup))]
|
o32 lgdt [cs:ebp + (ASM_PFX(gcSmmInitGdtr) - ASM_PFX(SmmStartup))]
|
||||||
mov eax, strict dword 0 ; source operand will be patched
|
mov eax, strict dword 0 ; source operand will be patched
|
||||||
ASM_PFX(gPatchSmmCr4):
|
ASM_PFX(gPatchSmmInitCr4):
|
||||||
or ah, 2 ; enable XMM registers access
|
or ah, 2 ; enable XMM registers access
|
||||||
mov cr4, eax
|
mov cr4, eax
|
||||||
mov ecx, 0xc0000080 ; IA32_EFER MSR
|
mov ecx, 0xc0000080 ; IA32_EFER MSR
|
||||||
|
@ -116,7 +116,7 @@ ASM_PFX(gPatchSmmCr4):
|
||||||
.1:
|
.1:
|
||||||
wrmsr
|
wrmsr
|
||||||
mov eax, strict dword 0 ; source operand will be patched
|
mov eax, strict dword 0 ; source operand will be patched
|
||||||
ASM_PFX(gPatchSmmCr0):
|
ASM_PFX(gPatchSmmInitCr0):
|
||||||
mov cr0, eax ; enable protected mode & paging
|
mov cr0, eax ; enable protected mode & paging
|
||||||
jmp LONG_MODE_CS : dword 0 ; offset will be patched to @LongMode
|
jmp LONG_MODE_CS : dword 0 ; offset will be patched to @LongMode
|
||||||
@PatchLongModeOffset:
|
@PatchLongModeOffset:
|
||||||
|
|
Loading…
Reference in New Issue