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:
Jiaxin Wu 2024-04-18 11:13:37 +08:00 committed by mergify[bot]
parent 51fcd2023b
commit 42e8fa84f7
4 changed files with 35 additions and 35 deletions

View File

@ -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

View File

@ -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;
// //

View File

@ -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);

View File

@ -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: