blob: 77d7622c8966d24555c2ca07e5e03846cfd0101b [file] [log] [blame]
/** @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 } \
}
typedef struct _EFI_PEI_MM_CONFIGURATION_PPI EFI_PEI_MM_CONFIGURATION_PPI;
/**
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
(EFIAPI *EFI_PEI_MM_REGISTER_MM_ENTRY)(
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 {
EFI_MM_RESERVED_MMRAM_REGION *MmramReservedRegions;
EFI_PEI_MM_REGISTER_MM_ENTRY RegisterMmEntry;
};
extern EFI_GUID gEfiPeiMmConfigurationPpi;
#endif