2021-06-24 05:33:08 +02:00
|
|
|
/** @file
|
|
|
|
EFI MM Configuration PPI as defined in PI 1.5 specification.
|
|
|
|
|
|
|
|
This PPI is used to:
|
|
|
|
1) report the portions of MMRAM regions which cannot be used for the MMRAM heap.
|
|
|
|
2) register the MM Foundation entry point with the processor code. The entry
|
|
|
|
point will be invoked by the MM processor entry code.
|
|
|
|
|
|
|
|
Copyright (c) Microsoft Corporation.
|
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
#ifndef MM_CONFIGURATION_PPI_H_
|
|
|
|
#define MM_CONFIGURATION_PPI_H_
|
|
|
|
|
|
|
|
#include <Pi/PiMultiPhase.h>
|
|
|
|
|
|
|
|
#define EFI_PEI_MM_CONFIGURATION_PPI_GUID \
|
|
|
|
{ \
|
|
|
|
0xc109319, 0xc149, 0x450e, { 0xa3, 0xe3, 0xb9, 0xba, 0xdd, 0x9d, 0xc3, 0xa4 } \
|
|
|
|
}
|
|
|
|
|
2021-12-05 23:54:05 +01:00
|
|
|
typedef struct _EFI_PEI_MM_CONFIGURATION_PPI EFI_PEI_MM_CONFIGURATION_PPI;
|
2021-06-24 05:33:08 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
This function registers the MM Foundation entry point with the processor code. This entry point will be
|
|
|
|
invoked by the MM Processor entry code as defined in PI specification.
|
|
|
|
|
|
|
|
@param[in] This The EFI_PEI_MM_CONFIGURATION_PPI instance.
|
|
|
|
@param[in] MmEntryPoint MM Foundation entry point.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS The entry-point was successfully registered.
|
|
|
|
|
|
|
|
**/
|
|
|
|
typedef
|
|
|
|
EFI_STATUS
|
2021-12-05 23:54:05 +01:00
|
|
|
(EFIAPI *EFI_PEI_MM_REGISTER_MM_ENTRY)(
|
2021-06-24 05:33:08 +02:00
|
|
|
IN CONST EFI_PEI_MM_CONFIGURATION_PPI *This,
|
|
|
|
IN EFI_MM_ENTRY_POINT MmEntryPoint
|
|
|
|
);
|
|
|
|
|
|
|
|
///
|
|
|
|
/// This PPI is a PPI published by a CPU PEIM to indicate which areas within MMRAM are reserved for use by
|
|
|
|
/// the CPU for any purpose, such as stack, save state or MM entry point. If a platform chooses to let a CPU
|
|
|
|
/// PEIM do MMRAM relocation, this PPI must be produced by this CPU PEIM.
|
|
|
|
///
|
|
|
|
/// The MmramReservedRegions points to an array of one or more EFI_MM_RESERVED_MMRAM_REGION structures, with
|
|
|
|
/// the last structure having the MmramReservedSize set to 0. An empty array would contain only the last
|
|
|
|
/// structure.
|
|
|
|
///
|
|
|
|
/// The RegisterMmEntry() function allows the MM IPL PEIM to register the MM Foundation entry point with the
|
|
|
|
/// MM entry vector code.
|
|
|
|
///
|
|
|
|
struct _EFI_PEI_MM_CONFIGURATION_PPI {
|
2021-12-05 23:54:05 +01:00
|
|
|
EFI_MM_RESERVED_MMRAM_REGION *MmramReservedRegions;
|
|
|
|
EFI_PEI_MM_REGISTER_MM_ENTRY RegisterMmEntry;
|
2021-06-24 05:33:08 +02:00
|
|
|
};
|
|
|
|
|
2021-12-05 23:54:05 +01:00
|
|
|
extern EFI_GUID gEfiPeiMmConfigurationPpi;
|
2021-06-24 05:33:08 +02:00
|
|
|
|
|
|
|
#endif
|