/** @file | |
EFI SMM Status Code Protocol as defined in the PI 1.2 specification. | |
This protocol provides the basic status code services while in SMM. | |
Copyright (c) 2009 - 2010, Intel Corporation. All rights reserved.<BR> | |
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 _SMM_STATUS_CODE_H__ | |
#define _SMM_STATUS_CODE_H__ | |
#define EFI_SMM_STATUS_CODE_PROTOCOL_GUID \ | |
{ \ | |
0x6afd2b77, 0x98c1, 0x4acd, {0xa6, 0xf9, 0x8a, 0x94, 0x39, 0xde, 0xf, 0xb1} \ | |
} | |
typedef struct _EFI_SMM_STATUS_CODE_PROTOCOL EFI_SMM_STATUS_CODE_PROTOCOL; | |
/** | |
Service to emit the status code in SMM. | |
The EFI_SMM_STATUS_CODE_PROTOCOL.ReportStatusCode() function enables a driver | |
to emit a status code while in SMM. 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_SMM_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_SMM_REPORT_STATUS_CODE)( | |
IN CONST EFI_SMM_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_SMM_STATUS_CODE_PROTOCOL { | |
EFI_SMM_REPORT_STATUS_CODE ReportStatusCode; | |
}; | |
extern EFI_GUID gEfiSmmStatusCodeProtocolGuid; | |
#endif | |