mirror of
https://github.com/acidanthera/audk.git
synced 2025-07-23 21:54:27 +02:00
UefiCpuPkg: Move MigrateGdt from DiscoverMemory to TempRamDone. (CVE-2019-11098)
REF: https://bugzilla.tianocore.org/show_bug.cgi?id=1614 REF: https://bugzilla.tianocore.org/show_bug.cgi?id=3160 The GDT still in flash with commit 60b12e69fb1c8c7180fdda92f008248b9ec83db1 after TempRamDone So move the action to TempRamDone event to avoid reading GDT from flash. Signed-off-by: Guomin Jiang <guomin.jiang@intel.com> Cc: Eric Dong <eric.dong@intel.com> Cc: Ray Ni <ray.ni@intel.com> Cc: Laszlo Ersek <lersek@redhat.com> Cc: Rahul Kumar <rahul1.kumar@intel.com> Cc: Debkumar De <debkumar.de@intel.com> Cc: Harry Han <harry.han@intel.com> Cc: Catharine West <catharine.west@intel.com> Reviewed-by: Ray Ni <ray.ni@intel.com>
This commit is contained in:
parent
e806bb29cf
commit
f6ec1dd34f
@ -429,43 +429,6 @@ GetGdtr (
|
|||||||
AsmReadGdtr ((IA32_DESCRIPTOR *)Buffer);
|
AsmReadGdtr ((IA32_DESCRIPTOR *)Buffer);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
Migrates the Global Descriptor Table (GDT) to permanent memory.
|
|
||||||
|
|
||||||
@retval EFI_SUCCESS The GDT was migrated successfully.
|
|
||||||
@retval EFI_OUT_OF_RESOURCES The GDT could not be migrated due to lack of available memory.
|
|
||||||
|
|
||||||
**/
|
|
||||||
EFI_STATUS
|
|
||||||
MigrateGdt (
|
|
||||||
VOID
|
|
||||||
)
|
|
||||||
{
|
|
||||||
EFI_STATUS Status;
|
|
||||||
UINTN GdtBufferSize;
|
|
||||||
IA32_DESCRIPTOR Gdtr;
|
|
||||||
VOID *GdtBuffer;
|
|
||||||
|
|
||||||
AsmReadGdtr ((IA32_DESCRIPTOR *) &Gdtr);
|
|
||||||
GdtBufferSize = sizeof (IA32_SEGMENT_DESCRIPTOR) -1 + Gdtr.Limit + 1;
|
|
||||||
|
|
||||||
Status = PeiServicesAllocatePool (
|
|
||||||
GdtBufferSize,
|
|
||||||
&GdtBuffer
|
|
||||||
);
|
|
||||||
ASSERT (GdtBuffer != NULL);
|
|
||||||
if (EFI_ERROR (Status)) {
|
|
||||||
return EFI_OUT_OF_RESOURCES;
|
|
||||||
}
|
|
||||||
|
|
||||||
GdtBuffer = ALIGN_POINTER (GdtBuffer, sizeof (IA32_SEGMENT_DESCRIPTOR));
|
|
||||||
CopyMem (GdtBuffer, (VOID *) Gdtr.Base, Gdtr.Limit + 1);
|
|
||||||
Gdtr.Base = (UINTN) GdtBuffer;
|
|
||||||
AsmWriteGdtr (&Gdtr);
|
|
||||||
|
|
||||||
return EFI_SUCCESS;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Initializes CPU exceptions handlers for the sake of stack switch requirement.
|
Initializes CPU exceptions handlers for the sake of stack switch requirement.
|
||||||
|
|
||||||
|
@ -67,7 +67,6 @@
|
|||||||
gUefiCpuPkgTokenSpaceGuid.PcdCpuStackSwitchExceptionList ## SOMETIMES_CONSUMES
|
gUefiCpuPkgTokenSpaceGuid.PcdCpuStackSwitchExceptionList ## SOMETIMES_CONSUMES
|
||||||
gUefiCpuPkgTokenSpaceGuid.PcdCpuKnownGoodStackSize ## SOMETIMES_CONSUMES
|
gUefiCpuPkgTokenSpaceGuid.PcdCpuKnownGoodStackSize ## SOMETIMES_CONSUMES
|
||||||
gUefiCpuPkgTokenSpaceGuid.PcdCpuApStackSize ## SOMETIMES_CONSUMES
|
gUefiCpuPkgTokenSpaceGuid.PcdCpuApStackSize ## SOMETIMES_CONSUMES
|
||||||
gEfiMdeModulePkgTokenSpaceGuid.PcdMigrateTemporaryRamFirmwareVolumes ## CONSUMES
|
|
||||||
|
|
||||||
[Depex]
|
[Depex]
|
||||||
TRUE
|
TRUE
|
||||||
|
@ -605,17 +605,9 @@ MemoryDiscoveredPpiNotifyCallback (
|
|||||||
{
|
{
|
||||||
EFI_STATUS Status;
|
EFI_STATUS Status;
|
||||||
BOOLEAN InitStackGuard;
|
BOOLEAN InitStackGuard;
|
||||||
BOOLEAN InterruptState;
|
|
||||||
EDKII_MIGRATED_FV_INFO *MigratedFvInfo;
|
EDKII_MIGRATED_FV_INFO *MigratedFvInfo;
|
||||||
EFI_PEI_HOB_POINTERS Hob;
|
EFI_PEI_HOB_POINTERS Hob;
|
||||||
|
|
||||||
if (PcdGetBool (PcdMigrateTemporaryRamFirmwareVolumes)) {
|
|
||||||
InterruptState = SaveAndDisableInterrupts ();
|
|
||||||
Status = MigrateGdt ();
|
|
||||||
ASSERT_EFI_ERROR (Status);
|
|
||||||
SetInterruptState (InterruptState);
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// Paging must be setup first. Otherwise the exception TSS setup during MP
|
// Paging must be setup first. Otherwise the exception TSS setup during MP
|
||||||
// initialization later will not contain paging information and then fail
|
// initialization later will not contain paging information and then fail
|
||||||
|
@ -77,6 +77,7 @@
|
|||||||
|
|
||||||
[Pcd]
|
[Pcd]
|
||||||
gUefiCpuPkgTokenSpaceGuid.PcdPeiTemporaryRamStackSize ## CONSUMES
|
gUefiCpuPkgTokenSpaceGuid.PcdPeiTemporaryRamStackSize ## CONSUMES
|
||||||
|
gEfiMdeModulePkgTokenSpaceGuid.PcdMigrateTemporaryRamFirmwareVolumes ## CONSUMES
|
||||||
|
|
||||||
[UserExtensions.TianoCore."ExtraFiles"]
|
[UserExtensions.TianoCore."ExtraFiles"]
|
||||||
SecCoreExtra.uni
|
SecCoreExtra.uni
|
||||||
|
@ -35,6 +35,43 @@ EFI_PEI_PPI_DESCRIPTOR mPeiSecPlatformInformationPpi[] = {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
Migrates the Global Descriptor Table (GDT) to permanent memory.
|
||||||
|
|
||||||
|
@retval EFI_SUCCESS The GDT was migrated successfully.
|
||||||
|
@retval EFI_OUT_OF_RESOURCES The GDT could not be migrated due to lack of available memory.
|
||||||
|
|
||||||
|
**/
|
||||||
|
EFI_STATUS
|
||||||
|
MigrateGdt (
|
||||||
|
VOID
|
||||||
|
)
|
||||||
|
{
|
||||||
|
EFI_STATUS Status;
|
||||||
|
UINTN GdtBufferSize;
|
||||||
|
IA32_DESCRIPTOR Gdtr;
|
||||||
|
VOID *GdtBuffer;
|
||||||
|
|
||||||
|
AsmReadGdtr ((IA32_DESCRIPTOR *) &Gdtr);
|
||||||
|
GdtBufferSize = sizeof (IA32_SEGMENT_DESCRIPTOR) -1 + Gdtr.Limit + 1;
|
||||||
|
|
||||||
|
Status = PeiServicesAllocatePool (
|
||||||
|
GdtBufferSize,
|
||||||
|
&GdtBuffer
|
||||||
|
);
|
||||||
|
ASSERT (GdtBuffer != NULL);
|
||||||
|
if (EFI_ERROR (Status)) {
|
||||||
|
return EFI_OUT_OF_RESOURCES;
|
||||||
|
}
|
||||||
|
|
||||||
|
GdtBuffer = ALIGN_POINTER (GdtBuffer, sizeof (IA32_SEGMENT_DESCRIPTOR));
|
||||||
|
CopyMem (GdtBuffer, (VOID *) Gdtr.Base, Gdtr.Limit + 1);
|
||||||
|
Gdtr.Base = (UINTN) GdtBuffer;
|
||||||
|
AsmWriteGdtr (&Gdtr);
|
||||||
|
|
||||||
|
return EFI_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
// These are IDT entries pointing to 10:FFFFFFE4h.
|
// These are IDT entries pointing to 10:FFFFFFE4h.
|
||||||
//
|
//
|
||||||
@ -409,6 +446,14 @@ SecTemporaryRamDone (
|
|||||||
//
|
//
|
||||||
State = SaveAndDisableInterrupts ();
|
State = SaveAndDisableInterrupts ();
|
||||||
|
|
||||||
|
//
|
||||||
|
// Migrate GDT before NEM near down
|
||||||
|
//
|
||||||
|
if (PcdGetBool (PcdMigrateTemporaryRamFirmwareVolumes)) {
|
||||||
|
Status = MigrateGdt ();
|
||||||
|
ASSERT_EFI_ERROR (Status);
|
||||||
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
// Disable Temporary RAM after Stack and Heap have been migrated at this point.
|
// Disable Temporary RAM after Stack and Heap have been migrated at this point.
|
||||||
//
|
//
|
||||||
|
Loading…
x
Reference in New Issue
Block a user