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
|
|
|
|
2008-11-14 04:45:34 +01:00
|
|
|
Copyright (c) 2006 - 2008, Intel Corporation<BR>
|
2007-06-19 12:55:24 +02:00
|
|
|
All rights reserved. This program and the accompanying materials
|
|
|
|
are licensed and made available under the terms and conditions of the BSD License
|
|
|
|
which accompanies this distribution. The full text of the license may be found at
|
|
|
|
http://opensource.org/licenses/bsd-license.php
|
|
|
|
|
|
|
|
THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
|
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
#ifndef __MODULE_ENTRY_POINT_H__
|
|
|
|
#define __MODULE_ENTRY_POINT_H__
|
|
|
|
|
|
|
|
/**
|
2007-06-22 18:22:26 +02:00
|
|
|
|
2007-06-19 12:55:24 +02:00
|
|
|
Enrty point to PEI core.
|
|
|
|
|
2007-06-22 18:22:26 +02: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, the stack
|
|
|
|
location and the BFV location. The type
|
|
|
|
EFI_SEC_PEI_HAND_OFF is
|
|
|
|
|
|
|
|
@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
|
|
|
|
EFIAPI
|
|
|
|
_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-07-21 09:53:14 +02: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, the stack
|
|
|
|
location and the BFV location. The type
|
|
|
|
EFI_SEC_PEI_HAND_OFF is
|
|
|
|
|
|
|
|
@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
|
|
|
|
|
|
|
@return Status returned by entry points of core and drivers.
|
|
|
|
|
|
|
|
**/
|
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.
|
|
|
|
|
|
|
|
This function must be called by the PEI Core once an initial PEI Services Table has
|
|
|
|
been established.
|
2007-06-19 12:55:24 +02:00
|
|
|
|
2008-11-04 15:16:02 +01:00
|
|
|
@param FileHandle Handle of the file being invoked.
|
|
|
|
Type EFI_PEI_FILE_HANDLE is defined in FfsFindNextFile().
|
2007-06-19 12:55:24 +02:00
|
|
|
@param PeiServices Pointer to the PEI Services Table.
|
|
|
|
|
|
|
|
**/
|
|
|
|
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().
|
2007-06-19 12:55:24 +02:00
|
|
|
|
2008-07-21 09:53:14 +02: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, the stack
|
|
|
|
location and the BFV location. The type
|
|
|
|
EFI_SEC_PEI_HAND_OFF is
|
|
|
|
|
|
|
|
@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.
|
|
|
|
@param OldCoreData Pointer to Original startup information.
|
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,
|
|
|
|
IN VOID *OldCoreData
|
|
|
|
);
|
|
|
|
|
|
|
|
#endif
|