Remove the GrowBuffer function. Just use the simple way to get the buffer size and then read the buffer. This change improve the readability and save 0x60 byte of data for release build according to MAP file generated for X64 arch.

git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@5924 6f19259b-4bc3-4df7-8a09-765794883524
This commit is contained in:
qwang12 2008-09-18 08:42:11 +00:00
parent c8b671eea5
commit 61ad8a41e7
1 changed files with 48 additions and 92 deletions

View File

@ -18,6 +18,8 @@ WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
Search a handle to a device on a specified device path that supports a specified protocol, Search a handle to a device on a specified device path that supports a specified protocol,
interface of that protocol on that handle is another output. interface of that protocol on that handle is another output.
@param Protocol The protocol to search for @param Protocol The protocol to search for
@param FilePath The specified device path @param FilePath The specified device path
@param Interface Interface of the protocol on the handle @param Interface Interface of the protocol on the handle
@ -261,18 +263,28 @@ CoreOpenImageFile (
// figure out how big the file is. // figure out how big the file is.
// //
FileInfo = NULL; FileInfo = NULL;
FileInfoSize = sizeof (EFI_FILE_INFO); FileInfoSize = 0;
while (CoreGrowBuffer (&Status, (VOID **)&FileInfo, FileInfoSize)) { Status = FileHandle->GetInfo (
// FileHandle,
// Automatically allocate buffer of the correct size and make the call &gEfiFileInfoGuid,
// &FileInfoSize,
Status = FileHandle->GetInfo ( FileInfo
FileHandle, );
&gEfiFileInfoGuid, if (Status == EFI_BUFFER_TOO_SMALL) {
&FileInfoSize, FileInfo = AllocatePool (FileInfoSize);
FileInfo if (FileInfo != NULL) {
); Status = FileHandle->GetInfo (
FileHandle,
&gEfiFileInfoGuid,
&FileInfoSize,
FileInfo
);
} else {
Status = EFI_OUT_OF_RESOURCES;
goto Done;
}
} }
if (!EFI_ERROR (Status)) { if (!EFI_ERROR (Status)) {
// //
// Allocate space for the file // Allocate space for the file
@ -290,6 +302,7 @@ CoreOpenImageFile (
// Close the file since we are done // Close the file since we are done
// //
FileHandle->Close (FileHandle); FileHandle->Close (FileHandle);
CoreFreePool (FileInfo);
} else { } else {
Status = EFI_OUT_OF_RESOURCES; Status = EFI_OUT_OF_RESOURCES;
} }
@ -316,23 +329,31 @@ CoreOpenImageFile (
// //
// Call LoadFile with the correct buffer size // Call LoadFile with the correct buffer size
// //
while (CoreGrowBuffer (&Status, (VOID **)&ImageFileHandle->Source, ImageFileHandle->SourceSize)) { ASSERT (ImageFileHandle->SourceSize == 0);
Status = LoadFile->LoadFile ( ASSERT (ImageFileHandle->Source == NULL);
LoadFile, Status = LoadFile->LoadFile (
TempFilePath, LoadFile,
BootPolicy, TempFilePath,
&ImageFileHandle->SourceSize, BootPolicy,
ImageFileHandle->Source &ImageFileHandle->SourceSize,
); ImageFileHandle->Source
// );
// If success or other error happens, stop loop if (Status == EFI_BUFFER_TOO_SMALL) {
// ImageFileHandle->Source = AllocatePool (ImageFileHandle->SourceSize);
if (Status != EFI_BUFFER_TOO_SMALL) { if (ImageFileHandle->Source == NULL) {
break; Status = EFI_OUT_OF_RESOURCES;
} else {
Status = LoadFile->LoadFile (
LoadFile,
TempFilePath,
BootPolicy,
&ImageFileHandle->SourceSize,
ImageFileHandle->Source
);
} }
} }
if (!EFI_ERROR (Status)) { if (!EFI_ERROR (Status) || Status == EFI_ALREADY_STARTED) {
ImageFileHandle->FreeBuffer = TRUE; ImageFileHandle->FreeBuffer = TRUE;
goto Done; goto Done;
} }
@ -341,15 +362,14 @@ CoreOpenImageFile (
// //
// Nothing else to try // Nothing else to try
// //
DEBUG ((DEBUG_LOAD | DEBUG_WARN, "CoreOpenImageFile: Device did not support a known load protocol\n")); DEBUG ((DEBUG_LOAD|DEBUG_WARN, "CoreOpenImageFile: Device did not support a known load protocol\n"));
Status = EFI_NOT_FOUND; Status = EFI_NOT_FOUND;
Done: Done:
// //
// If the file was not accessed, clean up // If the file was not accessed, clean up
// //
if (EFI_ERROR (Status)) { if (EFI_ERROR (Status) && (Status != EFI_ALREADY_STARTED)) {
if (ImageFileHandle->FreeBuffer) { if (ImageFileHandle->FreeBuffer) {
// //
// Free the source buffer if we allocated it // Free the source buffer if we allocated it
@ -407,67 +427,3 @@ CoreReadImageFile (
return EFI_SUCCESS; return EFI_SUCCESS;
} }
/**
Helper function called as part of the code needed
to allocate the proper sized buffer for various
EFI interfaces.
@param Status Current status
@param Buffer Current allocated buffer, or NULL
@param BufferSize Current buffer size needed
@retval TRUE if the buffer was reallocated and the caller
should try the API again.
@retval FALSE buffer could not be allocated and the caller
should not try the API again.
**/
BOOLEAN
CoreGrowBuffer (
IN OUT EFI_STATUS *Status,
IN OUT VOID **Buffer,
IN UINTN BufferSize
)
{
BOOLEAN TryAgain;
TryAgain = FALSE;
//
// If this is an initial request, buffer will be null with a new buffer size
//
if (*Buffer == NULL) {
*Status = EFI_BUFFER_TOO_SMALL;
}
if (BufferSize == 0) {
return TRUE;
}
//
// If the status code is "buffer too small", resize the buffer
//
if (*Status == EFI_BUFFER_TOO_SMALL) {
if (*Buffer != NULL) {
CoreFreePool (*Buffer);
}
*Buffer = AllocatePool (BufferSize);
if (*Buffer != NULL) {
TryAgain = TRUE;
} else {
*Status = EFI_OUT_OF_RESOURCES;
}
}
//
// If there's an error, free the buffer
//
if ((!TryAgain) && (EFI_ERROR (*Status)) && (*Buffer != NULL)) {
CoreFreePool (*Buffer);
*Buffer = NULL;
}
return TryAgain;
}