2012-03-27 10:17:23 +02:00
|
|
|
/** @file
|
|
|
|
Helper functions for SecureBoot configuration module.
|
|
|
|
|
2018-06-27 15:13:09 +02:00
|
|
|
Copyright (c) 2015 - 2018, Intel Corporation. All rights reserved.<BR>
|
2019-04-04 01:06:56 +02:00
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
2012-03-27 10:17:23 +02:00
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
#include "SecureBootConfigImpl.h"
|
|
|
|
|
|
|
|
/**
|
2018-06-27 15:13:09 +02:00
|
|
|
Read file content into BufferPtr, the size of the allocate buffer
|
2019-10-09 09:20:15 +02:00
|
|
|
is *FileSize plus AdditionAllocateSize.
|
2012-03-27 10:17:23 +02:00
|
|
|
|
|
|
|
@param[in] FileHandle The file to be read.
|
|
|
|
@param[in, out] BufferPtr Pointers to the pointer of allocated buffer.
|
|
|
|
@param[out] FileSize Size of input file
|
2019-10-09 09:20:15 +02:00
|
|
|
@param[in] AdditionAllocateSize Addition size the buffer need to be allocated.
|
2012-03-27 10:17:23 +02:00
|
|
|
In case the buffer need to contain others besides the file content.
|
2018-06-27 15:13:09 +02:00
|
|
|
|
2012-03-27 10:17:23 +02:00
|
|
|
@retval EFI_SUCCESS The file was read into the buffer.
|
|
|
|
@retval EFI_INVALID_PARAMETER A parameter was invalid.
|
|
|
|
@retval EFI_OUT_OF_RESOURCES A memory allocation failed.
|
|
|
|
@retval others Unexpected error.
|
|
|
|
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
ReadFileContent (
|
|
|
|
IN EFI_FILE_HANDLE FileHandle,
|
|
|
|
IN OUT VOID **BufferPtr,
|
|
|
|
OUT UINTN *FileSize,
|
2019-10-09 09:20:15 +02:00
|
|
|
IN UINTN AdditionAllocateSize
|
2012-03-27 10:17:23 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
{
|
|
|
|
UINTN BufferSize;
|
|
|
|
UINT64 SourceFileSize;
|
|
|
|
VOID *Buffer;
|
|
|
|
EFI_STATUS Status;
|
|
|
|
|
|
|
|
if ((FileHandle == NULL) || (FileSize == NULL)) {
|
|
|
|
return EFI_INVALID_PARAMETER;
|
|
|
|
}
|
|
|
|
|
|
|
|
Buffer = NULL;
|
|
|
|
|
|
|
|
//
|
|
|
|
// Get the file size
|
|
|
|
//
|
|
|
|
Status = FileHandle->SetPosition (FileHandle, (UINT64)-1);
|
|
|
|
if (EFI_ERROR (Status)) {
|
|
|
|
goto ON_EXIT;
|
|
|
|
}
|
|
|
|
|
|
|
|
Status = FileHandle->GetPosition (FileHandle, &SourceFileSize);
|
|
|
|
if (EFI_ERROR (Status)) {
|
|
|
|
goto ON_EXIT;
|
|
|
|
}
|
2018-06-27 15:13:09 +02:00
|
|
|
|
2012-03-27 10:17:23 +02:00
|
|
|
Status = FileHandle->SetPosition (FileHandle, 0);
|
|
|
|
if (EFI_ERROR (Status)) {
|
|
|
|
goto ON_EXIT;
|
|
|
|
}
|
|
|
|
|
2019-10-09 09:20:15 +02:00
|
|
|
BufferSize = (UINTN)SourceFileSize + AdditionAllocateSize;
|
2012-03-27 10:17:23 +02:00
|
|
|
Buffer = AllocateZeroPool (BufferSize);
|
|
|
|
if (Buffer == NULL) {
|
|
|
|
return EFI_OUT_OF_RESOURCES;
|
|
|
|
}
|
|
|
|
|
|
|
|
BufferSize = (UINTN)SourceFileSize;
|
|
|
|
*FileSize = BufferSize;
|
|
|
|
|
|
|
|
Status = FileHandle->Read (FileHandle, &BufferSize, Buffer);
|
|
|
|
if (EFI_ERROR (Status) || (BufferSize != *FileSize)) {
|
|
|
|
FreePool (Buffer);
|
|
|
|
Buffer = NULL;
|
|
|
|
Status = EFI_BAD_BUFFER_SIZE;
|
|
|
|
goto ON_EXIT;
|
|
|
|
}
|
|
|
|
|
|
|
|
ON_EXIT:
|
2018-06-27 15:13:09 +02:00
|
|
|
|
2012-03-27 10:17:23 +02:00
|
|
|
*BufferPtr = Buffer;
|
|
|
|
return Status;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
Close an open file handle.
|
|
|
|
|
|
|
|
@param[in] FileHandle The file handle to close.
|
2018-06-27 15:13:09 +02:00
|
|
|
|
2012-03-27 10:17:23 +02:00
|
|
|
**/
|
|
|
|
VOID
|
|
|
|
CloseFile (
|
|
|
|
IN EFI_FILE_HANDLE FileHandle
|
|
|
|
)
|
|
|
|
{
|
|
|
|
if (FileHandle != NULL) {
|
2018-06-27 15:13:09 +02:00
|
|
|
FileHandle->Close (FileHandle);
|
2012-03-27 10:17:23 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
Convert a nonnegative integer to an octet string of a specified length.
|
|
|
|
|
|
|
|
@param[in] Integer Pointer to the nonnegative integer to be converted
|
|
|
|
@param[in] IntSizeInWords Length of integer buffer in words
|
2018-06-27 15:13:09 +02:00
|
|
|
@param[out] OctetString Converted octet string of the specified length
|
2012-03-27 10:17:23 +02:00
|
|
|
@param[in] OSSizeInBytes Intended length of resulting octet string in bytes
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS Data conversion successfully
|
|
|
|
@retval EFI_BUFFER_TOOL_SMALL Buffer is too small for output string
|
|
|
|
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
Int2OctStr (
|
|
|
|
IN CONST UINTN *Integer,
|
|
|
|
IN UINTN IntSizeInWords,
|
|
|
|
OUT UINT8 *OctetString,
|
|
|
|
IN UINTN OSSizeInBytes
|
|
|
|
)
|
|
|
|
{
|
|
|
|
CONST UINT8 *Ptr1;
|
|
|
|
UINT8 *Ptr2;
|
|
|
|
|
|
|
|
for (Ptr1 = (CONST UINT8 *)Integer, Ptr2 = OctetString + OSSizeInBytes - 1;
|
|
|
|
Ptr1 < (UINT8 *)(Integer + IntSizeInWords) && Ptr2 >= OctetString;
|
|
|
|
Ptr1++, Ptr2--)
|
|
|
|
{
|
|
|
|
*Ptr2 = *Ptr1;
|
|
|
|
}
|
2018-06-27 15:13:09 +02:00
|
|
|
|
2012-03-27 10:17:23 +02:00
|
|
|
for ( ; Ptr1 < (CONST UINT8 *)(Integer + IntSizeInWords) && *Ptr1 == 0; Ptr1++) {
|
2021-12-05 23:54:12 +01:00
|
|
|
}
|
2018-06-27 15:13:09 +02:00
|
|
|
|
2012-03-27 10:17:23 +02:00
|
|
|
if (Ptr1 < (CONST UINT8 *)(Integer + IntSizeInWords)) {
|
|
|
|
return EFI_BUFFER_TOO_SMALL;
|
|
|
|
}
|
2018-06-27 15:13:09 +02:00
|
|
|
|
2012-03-27 10:17:23 +02:00
|
|
|
if (Ptr2 >= OctetString) {
|
|
|
|
ZeroMem (OctetString, Ptr2 - OctetString + 1);
|
|
|
|
}
|
2018-06-27 15:13:09 +02:00
|
|
|
|
2012-03-27 10:17:23 +02:00
|
|
|
return EFI_SUCCESS;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
Worker function that prints an EFI_GUID into specified Buffer.
|
|
|
|
|
|
|
|
@param[in] Guid Pointer to GUID to print.
|
|
|
|
@param[in] Buffer Buffer to print Guid into.
|
|
|
|
@param[in] BufferSize Size of Buffer.
|
2018-06-27 15:13:09 +02:00
|
|
|
|
2012-03-27 10:17:23 +02:00
|
|
|
@retval Number of characters printed.
|
|
|
|
|
|
|
|
**/
|
|
|
|
UINTN
|
|
|
|
GuidToString (
|
|
|
|
IN EFI_GUID *Guid,
|
|
|
|
IN CHAR16 *Buffer,
|
|
|
|
IN UINTN BufferSize
|
|
|
|
)
|
|
|
|
{
|
|
|
|
UINTN Size;
|
|
|
|
|
|
|
|
Size = UnicodeSPrint (
|
|
|
|
Buffer,
|
2018-06-27 15:13:09 +02:00
|
|
|
BufferSize,
|
2012-03-27 10:17:23 +02:00
|
|
|
L"%08x-%04x-%04x-%02x%02x-%02x%02x%02x%02x%02x%02x",
|
2018-06-27 15:13:09 +02:00
|
|
|
(UINTN)Guid->Data1,
|
2012-03-27 10:17:23 +02:00
|
|
|
(UINTN)Guid->Data2,
|
|
|
|
(UINTN)Guid->Data3,
|
|
|
|
(UINTN)Guid->Data4[0],
|
|
|
|
(UINTN)Guid->Data4[1],
|
|
|
|
(UINTN)Guid->Data4[2],
|
|
|
|
(UINTN)Guid->Data4[3],
|
|
|
|
(UINTN)Guid->Data4[4],
|
|
|
|
(UINTN)Guid->Data4[5],
|
|
|
|
(UINTN)Guid->Data4[6],
|
|
|
|
(UINTN)Guid->Data4[7]
|
|
|
|
);
|
|
|
|
|
|
|
|
//
|
|
|
|
// SPrint will null terminate the string. The -1 skips the null
|
|
|
|
//
|
|
|
|
return Size - 1;
|
|
|
|
}
|