X-Git-Url: https://git.proxmox.com/?p=mirror_edk2.git;a=blobdiff_plain;f=UefiCpuPkg%2FPiSmmCpuDxeSmm%2FSmramSaveState.c;h=f0c289254330d3949a0f00dcd3fcc98818c13b9f;hp=d34345d5ff8034515165fd782c10402a69f88cea;hb=fc504fdea7fe92bfa88e15f50e64b4d76d4f75fd;hpb=5a1bfda4bd04815ed8c7489e2db47f9a1f245566 diff --git a/UefiCpuPkg/PiSmmCpuDxeSmm/SmramSaveState.c b/UefiCpuPkg/PiSmmCpuDxeSmm/SmramSaveState.c index d34345d5ff..f0c2892543 100644 --- a/UefiCpuPkg/PiSmmCpuDxeSmm/SmramSaveState.c +++ b/UefiCpuPkg/PiSmmCpuDxeSmm/SmramSaveState.c @@ -106,7 +106,7 @@ typedef struct { /// Variables from SMI Handler /// X86_ASSEMBLY_PATCH_LABEL gPatchSmbase; -extern volatile UINT32 gSmiStack; +X86_ASSEMBLY_PATCH_LABEL gPatchSmiStack; extern UINT32 gSmiCr3; extern volatile UINT8 gcSmiHandlerTemplate[]; extern CONST UINT16 gcSmiHandlerSize; @@ -686,6 +686,7 @@ InstallSmiHandler ( ) { PROCESSOR_SMM_DESCRIPTOR *Psd; + UINT32 CpuSmiStack; // // Initialize PROCESSOR_SMM_DESCRIPTOR @@ -716,7 +717,8 @@ InstallSmiHandler ( // // Initialize values in template before copy // - gSmiStack = (UINT32)((UINTN)SmiStack + StackSize - sizeof (UINTN)); + CpuSmiStack = (UINT32)((UINTN)SmiStack + StackSize - sizeof (UINTN)); + PatchInstructionX86 (gPatchSmiStack, CpuSmiStack, 4); gSmiCr3 = Cr3; PatchInstructionX86 (gPatchSmbase, SmBase, 4); gSmiHandlerIdtr.Base = IdtBase; @@ -725,7 +727,7 @@ InstallSmiHandler ( // // Set the value at the top of the CPU stack to the CPU Index // - *(UINTN*)(UINTN)gSmiStack = CpuIndex; + *(UINTN*)(UINTN)CpuSmiStack = CpuIndex; // // Copy template to CPU specific SMI handler location