You've already forked slimbootloader
mirror of
https://github.com/Dasharo/slimbootloader.git
synced 2026-03-06 15:26:20 -08:00
* Sync BaseTools to align with edk2-stable202311 Keep the SBL specific change (e.g. Lz4). Signed-off-by: Guo Dong <guo.dong@intel.com> * feat: Sync MdePkg from EDK2 edk2-stable202311 branch Only sync required file without any changes to EDK2 files. Signed-off-by: Guo Dong <guo.dong@intel.com> * feat: Update MdePkg for SBL after sync from EDK2 Signed-off-by: Guo Dong <guo.dong@intel.com> * Update SBL after updating Basetool and MdePkg After Sync BaseTool and MdePkg to edk2-stable202311, Need update SBL code to align with this change. Signed-off-by: Guo Dong <guo.dong@intel.com> * feat: rollback some changes after mdepkg sync New change from MdePkg requires new NASM version. To make sure NASM 2.14.02 still works, just rollback few changes. Signed-off-by: Guo Dong <guo.dong@intel.com> * feat: Update component size to fix build failure After syncing BaseTool and MdePkg, some components would have a little bigger size. So update the config to fix the build failure. Signed-off-by: Guo Dong <guo.dong@intel.com> * feat: Remove unused asl code Some ASL files don't exist but they are included in other asl files. It would cause build failure with new build BaseTool. So just remove them to fix the build failure. Signed-off-by: Guo Dong <guo.dong@intel.com> --------- Signed-off-by: Guo Dong <guo.dong@intel.com>
226 lines
4.7 KiB
C
226 lines
4.7 KiB
C
/** @file
|
|
This contains some useful functions for accessing files.
|
|
|
|
Copyright (c) 2004 - 2018, Intel Corporation. All rights reserved.<BR>
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
|
|
|
**/
|
|
|
|
#include <assert.h>
|
|
#include <string.h>
|
|
#include <ctype.h>
|
|
#include <stdlib.h>
|
|
#include "CommonLib.h"
|
|
#include "MemoryFile.h"
|
|
|
|
|
|
//
|
|
// Local (static) function prototypes
|
|
//
|
|
STATIC
|
|
VOID
|
|
CheckMemoryFileState (
|
|
IN EFI_HANDLE InputMemoryFile
|
|
);
|
|
|
|
//
|
|
// Function implementations
|
|
//
|
|
|
|
/**
|
|
This opens a file, reads it into memory and returns a memory file
|
|
object.
|
|
|
|
@param InputFile Memory file image.
|
|
@param OutputMemoryFile Handle to memory file
|
|
|
|
@return EFI_STATUS
|
|
OutputMemoryFile is valid if !EFI_ERROR
|
|
**/
|
|
EFI_STATUS
|
|
GetMemoryFile (
|
|
IN CHAR8 *InputFileName,
|
|
OUT EFI_HANDLE *OutputMemoryFile
|
|
)
|
|
{
|
|
EFI_STATUS Status;
|
|
CHAR8 *InputFileImage;
|
|
UINT32 BytesRead;
|
|
MEMORY_FILE *NewMemoryFile;
|
|
|
|
Status = GetFileImage (InputFileName, &InputFileImage, &BytesRead);
|
|
if (EFI_ERROR (Status)) {
|
|
return Status;
|
|
}
|
|
|
|
NewMemoryFile = malloc (sizeof (*NewMemoryFile));
|
|
if (NewMemoryFile == NULL) {
|
|
free (InputFileImage);
|
|
return EFI_OUT_OF_RESOURCES;
|
|
}
|
|
|
|
NewMemoryFile->FileImage = InputFileImage;
|
|
NewMemoryFile->CurrentFilePointer = InputFileImage;
|
|
NewMemoryFile->Eof = InputFileImage + BytesRead;
|
|
|
|
*OutputMemoryFile = (EFI_HANDLE)NewMemoryFile;
|
|
|
|
CheckMemoryFileState (*OutputMemoryFile);
|
|
|
|
return EFI_SUCCESS;
|
|
}
|
|
|
|
/**
|
|
Frees all memory associated with the input memory file.
|
|
|
|
@param InputMemoryFile Handle to memory file
|
|
|
|
@return EFI_STATUS
|
|
**/
|
|
EFI_STATUS
|
|
FreeMemoryFile (
|
|
IN EFI_HANDLE InputMemoryFile
|
|
)
|
|
{
|
|
MEMORY_FILE *MemoryFile;
|
|
|
|
CheckMemoryFileState (InputMemoryFile);
|
|
|
|
MemoryFile = (MEMORY_FILE*)InputMemoryFile;
|
|
|
|
free (MemoryFile->FileImage);
|
|
|
|
//
|
|
// Invalidate state of MEMORY_FILE structure to catch invalid usage.
|
|
//
|
|
memset (MemoryFile, 0xcc, sizeof (*MemoryFile));
|
|
MemoryFile->Eof -= 1;
|
|
|
|
free (MemoryFile);
|
|
|
|
return EFI_SUCCESS;
|
|
}
|
|
|
|
/**
|
|
This function reads a line from the memory file. The newline characters
|
|
are stripped and a null terminated string is returned.
|
|
|
|
If the string pointer returned is non-NULL, then the caller must free the
|
|
memory associated with this string.
|
|
|
|
@param InputMemoryFile Handle to memory file
|
|
|
|
@retval NULL if error or EOF
|
|
@retval NULL character termincated string otherwise (MUST BE FREED BY CALLER)
|
|
**/
|
|
CHAR8 *
|
|
ReadMemoryFileLine (
|
|
IN EFI_HANDLE InputMemoryFile
|
|
)
|
|
{
|
|
CHAR8 *EndOfLine;
|
|
UINTN CharsToCopy;
|
|
MEMORY_FILE *InputFile;
|
|
UINTN BytesToEof;
|
|
CHAR8 *OutputString;
|
|
|
|
//
|
|
// Verify input parameters are not null
|
|
//
|
|
CheckMemoryFileState (InputMemoryFile);
|
|
|
|
InputFile = (MEMORY_FILE*)InputMemoryFile;
|
|
|
|
//
|
|
// Check for end of file condition
|
|
//
|
|
if (InputFile->CurrentFilePointer >= InputFile->Eof) {
|
|
return NULL;
|
|
}
|
|
|
|
//
|
|
// Determine the number of bytes remaining until the EOF
|
|
//
|
|
BytesToEof = InputFile->Eof - InputFile->CurrentFilePointer;
|
|
|
|
//
|
|
// Find the next newline char
|
|
//
|
|
EndOfLine = memchr (InputFile->CurrentFilePointer, '\n', BytesToEof);
|
|
|
|
//
|
|
// Determine the number of characters to copy.
|
|
//
|
|
if (EndOfLine == 0) {
|
|
//
|
|
// If no newline found, copy to the end of the file.
|
|
//
|
|
CharsToCopy = InputFile->Eof - InputFile->CurrentFilePointer;
|
|
} else {
|
|
//
|
|
// Newline found in the file.
|
|
//
|
|
CharsToCopy = EndOfLine - InputFile->CurrentFilePointer;
|
|
}
|
|
|
|
OutputString = malloc (CharsToCopy + 1);
|
|
if (OutputString == NULL) {
|
|
return NULL;
|
|
}
|
|
|
|
//
|
|
// Copy the line.
|
|
//
|
|
memcpy (OutputString, InputFile->CurrentFilePointer, CharsToCopy);
|
|
|
|
//
|
|
// Add the null termination over the 0x0D
|
|
//
|
|
if (OutputString[CharsToCopy - 1] == '\r') {
|
|
|
|
OutputString[CharsToCopy - 1] = '\0';
|
|
|
|
} else {
|
|
|
|
OutputString[CharsToCopy] = '\0';
|
|
|
|
}
|
|
|
|
//
|
|
// Increment the current file pointer (include the 0x0A)
|
|
//
|
|
InputFile->CurrentFilePointer += CharsToCopy + 1;
|
|
if (InputFile->CurrentFilePointer > InputFile->Eof) {
|
|
InputFile->CurrentFilePointer = InputFile->Eof;
|
|
}
|
|
CheckMemoryFileState (InputMemoryFile);
|
|
|
|
//
|
|
// Return the string
|
|
//
|
|
return OutputString;
|
|
}
|
|
|
|
|
|
STATIC
|
|
VOID
|
|
CheckMemoryFileState (
|
|
IN EFI_HANDLE InputMemoryFile
|
|
)
|
|
{
|
|
MEMORY_FILE *MemoryFile;
|
|
|
|
assert (InputMemoryFile != NULL);
|
|
|
|
MemoryFile = (MEMORY_FILE*)InputMemoryFile;
|
|
|
|
assert (MemoryFile->FileImage != NULL);
|
|
assert (MemoryFile->CurrentFilePointer != NULL);
|
|
assert (MemoryFile->Eof != NULL);
|
|
assert (MemoryFile->Eof >= MemoryFile->FileImage);
|
|
assert (MemoryFile->CurrentFilePointer >= MemoryFile->FileImage);
|
|
assert (MemoryFile->CurrentFilePointer <= MemoryFile->Eof);
|
|
}
|
|
|
|
|