summaryrefslogtreecommitdiffstats
path: root/MdePkg/Include/Protocol/MmStatusCode.h
blob: 771cbee2d602f0bb3691491ae8f0035ad0c01a0f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
/** @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>
  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,
  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