/** @file EFI MM Status Code Protocol as defined in the PI 1.5 specification. This protocol provides the basic status code services while in MM. Copyright (c) 2017, Intel Corporation. All rights reserved.
SPDX-License-Identifier: BSD-2-Clause-Patent **/ #ifndef _MM_STATUS_CODE_H__ #define _MM_STATUS_CODE_H__ #define EFI_MM_STATUS_CODE_PROTOCOL_GUID \ { \ 0x6afd2b77, 0x98c1, 0x4acd, {0xa6, 0xf9, 0x8a, 0x94, 0x39, 0xde, 0xf, 0xb1} \ } typedef struct _EFI_MM_STATUS_CODE_PROTOCOL EFI_MM_STATUS_CODE_PROTOCOL; /** Service to emit the status code in MM. The EFI_MM_STATUS_CODE_PROTOCOL.ReportStatusCode() function enables a driver to emit a status code while in MM. The reason that there is a separate protocol definition from the DXE variant of this service is that the publisher of this protocol will provide a service that is capability of coexisting with a foreground operational environment, such as an operating system after the termination of boot services. @param[in] This Points to this instance of the EFI_MM_STATUS_CODE_PROTOCOL. @param[in] CodeType DIndicates the type of status code being reported. @param[in] Value Describes the current status of a hardware or software entity. @param[in] Instance The enumeration of a hardware or software entity within the system. @param[in] CallerId This optional parameter may be used to identify the caller. @param[in] Data This optional parameter may be used to pass additional data. @retval EFI_SUCCESS The function completed successfully. @retval EFI_INVALID_PARAMETER The function should not be completed due to a device error. **/ typedef EFI_STATUS (EFIAPI *EFI_MM_REPORT_STATUS_CODE)( IN CONST EFI_MM_STATUS_CODE_PROTOCOL *This, IN EFI_STATUS_CODE_TYPE CodeType, IN EFI_STATUS_CODE_VALUE Value, IN UINT32 Instance, CONST_EFI_GUID_PTR_T CallerId, IN EFI_STATUS_CODE_DATA *Data OPTIONAL ); struct _EFI_MM_STATUS_CODE_PROTOCOL { EFI_MM_REPORT_STATUS_CODE ReportStatusCode; }; extern EFI_GUID gEfiMmStatusCodeProtocolGuid; #endif