mirror of https://github.com/acidanthera/audk.git
68 lines
2.9 KiB
C
68 lines
2.9 KiB
C
/** @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, Intel Corporation
|
|
All rights reserved. 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__
|
|
|
|
#include <Uefi/UefiBaseType.h>
|
|
#include <Pi/PiMultiPhase.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
|
|
|