2017-08-28 08:20:31 +02:00
|
|
|
/** @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.<BR>
|
2019-04-04 01:06:00 +02:00
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
2017-08-28 08:20:31 +02:00
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
#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,
|
|
|
|
IN CONST EFI_GUID *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
|
|
|
|
|