2007-06-19 12:55:24 +02:00
|
|
|
/** @file
|
2008-11-14 04:45:34 +01:00
|
|
|
Module entry point library for PEI core.
|
2007-06-19 12:55:24 +02:00
|
|
|
|
2018-06-27 15:11:33 +02:00
|
|
|
Copyright (c) 2006 - 2018, Intel Corporation. All rights reserved.<BR>
|
2019-04-04 01:06:00 +02:00
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
2007-06-19 12:55:24 +02:00
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
#ifndef __MODULE_ENTRY_POINT_H__
|
|
|
|
#define __MODULE_ENTRY_POINT_H__
|
|
|
|
|
|
|
|
/**
|
2008-11-26 05:36:05 +01:00
|
|
|
The entry point of PE/COFF Image for the PEI Core.
|
|
|
|
|
|
|
|
This function is the entry point for the PEI Foundation, which allows the SEC phase
|
|
|
|
to pass information about the stack, temporary RAM and the Boot Firmware Volume.
|
|
|
|
In addition, it also allows the SEC phase to pass services and data forward for use
|
|
|
|
during the PEI phase in the form of one or more PPIs.
|
|
|
|
There is no limit to the number of additional PPIs that can be passed from SEC into
|
|
|
|
the PEI Foundation. As part of its initialization phase, the PEI Foundation will add
|
|
|
|
these SEC-hosted PPIs to its PPI database such that both the PEI Foundation and any
|
|
|
|
modules can leverage the associated service calls and/or code in these early PPIs.
|
|
|
|
This function is required to call ProcessModuleEntryPointList() with the Context
|
|
|
|
parameter set to NULL. ProcessModuleEntryPoint() is never expected to return.
|
|
|
|
The PEI Core is responsible for calling ProcessLibraryConstructorList() as soon as
|
|
|
|
the PEI Services Table and the file handle for the PEI Core itself have been established.
|
|
|
|
If ProcessModuleEntryPointList() returns, then ASSERT() and halt the system.
|
|
|
|
|
|
|
|
@param SecCoreData Points to a data structure containing information about the PEI
|
|
|
|
core's operating environment, such as the size and location of
|
2018-06-27 15:11:33 +02:00
|
|
|
temporary RAM, the stack location and the BFV location.
|
2008-11-26 05:36:05 +01:00
|
|
|
|
|
|
|
@param PpiList Points to a list of one or more PPI descriptors to be installed
|
|
|
|
initially by the PEI core. An empty PPI list consists of a single
|
|
|
|
descriptor with the end-tag EFI_PEI_PPI_DESCRIPTOR_TERMINATE_LIST.
|
|
|
|
As part of its initialization phase, the PEI Foundation will add
|
|
|
|
these SEC-hosted PPIs to its PPI database such that both the PEI
|
|
|
|
Foundation and any modules can leverage the associated service calls
|
|
|
|
and/or code in these early PPIs.
|
2007-06-19 12:55:24 +02:00
|
|
|
|
|
|
|
**/
|
2007-06-22 18:22:26 +02:00
|
|
|
VOID
|
2018-06-27 15:11:33 +02:00
|
|
|
EFIAPI
|
2007-06-22 18:22:26 +02:00
|
|
|
_ModuleEntryPoint(
|
2007-06-19 12:55:24 +02:00
|
|
|
IN CONST EFI_SEC_PEI_HAND_OFF *SecCoreData,
|
|
|
|
IN CONST EFI_PEI_PPI_DESCRIPTOR *PpiList
|
2008-10-26 11:05:12 +01:00
|
|
|
);
|
2007-06-19 12:55:24 +02:00
|
|
|
|
|
|
|
/**
|
2008-11-19 09:52:23 +01:00
|
|
|
Required by the EBC compiler and identical in functionality to _ModuleEntryPoint().
|
|
|
|
|
|
|
|
This function is required to call _ModuleEntryPoint() passing in SecCoreData and PpiList.
|
2007-06-19 12:55:24 +02:00
|
|
|
|
2008-11-26 05:36:05 +01:00
|
|
|
@param SecCoreData Points to a data structure containing information about the PEI core's
|
|
|
|
operating environment, such as the size and location of temporary RAM,
|
2018-06-27 15:11:33 +02:00
|
|
|
the stack location and the BFV location.
|
2008-11-26 05:36:05 +01:00
|
|
|
|
|
|
|
@param PpiList Points to a list of one or more PPI descriptors to be installed
|
|
|
|
initially by the PEI core. An empty PPI list consists of a single
|
|
|
|
descriptor with the end-tag EFI_PEI_PPI_DESCRIPTOR_TERMINATE_LIST.
|
|
|
|
As part of its initialization phase, the PEI Foundation will add these
|
|
|
|
SEC-hosted PPIs to its PPI database such that both the PEI Foundation
|
|
|
|
and any modules can leverage the associated service calls and/or code
|
|
|
|
in these early PPIs.
|
2007-06-19 12:55:24 +02:00
|
|
|
|
|
|
|
**/
|
2007-06-22 18:22:26 +02:00
|
|
|
VOID
|
2007-06-19 12:55:24 +02:00
|
|
|
EFIAPI
|
|
|
|
EfiMain (
|
|
|
|
IN CONST EFI_SEC_PEI_HAND_OFF *SecCoreData,
|
|
|
|
IN CONST EFI_PEI_PPI_DESCRIPTOR *PpiList
|
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
2008-11-19 09:52:23 +01:00
|
|
|
Autogenerated function that calls the library constructors for all of the module's
|
|
|
|
dependent libraries.
|
|
|
|
|
2008-11-26 05:36:05 +01:00
|
|
|
This function must be called by the PEI Core once an initial PEI Services Table has been established.
|
|
|
|
This function calls the set of library constructors for the set of library instances that a
|
|
|
|
module depends on. This include library instances that a module depends on directly and library
|
2018-06-27 15:11:33 +02:00
|
|
|
instances that a module depends on indirectly through other libraries.
|
2008-11-26 05:36:05 +01:00
|
|
|
This function is autogenerated by build tools and those build tools are responsible for collecting
|
2009-06-04 18:16:15 +02:00
|
|
|
the set of library instances, determining which ones have constructors, and calling the library
|
|
|
|
constructors in the proper order based upon the dependencies of each of the library instances.
|
2008-11-26 05:36:05 +01:00
|
|
|
The PEI Core must call this function with a NULL FileHandle value as soon as the initial PEI
|
|
|
|
Services Table has been established.
|
2007-06-19 12:55:24 +02:00
|
|
|
|
2008-12-12 09:51:16 +01:00
|
|
|
@param FileHandle Handle of the file being invoked.
|
2008-11-26 05:36:05 +01:00
|
|
|
@param PeiServices Describes the list of possible PEI Services.
|
2007-06-19 12:55:24 +02:00
|
|
|
|
|
|
|
**/
|
|
|
|
VOID
|
|
|
|
EFIAPI
|
|
|
|
ProcessLibraryConstructorList (
|
2008-10-28 10:07:50 +01:00
|
|
|
IN EFI_PEI_FILE_HANDLE FileHandle,
|
|
|
|
IN CONST EFI_PEI_SERVICES **PeiServices
|
2007-06-19 12:55:24 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
2008-11-19 09:52:23 +01:00
|
|
|
Autogenerated function that calls a set of module entry points.
|
|
|
|
|
|
|
|
This function must be called by _ModuleEntryPoint().
|
2018-06-27 15:11:33 +02:00
|
|
|
This function calls the set of module entry points.
|
2008-11-26 05:36:05 +01:00
|
|
|
This function is autogenerated by build tools and those build tools are responsible
|
|
|
|
for collecting the module entry points and calling them in a specified order.
|
|
|
|
|
|
|
|
@param SecCoreData Points to a data structure containing information about the PEI
|
|
|
|
core's operating environment, such as the size and location of
|
2018-06-27 15:11:33 +02:00
|
|
|
temporary RAM, the stack location and the BFV location.
|
2008-11-26 05:36:05 +01:00
|
|
|
|
|
|
|
@param PpiList Points to a list of one or more PPI descriptors to be installed
|
|
|
|
initially by the PEI core. An empty PPI list consists of a single
|
|
|
|
descriptor with the end-tag EFI_PEI_PPI_DESCRIPTOR_TERMINATE_LIST.
|
|
|
|
As part of its initialization phase, the PEI Foundation will add
|
|
|
|
these SEC-hosted PPIs to its PPI database such that both the PEI
|
|
|
|
Foundation and any modules can leverage the associated service calls
|
2018-06-27 15:11:33 +02:00
|
|
|
and/or code in these early PPIs.
|
2008-12-15 04:22:57 +01:00
|
|
|
@param Context A pointer to a private context structure defined by the PEI Core
|
|
|
|
implementation. The implementation of _ModuleEntryPoint() must set
|
|
|
|
this parameter is NULL to indicate that this is the first PEI phase.
|
2007-06-19 12:55:24 +02:00
|
|
|
|
|
|
|
**/
|
2007-06-22 18:22:26 +02:00
|
|
|
VOID
|
2007-06-19 12:55:24 +02:00
|
|
|
EFIAPI
|
|
|
|
ProcessModuleEntryPointList (
|
|
|
|
IN CONST EFI_SEC_PEI_HAND_OFF *SecCoreData,
|
|
|
|
IN CONST EFI_PEI_PPI_DESCRIPTOR *PpiList,
|
2008-12-15 04:22:57 +01:00
|
|
|
IN VOID *Context
|
2007-06-19 12:55:24 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
#endif
|