From 1aaa6f61a55a4db594d264ab8c0b0c9ddac1110e Mon Sep 17 00:00:00 2001 From: Brendan Jackman Date: Wed, 14 May 2014 16:39:43 +0000 Subject: [PATCH] ArmPkg/BdsLib: Fix allocating kernel buffer in TFTP Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Brendan Jackman Reviewed-By: Olivier Martin git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@15527 6f19259b-4bc3-4df7-8a09-765794883524 --- ArmPkg/Library/BdsLib/BdsFilePath.c | 19 +++++++++++-------- 1 file changed, 11 insertions(+), 8 deletions(-) diff --git a/ArmPkg/Library/BdsLib/BdsFilePath.c b/ArmPkg/Library/BdsLib/BdsFilePath.c index 487bd7654c..90be9c1e11 100644 --- a/ArmPkg/Library/BdsLib/BdsFilePath.c +++ b/ArmPkg/Library/BdsLib/BdsFilePath.c @@ -756,7 +756,6 @@ BdsTftpLoadImage ( EFI_STATUS Status; EFI_PXE_BASE_CODE_PROTOCOL *Pxe; UINT64 TftpBufferSize; - VOID* TftpBuffer; EFI_IP_ADDRESS ServerIp; IPv4_DEVICE_PATH* IPv4DevicePathNode; FILEPATH_DEVICE_PATH* FilePathDevicePath; @@ -838,16 +837,21 @@ BdsTftpLoadImage ( } // Allocate a buffer to hold the whole file. - TftpBuffer = AllocatePool (TftpBufferSize); - if (TftpBuffer == NULL) { - Status = EFI_OUT_OF_RESOURCES; + Status = gBS->AllocatePages ( + Type, + EfiBootServicesCode, + EFI_SIZE_TO_PAGES (TftpBufferSize), + Image + ); + if (EFI_ERROR (Status)) { + DEBUG ((EFI_D_ERROR, "Failed to allocate space for kernel image: %r\n", Status)); goto EXIT; } Status = Pxe->Mtftp ( Pxe, EFI_PXE_BASE_CODE_TFTP_READ_FILE, - TftpBuffer, + (VOID *)(UINTN)*Image, FALSE, &TftpBufferSize, NULL, @@ -857,9 +861,8 @@ BdsTftpLoadImage ( FALSE ); if (EFI_ERROR (Status)) { - FreePool (TftpBuffer); - } else if (ImageSize != NULL) { - *Image = (UINTN)TftpBuffer; + gBS->FreePages (*Image, EFI_SIZE_TO_PAGES (TftpBufferSize)); + } else { *ImageSize = (UINTN)TftpBufferSize; }