2011-05-11 20:31:20 +02:00
|
|
|
/** @file
|
|
|
|
Emulator Thunk to abstract OS services from pure EFI code
|
|
|
|
|
|
|
|
Copyright (c) 2008 - 2011, Apple Inc. All rights reserved.<BR>
|
2011-06-20 23:58:05 +02:00
|
|
|
Copyright (c) 2011, Intel Corporation. All rights reserved.<BR>
|
2011-06-28 18:50:26 +02:00
|
|
|
|
2019-04-04 01:03:44 +02:00
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
2011-05-11 20:31:20 +02:00
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
#include <PiPei.h>
|
|
|
|
#include <Library/BaseLib.h>
|
2011-06-20 23:58:05 +02:00
|
|
|
#include <Library/MemoryAllocationLib.h>
|
2011-05-11 20:31:20 +02:00
|
|
|
|
|
|
|
UINTN gThunkPpiListSize = 0;
|
|
|
|
EFI_PEI_PPI_DESCRIPTOR *gThunkPpiList = NULL;
|
|
|
|
|
|
|
|
EFI_PEI_PPI_DESCRIPTOR *
|
|
|
|
GetThunkPpiList (
|
|
|
|
VOID
|
|
|
|
)
|
|
|
|
{
|
|
|
|
UINTN Index;
|
2011-06-28 18:50:26 +02:00
|
|
|
|
2011-05-11 20:31:20 +02:00
|
|
|
if (gThunkPpiList == NULL) {
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
Index = (gThunkPpiListSize/sizeof (EFI_PEI_PPI_DESCRIPTOR)) - 1;
|
|
|
|
gThunkPpiList[Index].Flags |= EFI_PEI_PPI_DESCRIPTOR_TERMINATE_LIST;
|
2011-06-28 18:50:26 +02:00
|
|
|
|
2011-05-11 20:31:20 +02:00
|
|
|
return gThunkPpiList;
|
|
|
|
}
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
AddThunkPpi (
|
|
|
|
IN UINTN Flags,
|
|
|
|
IN EFI_GUID *Guid,
|
|
|
|
IN VOID *Ppi
|
|
|
|
)
|
|
|
|
{
|
|
|
|
UINTN Index;
|
2011-06-20 23:58:05 +02:00
|
|
|
|
|
|
|
gThunkPpiList = ReallocatePool (
|
|
|
|
gThunkPpiListSize,
|
|
|
|
gThunkPpiListSize + sizeof (EFI_PEI_PPI_DESCRIPTOR),
|
|
|
|
gThunkPpiList
|
|
|
|
);
|
2011-05-11 20:31:20 +02:00
|
|
|
if (gThunkPpiList == NULL) {
|
|
|
|
return EFI_OUT_OF_RESOURCES;
|
|
|
|
}
|
2011-06-28 18:50:26 +02:00
|
|
|
|
2011-05-11 20:31:20 +02:00
|
|
|
Index = (gThunkPpiListSize/sizeof (EFI_PEI_PPI_DESCRIPTOR));
|
|
|
|
gThunkPpiList[Index].Flags = Flags;
|
|
|
|
gThunkPpiList[Index].Guid = Guid;
|
|
|
|
gThunkPpiList[Index].Ppi = Ppi;
|
|
|
|
gThunkPpiListSize += sizeof (EFI_PEI_PPI_DESCRIPTOR);
|
|
|
|
|
|
|
|
return EFI_SUCCESS;
|
|
|
|
}
|