From: Star Zeng Date: Wed, 18 Mar 2015 08:47:47 +0000 (+0000) Subject: MdeModulePkg BootScriptExecutorDxe: Use ImageContext.ImageSize to allocate memory... X-Git-Tag: edk2-stable201903~10136 X-Git-Url: https://git.proxmox.com/?a=commitdiff_plain;h=32a81741dbc91c041ca57d600526ca9c088440ff;p=mirror_edk2.git MdeModulePkg BootScriptExecutorDxe: Use ImageContext.ImageSize to allocate memory for PE image to handle the case PE file alignment is not same as PE section alignment. Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Star Zeng Reviewed-by: Jiewen Yao git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@17063 6f19259b-4bc3-4df7-8a09-765794883524 --- diff --git a/MdeModulePkg/Universal/Acpi/BootScriptExecutorDxe/ScriptExecute.c b/MdeModulePkg/Universal/Acpi/BootScriptExecutorDxe/ScriptExecute.c index 3fbdf5cd83..97df37b7ab 100644 --- a/MdeModulePkg/Universal/Acpi/BootScriptExecutorDxe/ScriptExecute.c +++ b/MdeModulePkg/Universal/Acpi/BootScriptExecutorDxe/ScriptExecute.c @@ -4,7 +4,7 @@ This driver is dispatched by Dxe core and the driver will reload itself to ACPI reserved memory in the entry point. The functionality is to interpret and restore the S3 boot script -Copyright (c) 2006 - 2014, Intel Corporation. All rights reserved.
+Copyright (c) 2006 - 2015, Intel Corporation. All rights reserved.
This program and the accompanying materials are licensed and made available under the terms and conditions of the BSD License @@ -307,7 +307,11 @@ ReadyToLockEventNotify ( // Status = PeCoffLoaderGetImageInfo (&ImageContext); ASSERT_EFI_ERROR (Status); - Pages = EFI_SIZE_TO_PAGES(BufferSize + ImageContext.SectionAlignment); + if (ImageContext.SectionAlignment > EFI_PAGE_SIZE) { + Pages = EFI_SIZE_TO_PAGES (ImageContext.ImageSize + ImageContext.SectionAlignment); + } else { + Pages = EFI_SIZE_TO_PAGES (ImageContext.ImageSize); + } FfsBuffer = 0xFFFFFFFF; Status = gBS->AllocatePages ( AllocateMaxAddress,