]> git.proxmox.com Git - mirror_edk2.git/commitdiff
Move those status code definitions that exactly match the PI 1.2 Specification from...
authormdkinney <mdkinney@6f19259b-4bc3-4df7-8a09-765794883524>
Fri, 24 Jul 2009 03:26:30 +0000 (03:26 +0000)
committermdkinney <mdkinney@6f19259b-4bc3-4df7-8a09-765794883524>
Fri, 24 Jul 2009 03:26:30 +0000 (03:26 +0000)
git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@8988 6f19259b-4bc3-4df7-8a09-765794883524

MdePkg/Include/Guid/StatusCodeDataTypeId.h [new file with mode: 0644]
MdePkg/Include/Pi/PiMultiPhase.h
MdePkg/Include/Pi/PiStatusCode.h
MdePkg/MdePkg.dec

diff --git a/MdePkg/Include/Guid/StatusCodeDataTypeId.h b/MdePkg/Include/Guid/StatusCodeDataTypeId.h
new file mode 100644 (file)
index 0000000..6e02872
--- /dev/null
@@ -0,0 +1,785 @@
+/** @file\r
+  GUID used to identify id for the caller who is initiating the Status Code.\r
+\r
+  Copyright (c) 2006, Intel Corporation\r
+  All rights reserved. This program and the accompanying materials\r
+  are licensed and made available under the terms and conditions of the BSD License\r
+  which accompanies this distribution.  The full text of the license may be found at\r
+  http://opensource.org/licenses/bsd-license.php\r
+\r
+  THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
+  WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
+\r
+  @par Revision Reference:\r
+  These GUIDs and structures are defined in UEFI Platform Initialization Specification 1.2 \r
+  Volume 3: Shared Architectural Elements\r
+\r
+**/\r
+\r
+#ifndef __PI_STATUS_CODE_DATA_TYPE_ID_GUID_H__\r
+#define __PI_STATUS_CODE_DATA_TYPE_ID_GUID_H__\r
+\r
+#include <PiDxe.h>\r
+#include <Protocol/DebugSupport.h>\r
+\r
+///\r
+/// Global ID for the EFI_STATUS_CODE_STRING structure\r
+///\r
+#define EFI_STATUS_CODE_DATA_TYPE_STRING_GUID \\r
+  { 0x92D11080, 0x496F, 0x4D95, { 0xBE, 0x7E, 0x03, 0x74, 0x88, 0x38, 0x2B, 0x0A } }\r
\r
+#pragma pack(1)\r
\r
+typedef enum {\r
+  ///\r
+  /// A NULL-terminated ASCII string.\r
+  ///\r
+  EfiStringAscii,\r
+  ///\r
+  /// A double NULL-terminated Unicode string.\r
+  ///\r
+  EfiStringUnicode,\r
+  ///\r
+  /// An EFI_STATUS_CODE_STRING_TOKEN representing the string.  The actual \r
+  /// string can be obtained by querying the HII Database\r
+  ///\r
+  EfiStringToken\r
+} EFI_STRING_TYPE;\r
\r
+///\r
+/// Specifies the format of the data in EFI_STATUS_CODE_STRING_DATA.String.\r
+///\r
+typedef struct {\r
+  ///\r
+  /// The HII package list which contains the string.  Handle is a dynamic value that may\r
+  /// not be the same for different boots.  Type EFI_HII_HANDLE is defined in\r
+  /// EFI_HII_DATABASE_PROTOCOL.NewPackageList() in the UEFI Specification.\r
+  ///\r
+  EFI_HII_HANDLE  Handle;\r
+  ///\r
+  /// When combined with Handle, the string token can be used to retrieve the string.\r
+  /// Type EFI_STRING_ID is defined in EFI_IFR_OP_HEADER in the UEFI Specification.\r
+  ///\r
+  EFI_STRING_ID   Token;\r
+} EFI_STATUS_CODE_STRING_TOKEN;\r
\r
+typedef union {\r
+  ///\r
+  /// ASCII formatted string.\r
+  ///\r
+  CHAR8                         *Ascii;\r
+  ///\r
+  /// Unicode formatted string.\r
+  ///\r
+  CHAR16                        *Unicode;\r
+  ///\r
+  /// HII handle/token pair.\r
+  ///\r
+  EFI_STATUS_CODE_STRING_TOKEN  Hii;\r
+} EFI_STATUS_CODE_STRING;\r
\r
+///\r
+/// This data type defines a string type of extended data. A string can accompany \r
+/// any status code. The string can provide additional information about the \r
+/// status code. The string can be ASCII, Unicode, or a Human Interface Infrastructure \r
+/// (HII) token/GUID pair.\r
+///\r
+typedef struct {\r
+  ///\r
+  /// The data header identifying the data. DataHeader.HeaderSize should be\r
+  /// sizeof (EFI_STATUS_CODE_DATA), DataHeader.Size should be\r
+  /// sizeof (EFI_STATUS_CODE_STRING_DATA) \96 HeaderSize, and\r
+  /// DataHeader.Type should be\r
+  /// EFI_STATUS_CODE_DATA_TYPE_STRING_GUID.\r
+  /// \r
+  EFI_STATUS_CODE_DATA           DataHeader; \r
+  ///\r
+  /// Specifies the format of the data in String.\r
+  ///\r
+  EFI_STRING_TYPE                StringType;\r
+  ///\r
+  /// A pointer to the extended data. The data follows the format specified by \r
+  /// StringType.\r
+  ///\r
+  EFI_STATUS_CODE_STRING         String;\r
+} EFI_STATUS_CODE_STRING_DATA;\r
+\r
+#pragma pack()\r
+\r
+extern EFI_GUID gEfiStatusCodeDataTypeStringGuid;\r
+\r
+///\r
+/// Global ID for the following structures:\r
+///   - EFI_DEVICE_PATH_EXTENDED_DATA\r
+///   - EFI_DEVICE_HANDLE_EXTENDED_DATA\r
+///   - EFI_RESOURCE_ALLOC_FAILURE_ERROR_DATA\r
+///   - EFI_COMPUTING_UNIT_VOLTAGE_ERROR_DATA\r
+///   - EFI_COMPUTING_UNIT_MICROCODE_UPDATE_ERROR_DATA\r
+///   - EFI_COMPUTING_UNIT_TIMER_EXPIRED_ERROR_DATA\r
+///   - EFI_HOST_PROCESSOR_MISMATCH_ERROR_DATA\r
+///   - EFI_MEMORY_RANGE_EXTENDED_DATA\r
+///   - EFI_DEBUG_ASSERT_DATA\r
+///   - EFI_STATUS_CODE_EXCEP_EXTENDED_DATA\r
+///   - EFI_STATUS_CODE_START_EXTENDED_DATA\r
+///   - EFI_LEGACY_OPROM_EXTENDED_DATA\r
+///\r
+#define EFI_STATUS_CODE_SPECIFIC_DATA_GUID \\r
+  { 0x335984bd, 0xe805, 0x409a, { 0xb8, 0xf8, 0xd2, 0x7e, 0xce, 0x5f, 0xf7, 0xa6 } }\r
+\r
+#pragma pack(1)\r
+\r
+///\r
+/// Extended data about the device path, which is used for many errors and \r
+/// progress codes to point to the device.\r
+///\r
+/// The device path is used to point to the physical device in case there is more than one device\r
+/// belonging to the same subclass. For example, the system may contain two USB keyboards and one\r
+/// PS/2* keyboard. The driver that parses the status code can use the device path extended data to\r
+/// differentiate between the three. The index field is not useful in this case because there is no standard\r
+/// numbering convention. Device paths are preferred over using device handles because device handles\r
+/// for a given device can change from one boot to another and do not mean anything beyond Boot\r
+/// Services time. In certain cases, the bus driver may not create a device handle for a given device if it\r
+/// detects a critical error. In these cases, the device path extended data can be used to refer to the\r
+/// device, but there may not be any device handles with an instance of\r
+/// EFI_DEVICE_PATH_PROTOCOL that matches DevicePath. The variable device path structure\r
+/// is included in this structure to make it self sufficient.\r
+///\r
+typedef struct {\r
+  ///\r
+  /// The data header identifying the data. DataHeader.HeaderSize should be\r
+  /// sizeof (EFI_STATUS_CODE_DATA). DataHeader.Size should be the size\r
+  /// of variable-length DevicePath, and DataHeader.Size is zero for a virtual\r
+  /// device that does not have a device path. DataHeader.Type should be\r
+  /// EFI_STATUS_CODE_SPECIFIC_DATA_GUID.\r
+  ///\r
+  EFI_STATUS_CODE_DATA                 DataHeader;\r
+  ///\r
+  /// The device path to the controller or the hardware device. Note that this parameter is a\r
+  /// variable-length device path structure and not a pointer to such a structure. This\r
+  /// structure is populated only if it is a physical device. For virtual devices, the Size\r
+  /// field in DataHeader is set to zero and this field is not populated.\r
+  ///\r
+  UINT8                                *DevicePath;\r
+} EFI_DEVICE_PATH_EXTENDED_DATA;\r
+\r
+///\r
+/// Device handle Extended Data. Used for many\r
+/// errors and progress codes to point to the device.\r
+///\r
+/// The handle of the device with which the progress or error code is associated. The handle is\r
+/// guaranteed to be accurate only at the time the status code is reported. Handles are dynamic entities\r
+/// between boots, so handles cannot be considered to be valid if the system has reset subsequent to the\r
+/// status code being reported. Handles may be used to determine a wide variety of useful information\r
+/// about the source of the status code.\r
+///\r
+typedef struct {\r
+  ///\r
+  /// The data header identifying the data. DataHeader.HeaderSize should be\r
+  /// sizeof (EFI_STATUS_CODE_DATA), DataHeader.Size should be\r
+  /// sizeof (EFI_DEVICE_HANDLE_EXTENDED_DATA) - HeaderSize, and\r
+  /// DataHeader.Type should be EFI_STATUS_CODE_SPECIFIC_DATA_GUID.\r
+  ///\r
+  EFI_STATUS_CODE_DATA  DataHeader;\r
+  ///\r
+  /// The device handle.\r
+  ///\r
+  EFI_HANDLE            Handle;\r
+} EFI_DEVICE_HANDLE_EXTENDED_DATA;\r
+\r
+///\r
+/// This structure defines extended data describing a PCI resource allocation error.\r
+///\r
+/// @par Note: \r
+///   The following structure contains variable-length fields and cannot be defined as a C-style\r
+///   structure.\r
+///\r
+/// This extended data conveys details for a PCI resource allocation failure error. See the PCI\r
+/// specification and the ACPI specification for details on PCI resource allocations and the format for\r
+/// resource descriptors. This error does not detail why the resource allocation failed. It may be due to a\r
+/// bad resource request or a lack of available resources to satisfy a valid request. The variable device\r
+/// path structure and the resource structures are included in this structure to make it self sufficient.\r
+///\r
+typedef struct {\r
+  ///\r
+  /// The data header identifying the data. DataHeader.HeaderSize should be sizeof\r
+  /// (EFI_STATUS_CODE_DATA), DataHeader.Size should be\r
+  /// (DevicePathSize + DevicePathSize + DevicePathSize +\r
+  /// sizeof(UINT32) + 3 * sizeof (UINT16) ), and DataHeader.Type\r
+  /// should be EFI_STATUS_CODE_SPECIFIC_DATA_GUID.\r
+  ///\r
+  EFI_STATUS_CODE_DATA               DataHeader;\r
+  ///\r
+  /// The PCI BAR. Applicable only for PCI devices. Ignored for all other devices.\r
+  ///\r
+  UINT32                             Bar;\r
+  ///\r
+  /// DevicePathSize should be zero if it is a virtual device that is not associated with\r
+  /// a device path. Otherwise, this parameter is the length of the variable-length\r
+  /// DevicePath. \r
+  ///\r
+  UINT16                             DevicePathSize;\r
+  ///\r
+  /// Represents the size the ReqRes parameter. ReqResSize should be zero if the\r
+  /// requested resources are not provided as a part of extended data.\r
+  ///\r
+  UINT16                             ReqResSize;\r
+  ///\r
+  /// Represents the size the AllocRes parameter. AllocResSize should be zero if the\r
+  /// allocated resources are not provided as a part of extended data.\r
+  ///\r
+  UINT16                             AllocResSize;\r
+  ///\r
+  /// The device path to the controller or the hardware device that did not get the requested\r
+  /// resources. Note that this parameter is the variable-length device path structure and not\r
+  /// a pointer to this structure.\r
+  ///\r
+  UINT8                              *DevicePath;\r
+  ///\r
+  /// The requested resources in the format of an ACPI 2.0 resource descriptor. This\r
+  /// parameter is not a pointer; it is the complete resource descriptor.\r
+  ///\r
+  UINT8                              *ReqRes;\r
+  ///\r
+  /// The allocated resources in the format of an ACPI 2.0 resource descriptor. This\r
+  /// parameter is not a pointer; it is the complete resource descriptor.\r
+  ///\r
+  UINT8                              *AllocRes;\r
+} EFI_RESOURCE_ALLOC_FAILURE_ERROR_DATA;\r
+\r
+///\r
+/// This structure provides a calculation for base-10 representations.\r
+///\r
+/// Not consistent with PI 1.2 Specification.\r
+/// This data type is not defined in the PI 1.2 Specification, but is \r
+/// required by several of the other data structures in this file.\r
+///\r
+typedef struct {\r
+  ///\r
+  /// The INT16 number by which to multiply the base-2 representation.\r
+  ///\r
+  INT16                            Value;\r
+  ///\r
+  /// The INT16 number by which to raise the base-2 calculation. \r
+  ///\r
+  INT16                            Exponent;\r
+} EFI_EXP_BASE10_DATA;\r
+\r
+///\r
+/// This structure provides the voltage at the time of error. It also provides \r
+/// the threshold value indicating the minimum or maximum voltage that is considered \r
+/// an error. If the voltage is less then the threshold, the error indicates that the \r
+/// voltage fell below the minimum acceptable value. If the voltage is greater then the threshold, \r
+/// the error indicates that the voltage rose above the maximum acceptable value.\r
+///\r
+typedef struct {\r
+  ///\r
+  /// The data header identifying the data. DataHeader.HeaderSize should be\r
+  /// sizeof (EFI_STATUS_CODE_DATA), DataHeader.Size should be\r
+  /// sizeof (EFI_COMPUTING_UNIT_VOLTAGE_ERROR_DATA) -\r
+  /// HeaderSize, and DataHeader.Type should be\r
+  /// EFI_STATUS_CODE_SPECIFIC_DATA_GUID.\r
+  ///\r
+  EFI_STATUS_CODE_DATA  DataHeader;\r
+  ///\r
+  /// The voltage value at the time of the error.\r
+  ///\r
+  EFI_EXP_BASE10_DATA   Voltage;\r
+  ///\r
+  /// The voltage threshold.\r
+  ///\r
+  EFI_EXP_BASE10_DATA   Threshold;\r
+} EFI_COMPUTING_UNIT_VOLTAGE_ERROR_DATA;\r
+\r
+///\r
+/// Microcode Update Extended Error Data\r
+///\r
+typedef struct {\r
+  ///\r
+  /// The data header identifying the data. DataHeader.HeaderSize should be\r
+  /// sizeof (EFI_STATUS_CODE_DATA), DataHeader.Size should be\r
+  /// sizeof (EFI_COMPUTING_UNIT_MICROCODE_UPDATE_ERROR_DATA) -\r
+  /// HeaderSize, and DataHeader.Type should be\r
+  /// EFI_STATUS_CODE_SPECIFIC_DATA_GUID.\r
+  ///\r
+  EFI_STATUS_CODE_DATA  DataHeader;\r
+  ///\r
+  /// The version of the microcode update from the header.\r
+  ///\r
+  UINT32                Version;\r
+} EFI_COMPUTING_UNIT_MICROCODE_UPDATE_ERROR_DATA;\r
+\r
+///\r
+/// This structure provides details about the computing unit timer expiration error.\r
+/// The timer limit provides the timeout value of the timer prior to expiration.\r
+///\r
+typedef struct {\r
+  ///\r
+  /// The data header identifying the data. DataHeader.HeaderSize should be\r
+  /// sizeof (EFI_STATUS_CODE_DATA), DataHeader.Size should be\r
+  /// sizeof (EFI_COMPUTING_UNIT_TIMER_EXPIRED_ERROR_DATA) -\r
+  /// HeaderSize, and DataHeader.Type should be\r
+  /// EFI_STATUS_CODE_SPECIFIC_DATA_GUID.  \r
+  ///\r
+  EFI_STATUS_CODE_DATA  DataHeader;\r
+  ///\r
+  /// The number of seconds that the computing unit timer was configured to expire.\r
+  ///\r
+  EFI_EXP_BASE10_DATA   TimerLimit;\r
+} EFI_COMPUTING_UNIT_TIMER_EXPIRED_ERROR_DATA;\r
+\r
+///\r
+/// Attribute bits for EFI_HOST_PROCESSOR_MISMATCH_ERROR_DATA.Attributes\r
+/// All other attributes are reserved for future use and must be initialized to 0.\r
+///\r
+///@{\r
+#define EFI_COMPUTING_UNIT_MISMATCH_SPEED       0x0001\r
+#define EFI_COMPUTING_UNIT_MISMATCH_FSB_SPEED   0x0002\r
+#define EFI_COMPUTING_UNIT_MISMATCH_FAMILY      0x0004\r
+#define EFI_COMPUTING_UNIT_MISMATCH_MODEL       0x0008\r
+#define EFI_COMPUTING_UNIT_MISMATCH_STEPPING    0x0010\r
+#define EFI_COMPUTING_UNIT_MISMATCH_CACHE_SIZE  0x0020\r
+#define EFI_COMPUTING_UNIT_MISMATCH_OEM1        0x1000\r
+#define EFI_COMPUTING_UNIT_MISMATCH_OEM2        0x2000\r
+#define EFI_COMPUTING_UNIT_MISMATCH_OEM3        0x4000\r
+#define EFI_COMPUTING_UNIT_MISMATCH_OEM4        0x8000\r
+///@}\r
+\r
+///\r
+/// This structure defines extended data for processor mismatch errors.\r
+///\r
+/// This provides information to indicate which processors mismatch, and how they mismatch. The \r
+/// status code contains the instance number of the processor that is in error. This structure's \r
+/// Instance indicates the second processor that does not match. This differentiation allows the \r
+/// consumer to determine which two processors do not match. The Attributes indicate what \r
+/// mismatch is being reported. Because Attributes is a bit field, more than one mismatch can be \r
+/// reported with one error code.\r
+///\r
+typedef struct {\r
+  ///\r
+  /// The data header identifying the data. DataHeader.HeaderSize should be\r
+  /// sizeof (EFI_STATUS_CODE_DATA), DataHeader.Size should be\r
+  /// sizeof (EFI_ HOST_PROCESSOR_MISMATCH_ERROR_DATA) -\r
+  /// HeaderSize , and DataHeader.Type should be\r
+  /// EFI_STATUS_CODE_SPECIFIC_DATA_GUID.  \r
+  ///\r
+  EFI_STATUS_CODE_DATA  DataHeader;\r
+  ///\r
+  /// The unit number of the computing unit that does not match.\r
+  ///  \r
+  UINT32                Instance;\r
+  /// \r
+  /// The attributes describing the failure. \r
+  ///  \r
+  UINT16                Attributes;\r
+} EFI_HOST_PROCESSOR_MISMATCH_ERROR_DATA;\r
+\r
+///\r
+/// This structure provides details about the computing unit thermal failure.\r
+///\r
+/// This structure provides the temperature at the time of error. It also provides the threshold value \r
+/// indicating the minimum temperature that is considered an error.\r
+///\r
+typedef struct {\r
+  ///\r
+  /// The data header identifying the data. DataHeader.HeaderSize should be\r
+  /// sizeof (EFI_STATUS_CODE_DATA), DataHeader.Size should be\r
+  /// sizeof (EFI_COMPUTING_UNIT_THERMAL_ERROR_DATA) -\r
+  /// HeaderSize , and DataHeader.Type should be\r
+  /// EFI_STATUS_CODE_SPECIFIC_DATA_GUID.  \r
+  ///\r
+  EFI_STATUS_CODE_DATA  DataHeader;\r
+  ///\r
+  /// The thermal value at the time of the error.\r
+  ///\r
+  EFI_EXP_BASE10_DATA   Temperature;\r
+  ///\r
+  /// The thermal threshold.\r
+  ///\r
+  EFI_EXP_BASE10_DATA   Threshold;\r
+} EFI_COMPUTING_UNIT_THERMAL_ERROR_DATA;\r
+\r
+///\r
+/// Enumeration of valid cache types\r
+///\r
+typedef enum {\r
+  EfiInitCacheDataOnly,\r
+  EfiInitCacheInstrOnly,\r
+  EfiInitCacheBoth,\r
+  EfiInitCacheUnspecified\r
+} EFI_INIT_CACHE_TYPE;\r
+\r
+///\r
+/// Embedded cache init extended data\r
+///\r
+typedef struct {\r
+  ///\r
+  /// The data header identifying the data. DataHeader.HeaderSize should be\r
+  /// sizeof (EFI_STATUS_CODE_DATA), DataHeader.Size should be\r
+  /// sizeof (EFI_CACHE_INIT_DATA) - HeaderSize , and\r
+  /// DataHeader.Type should be EFI_STATUS_CODE_SPECIFIC_DATA_GUID.\r
+  ///\r
+  EFI_STATUS_CODE_DATA  DataHeader;\r
+  ///\r
+  /// The cache level. Starts with 1 for level 1 cache.\r
+  ///\r
+  UINT32                Level;\r
+  ///\r
+  /// The type of cache.\r
+  ///\r
+  EFI_INIT_CACHE_TYPE   Type;\r
+} EFI_CACHE_INIT_DATA;\r
+\r
+///\r
+///\r
+///\r
+typedef UINT32  EFI_CPU_STATE_CHANGE_CAUSE;\r
+\r
+///\r
+/// The reasons that the processor is disabled.  \r
+/// Used to fill in EFI_COMPUTING_UNIT_CPU_DISABLED_ERROR_DATA.Cause.\r
+///\r
+///@{\r
+#define EFI_CPU_CAUSE_INTERNAL_ERROR            0x0001\r
+#define EFI_CPU_CAUSE_THERMAL_ERROR             0x0002\r
+#define EFI_CPU_CAUSE_SELFTEST_FAILURE          0x0004\r
+#define EFI_CPU_CAUSE_PREBOOT_TIMEOUT           0x0008\r
+#define EFI_CPU_CAUSE_FAILED_TO_START           0x0010\r
+#define EFI_CPU_CAUSE_CONFIG_ERROR              0x0020\r
+#define EFI_CPU_CAUSE_USER_SELECTION            0x0080\r
+#define EFI_CPU_CAUSE_BY_ASSOCIATION            0x0100\r
+#define EFI_CPU_CAUSE_UNSPECIFIED               0x8000\r
+///@}\r
+\r
+///\r
+/// This structure provides information about the disabled computing unit.\r
+///\r
+/// This structure provides details as to why and how the computing unit was disabled. The causes \r
+/// should cover the typical reasons a processor would be disabled. How the processor was disabled is \r
+/// important because there are distinct differences between hardware and software disabling.\r
+///\r
+typedef struct {\r
+  ///\r
+  /// The data header identifying the data. DataHeader.HeaderSize should be\r
+  /// sizeof (EFI_STATUS_CODE_DATA), DataHeader.Size should be\r
+  /// sizeof (EFI_COMPUTING_UNIT_CPU_DISABLED_ERROR_DATA) -\r
+  /// HeaderSize, and DataHeader.Type should be\r
+  /// EFI_STATUS_CODE_SPECIFIC_DATA_GUID.\r
+  ///\r
+  EFI_STATUS_CODE_DATA  DataHeader;\r
+  ///\r
+  /// The reason for disabling the processor. \r
+  /// \r
+  UINT32                Cause;\r
+  ///\r
+  /// TRUE if the processor is disabled via software means such as not listing it in the ACPI tables. \r
+  /// Such a processor will respond to Interprocessor Interrupts (IPIs). FALSE if the processor is hardware \r
+  /// disabled, which means it is invisible to software and will not respond to IPIs.\r
+  ///\r
+  BOOLEAN               SoftwareDisabled;\r
+} EFI_COMPUTING_UNIT_CPU_DISABLED_ERROR_DATA;\r
+\r
+///\r
+/// Memory Error Granularity Definition\r
+///\r
+typedef UINT8 EFI_MEMORY_ERROR_GRANULARITY;\r
+\r
+///\r
+/// Memory Error Granularities.  Used to fill in EFI_MEMORY_EXTENDED_ERROR_DATA.Granularity.\r
+///\r
+///@{\r
+#define EFI_MEMORY_ERROR_OTHER      0x01\r
+#define EFI_MEMORY_ERROR_UNKNOWN    0x02\r
+#define EFI_MEMORY_ERROR_DEVICE     0x03\r
+#define EFI_MEMORY_ERROR_PARTITION  0x04\r
+///@}\r
+\r
+///\r
+/// Memory Error Operation Definition\r
+///\r
+typedef UINT8 EFI_MEMORY_ERROR_OPERATION;\r
+\r
+///\r
+/// Memory Error Operations.  Used to fill in EFI_MEMORY_EXTENDED_ERROR_DATA.Operation.\r
+///\r
+///@{\r
+#define EFI_MEMORY_OPERATION_OTHER 0x01\r
+#define EFI_MEMORY_OPERATION_UNKNOWN 0x02\r
+#define EFI_MEMORY_OPERATION_READ 0x03\r
+#define EFI_MEMORY_OPERATION_WRITE 0x04\r
+#define EFI_MEMORY_OPERATION_PARTIAL_WRITE 0x05\r
+///@}\r
+\r
+///\r
+/// This structure provides specific details about the memory error that was detected. It provides \r
+/// enough information so that consumers can identify the exact failure and provides enough \r
+/// information to enable corrective action if necessary.\r
+///\r
+typedef struct {\r
+  ///\r
+  /// The data header identifying the data. DataHeader.HeaderSize should be\r
+  /// sizeof (EFI_STATUS_CODE_DATA), DataHeader.Size should be\r
+  /// sizeof (EFI_MEMORY_EXTENDED_ERROR_DATA) - HeaderSize, and\r
+  /// DataHeader.Type should be EFI_STATUS_CODE_SPECIFIC_DATA_GUID.  \r
+  ///\r
+  EFI_STATUS_CODE_DATA          DataHeader;\r
+  ///\r
+  /// The error granularity type.\r
+  ///\r
+  EFI_MEMORY_ERROR_GRANULARITY  Granularity;\r
+  ///\r
+  /// The operation that resulted in the error being detected. \r
+  ///\r
+  EFI_MEMORY_ERROR_OPERATION    Operation;\r
+  ///\r
+  /// The error syndrome, vendor-specific ECC syndrome, or CRC data associated with \r
+  /// the error.  If unknown, should be initialized to 0.\r
+  /// Inconsistent with specification here:  \r
+  /// This field in StatusCodes spec0.9 is defined as UINT32, keep code unchanged.\r
+  ///\r
+  UINTN                         Syndrome;\r
+  ///\r
+  /// The physical address of the error. \r
+  ///\r
+  EFI_PHYSICAL_ADDRESS          Address;\r
+  ///\r
+  /// The range, in bytes, within which the error address can be determined.\r
+  ///\r
+  UINTN                         Resolution;\r
+} EFI_MEMORY_EXTENDED_ERROR_DATA;\r
+\r
+///\r
+/// A definition to describe that the operation is performed on multiple devices within the array.\r
+/// May be used for EFI_STATUS_CODE_DIMM_NUMBER.Array and EFI_STATUS_CODE_DIMM_NUMBER.Device. \r
+///\r
+#define EFI_MULTIPLE_MEMORY_DEVICE_OPERATION 0xfffe\r
+\r
+///\r
+/// A definition to describe that the operation is performed on all devices within the array.\r
+/// May be used for EFI_STATUS_CODE_DIMM_NUMBER.Array and EFI_STATUS_CODE_DIMM_NUMBER.Device. \r
+///\r
+#define EFI_ALL_MEMORY_DEVICE_OPERATION 0xffff\r
+\r
+///\r
+/// A definition to describe that the operation is performed on multiple arrays.\r
+/// May be used for EFI_STATUS_CODE_DIMM_NUMBER.Array and EFI_STATUS_CODE_DIMM_NUMBER.Device. \r
+///\r
+#define EFI_MULTIPLE_MEMORY_ARRAY_OPERATION 0xfffe\r
+\r
+///\r
+/// A definition to describe that the operation is performed on all the arrays.\r
+/// May be used for EFI_STATUS_CODE_DIMM_NUMBER.Array and EFI_STATUS_CODE_DIMM_NUMBER.Device. \r
+///\r
+#define EFI_ALL_MEMORY_ARRAY_OPERATION 0xffff\r
+\r
+///\r
+/// This extended data provides some context that consumers can use to locate a DIMM within the \r
+/// overall memory scheme.  \r
+///\r
+/// This extended data provides some context that consumers can use to locate a DIMM within the\r
+/// overall memory scheme. The Array and Device numbers may indicate a specific DIMM, or they\r
+/// may be populated with the group definitions in "Related Definitions" below.\r
+///\r
+typedef struct {\r
+  ///\r
+  /// The data header identifying the data. DataHeader.HeaderSize should be\r
+  /// sizeof (EFI_STATUS_CODE_DATA), DataHeader.Size should be\r
+  /// sizeof (EFI_STATUS_CODE_DIMM_NUMBER) - HeaderSize, and\r
+  /// DataHeader.Type should be EFI_STATUS_CODE_SPECIFIC_DATA_GUID.\r
+  ///\r
+  EFI_STATUS_CODE_DATA  DataHeader;\r
+  ///\r
+  /// The memory array number.\r
+  ///\r
+  UINT16                Array;\r
+  ///\r
+  /// The device number within that Array.\r
+  ///\r
+  UINT16                Device;\r
+} EFI_STATUS_CODE_DIMM_NUMBER;\r
+\r
+///\r
+/// This structure defines extended data describing memory modules that do not match.\r
+///\r
+/// This extended data may be used to convey the specifics of memory modules that do not match.\r
+/// \r
+typedef struct {\r
+  ///\r
+  /// The data header identifying the data. DataHeader.HeaderSize should be\r
+  /// sizeof (EFI_STATUS_CODE_DATA), DataHeader.Size should be\r
+  /// sizeof (EFI_MEMORY_MODULE_MISMATCH_ERROR_DATA) -\r
+  /// HeaderSize, and DataHeader.Type should be\r
+  /// EFI_STATUS_CODE_SPECIFIC_DATA_GUID.\r
+  ///\r
+  EFI_STATUS_CODE_DATA         DataHeader;\r
+  ///\r
+  /// The instance number of the memory module that does not match. \r
+  ///\r
+  EFI_STATUS_CODE_DIMM_NUMBER  Instance;\r
+} EFI_MEMORY_MODULE_MISMATCH_ERROR_DATA;\r
+\r
+///\r
+/// This structure defines extended data describing a memory range.\r
+///\r
+/// This extended data may be used to convey the specifics of a memory range.  Ranges are specified \r
+/// with a start address and a length.\r
+///\r
+typedef struct {\r
+  ///\r
+  /// The data header identifying the data. DataHeader.HeaderSize should be\r
+  /// sizeof (EFI_STATUS_CODE_DATA), DataHeader.Size should be\r
+  /// sizeof (EFI_MEMORY_RANGE_EXTENDED_DATA) - HeaderSize, and\r
+  /// DataHeader.Type should be EFI_STATUS_CODE_SPECIFIC_DATA_GUID.  \r
+  ///\r
+  EFI_STATUS_CODE_DATA  DataHeader;\r
+  ///\r
+  /// The starting address of the memory range. \r
+  ///\r
+  EFI_PHYSICAL_ADDRESS  Start;\r
+  ///\r
+  /// The length in bytes of the memory range.\r
+  ///\r
+  EFI_PHYSICAL_ADDRESS  Length;\r
+} EFI_MEMORY_RANGE_EXTENDED_DATA;\r
+\r
+///\r
+/// This structure provides the assert information that is typically associated with a debug assertion failing.\r
+///\r
+/// The data indicates the location of the assertion that failed in the source code. This information\r
+/// includes the file name and line number that are necessary to find the failing assertion in source code.\r
+///\r
+typedef struct {\r
+  ///\r
+  /// The data header identifying the data. DataHeader.HeaderSize should be\r
+  /// sizeof (EFI_STATUS_CODE_DATA), DataHeader.Size should be\r
+  /// sizeof (EFI_DEBUG_ASSERT_DATA) \96 HeaderSize , and\r
+  /// DataHeader.Type should be EFI_STATUS_CODE_SPECIFIC_DATA_GUID.\r
+  /// \r
+  EFI_STATUS_CODE_DATA         DataHeader;\r
+  ///\r
+  /// The line number of the source file where the fault was generated.\r
+  ///\r
+  UINT32                       LineNumber;\r
+  ///\r
+  /// The size in bytes of FileName.\r
+  ///\r
+  UINT32                       FileNameSize;\r
+  ///\r
+  /// A pointer to a NULL-terminated ASCII or Unicode string that represents \r
+  /// the file name of the source file where the fault was generated.\r
+  ///\r
+  EFI_STATUS_CODE_STRING_DATA  *FileName;\r
+} EFI_DEBUG_ASSERT_DATA;\r
+\r
+///\r
+/// System Context Data EBC/IA32/IPF\r
+///\r
+typedef union {\r
+  ///\r
+  /// The context of the EBC virtual machine when the exception was generated. Type\r
+  /// EFI_SYSTEM_CONTEXT_EBC is defined in EFI_DEBUG_SUPPORT_PROTOCOL\r
+  /// in the UEFI Specification.\r
+  ///\r
+  EFI_SYSTEM_CONTEXT_EBC  SystemContextEbc;\r
+  ///\r
+  /// The context of the IA-32 processor when the exception was generated. Type\r
+  /// EFI_SYSTEM_CONTEXT_IA32 is defined in the\r
+  /// EFI_DEBUG_SUPPORT_PROTOCOL in the UEFI Specification.\r
+  ///\r
+  EFI_SYSTEM_CONTEXT_IA32 SystemContextIa32;\r
+  ///\r
+  /// The context of the Itanium(R) processor when the exception was generated. Type\r
+  /// EFI_SYSTEM_CONTEXT_IPF is defined in the\r
+  /// EFI_DEBUG_SUPPORT_PROTOCOL in the UEFI Specification.\r
+  ///\r
+  EFI_SYSTEM_CONTEXT_IPF  SystemContextIpf;\r
+} EFI_STATUS_CODE_EXCEP_SYSTEM_CONTEXT;\r
+\r
+///\r
+/// This structure defines extended data describing a processor exception error.\r
+///\r
+/// This extended data allows the processor context that is present at the time of the exception to be\r
+/// reported with the exception. The format and contents of the context data varies depending on the\r
+/// processor architecture.\r
+///\r
+typedef struct {\r
+  ///\r
+  /// The data header identifying the data. DataHeader.HeaderSize should be\r
+  /// sizeof (EFI_STATUS_CODE_DATA), DataHeader.Size should be\r
+  /// sizeof (EFI_STATUS_CODE_EXCEP_EXTENDED_DATA) \96 HeaderSize,\r
+  /// and DataHeader.Type should be\r
+  /// EFI_STATUS_CODE_SPECIFIC_DATA_GUID.  \r
+  ///\r
+  EFI_STATUS_CODE_DATA                  DataHeader;\r
+  ///\r
+  /// The system context. \r
+  ///\r
+  EFI_STATUS_CODE_EXCEP_SYSTEM_CONTEXT  Context;\r
+} EFI_STATUS_CODE_EXCEP_EXTENDED_DATA;\r
+\r
+///\r
+/// This structure defines extended data describing a call to a driver binding protocol start function.\r
+///\r
+/// This extended data records information about a Start() function call. Start() is a member of\r
+/// the UEFI Driver Binding Protocol.\r
+///\r
+typedef struct {\r
+  /// \r
+  /// The data header identifying the data. DataHeader.HeaderSize should be\r
+  /// sizeof (EFI_STATUS_CODE_DATA), DataHeader.Size should be\r
+  /// sizeof (EFI_STATUS_CODE_START_EXTENDED_DATA) - HeaderSize,\r
+  /// and DataHeader.Type should be\r
+  /// EFI_STATUS_CODE_SPECIFIC_DATA_GUID.  \r
+  ///\r
+  EFI_STATUS_CODE_DATA           DataHeader;\r
+  ///\r
+  /// The controller handle. \r
+  ///\r
+  EFI_HANDLE                     ControllerHandle;\r
+  ///\r
+  /// The driver binding handle.\r
+  ///\r
+  EFI_HANDLE                     DriverBindingHandle;\r
+  /// \r
+  /// The size of the RemainingDevicePath. It is zero if the Start() function is \r
+  /// called with RemainingDevicePath = NULL.  The UEFI Specification allows\r
+  /// that the Start() function of bus drivers can be called in this way.\r
+  ///\r
+  UINT16                         DevicePathSize;\r
+  ///\r
+  /// Matches the RemainingDevicePath parameter being passed to the Start() \r
+  /// function. Note that this parameter is the variable-length device path and not a pointer \r
+  /// to the device path.\r
+  ///  \r
+  UINT8                          *RemainingDevicePath;\r
+} EFI_STATUS_CODE_START_EXTENDED_DATA;\r
+\r
+///\r
+/// This structure defines extended data describing a legacy option ROM (OpROM).\r
+///\r
+/// The device handle and ROM image base can be used by consumers to determine which option ROM\r
+/// failed. Due to the black-box nature of legacy option ROMs, the amount of information that can be\r
+/// obtained may be limited.\r
+///\r
+typedef struct {\r
+  ///\r
+  /// The data header identifying the data. DataHeader.HeaderSize should be\r
+  /// sizeof (EFI_STATUS_CODE_DATA), DataHeader.Size should be\r
+  /// sizeof (EFI_LEGACY_OPROM_EXTENDED_DATA) - HeaderSize, and\r
+  /// DataHeader.Type should be EFI_STATUS_CODE_SPECIFIC_DATA_GUID.  \r
+  ///\r
+  EFI_STATUS_CODE_DATA  DataHeader;\r
+  ///\r
+  /// The handle corresponding to the device that this legacy option ROM is being invoked.\r
+  ///\r
+  EFI_HANDLE            DeviceHandle;\r
+  ///\r
+  /// The base address of the shadowed legacy ROM image.  May or may not point to the shadow RAM area. \r
+  ///\r
+  EFI_PHYSICAL_ADDRESS  RomImageBase;\r
+} EFI_LEGACY_OPROM_EXTENDED_DATA;\r
+\r
+#pragma pack()\r
+\r
+extern EFI_GUID gEfiStatusCodeSpecificDataGuid;\r
+\r
+#endif\r
index 5791a92281e77ede8741a83d9629dc5326cc8f16..b29c4949ba0406f56704a61bb79668699038636e 100644 (file)
@@ -11,7 +11,7 @@
   WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.             \r
 \r
   @par Revision Reference:\r
-  PI Version 1.0\r
+  These elements are defined in UEFI Platform Initialization Specification 1.2 \r
 \r
 **/\r
 \r
 #include <Pi/PiDependency.h>\r
 #include <Pi/PiStatusCode.h>\r
 \r
-#define EFI_NOT_AVAILABLE_YET   EFIERR (32)\r
+/**\r
+  Produces an error code in the range reserved for use by the Platform Initialization\r
+  Architecture Specification.\r
+\r
+  The supported 32-bit range is 0xA0000000-0xBFFFFFFF \r
+  The supported 64-bit range is 0xA000000000000000-0xBFFFFFFFFFFFFFFF \r
+\r
+  @param  StatusCode    The status code value to convert into a warning code.  \r
+                        StatusCode must be in the range 0x00000000..0x1FFFFFFF.\r
+\r
+  @return The value specified by StatusCode in the PI reserved range.\r
+\r
+**/\r
+#define DXE_ERROR(StatusCode)  (MAX_BIT | (MAX_BIT >> 2) | StatusCode)\r
+\r
+///\r
+/// If this value is returned by an EFI image, then the image should be unloaded.\r
+///\r
+#define EFI_REQUEST_UNLOAD_IMAGE  DXE_ERROR (1)\r
+\r
+///\r
+/// If this value is returned by an API, it means the capability is not yet \r
+/// installed/available/ready to use.\r
+///\r
+#define EFI_NOT_AVAILABLE_YET     DXE_ERROR (2)\r
+\r
+///\r
+/// Bitmask of values for Authentication Status.\r
+/// Authentication Status is returned from EFI_GUIDED_SECTION_EXTRACTION_PROTOCOL \r
+/// and the EFI_PEI_GUIDED_SECTION_EXTRACTION_PPI\r
+///\r
+/// xx00 Image was not signed.\r
+/// xxx1 Platform security policy override. Assumes same meaning as 0010 (the image was signed, the\r
+///      signature was tested, and the signature passed authentication test).\r
+/// 0010 Image was signed, the signature was tested, and the signature passed authentication test.\r
+/// 0110 Image was signed and the signature was not tested.\r
+/// 1010 Image was signed, the signature was tested, and the signature failed the authentication test.\r
+///\r
+///@{\r
+#define EFI_AUTH_STATUS_PLATFORM_OVERRIDE   0x01\r
+#define EFI_AUTH_STATUS_IMAGE_SIGNED        0x02\r
+#define EFI_AUTH_STATUS_NOT_TESTED          0x04\r
+#define EFI_AUTH_STATUS_TEST_FAILED         0x08\r
+#define EFI_AUTH_STATUS_ALL                 0x0f\r
+///@}\r
 \r
 #endif\r
index dc4b46176ae0f3893a2da225f996d832c2806bdb..ed808daf098c89f042930d84f3899343b5039d17 100644 (file)
   WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.             \r
 \r
   @par Revision Reference:\r
-  PI Version 1.0\r
+  These status codes are defined in UEFI Platform Initialization Specification 1.2 \r
+  Volume 3: Shared Architectural Elements\r
 \r
 **/\r
 \r
 #ifndef __PI_STATUS_CODE_H__\r
 #define __PI_STATUS_CODE_H__\r
 \r
+//\r
+// Required for IA32 and IPF defines for CPU exception types\r
+//\r
+#include <Protocol/DebugSupport.h>\r
+\r
 ///\r
 /// Status Code Type Definition\r
 ///\r
 typedef UINT32  EFI_STATUS_CODE_TYPE;\r
 \r
-//\r
-// A Status Code Type is made up of the code type and severity\r
-// All values masked by EFI_STATUS_CODE_RESERVED_MASK are\r
-// reserved for use by this specification.\r
-//\r
+///\r
+/// A Status Code Type is made up of the code type and severity\r
+/// All values masked by EFI_STATUS_CODE_RESERVED_MASK are\r
+/// reserved for use by this specification.\r
+///\r
+///@{\r
 #define EFI_STATUS_CODE_TYPE_MASK     0x000000FF\r
 #define EFI_STATUS_CODE_SEVERITY_MASK 0xFF000000\r
 #define EFI_STATUS_CODE_RESERVED_MASK 0x00FFFF00\r
+///@}\r
 \r
-//\r
-// Definition of code types, all other values masked by\r
-// EFI_STATUS_CODE_TYPE_MASK are reserved for use by\r
-// this specification.\r
-//\r
+///\r
+/// Definition of code types, all other values masked by\r
+/// EFI_STATUS_CODE_TYPE_MASK are reserved for use by\r
+/// this specification.\r
+///\r
+///@{\r
 #define EFI_PROGRESS_CODE             0x00000001\r
 #define EFI_ERROR_CODE                0x00000002\r
 #define EFI_DEBUG_CODE                0x00000003\r
+///@}\r
 \r
-//\r
-// Definitions of severities, all other values masked by\r
-// EFI_STATUS_CODE_SEVERITY_MASK are reserved for use by\r
-// this specification.\r
-// Uncontained errors are major errors that could not contained\r
-// to the specific component that is reporting the error\r
-// For example, if a memory error was not detected early enough,\r
-// the bad data could be consumed by other drivers.\r
-//\r
+///\r
+/// Definitions of severities, all other values masked by\r
+/// EFI_STATUS_CODE_SEVERITY_MASK are reserved for use by\r
+/// this specification.\r
+/// Uncontained errors are major errors that could not contained\r
+/// to the specific component that is reporting the error\r
+/// For example, if a memory error was not detected early enough,\r
+/// the bad data could be consumed by other drivers.\r
+///\r
+///@{\r
 #define EFI_ERROR_MINOR               0x40000000\r
 #define EFI_ERROR_MAJOR               0x80000000\r
 #define EFI_ERROR_UNRECOVERED         0x90000000\r
 #define EFI_ERROR_UNCONTAINED         0xa0000000\r
+///@}\r
 \r
 ///\r
 /// Status Code Value Definition\r
 ///\r
 typedef UINT32 EFI_STATUS_CODE_VALUE;\r
 \r
-//\r
-// A Status Code Value is made up of the class, subclass, and\r
-// an operation.\r
-//\r
+///\r
+/// A Status Code Value is made up of the class, subclass, and\r
+/// an operation.\r
+///\r
+///@{\r
 #define EFI_STATUS_CODE_CLASS_MASK      0xFF000000\r
 #define EFI_STATUS_CODE_SUBCLASS_MASK   0x00FF0000\r
 #define EFI_STATUS_CODE_OPERATION_MASK  0x0000FFFF\r
+///@}\r
 \r
 ///\r
 /// Definition of Status Code extended data header.\r
@@ -88,21 +102,968 @@ typedef struct {
   EFI_GUID  Type;\r
 } EFI_STATUS_CODE_DATA;\r
 \r
+///\r
+/// General partitioning scheme for Progress and Error Codes are\r
+///   - 0x0000-0x0FFF    Shared by all sub-classes in a given class\r
+///   - 0x1000-0x7FFF    Subclass Specific\r
+///   - 0x8000-0xFFFF    OEM specific\r
+///@{\r
+#define EFI_SUBCLASS_SPECIFIC 0x1000\r
+#define EFI_OEM_SPECIFIC      0x8000\r
+///@}\r
+\r
+///\r
+/// Debug Code definitions for all classes and subclass\r
+/// Only one debug code is defined at this point and should\r
+/// be used for anything that gets sent to debug stream.\r
+///\r
+///@{\r
+#define EFI_DC_UNSPECIFIED  0x0\r
+///@}\r
+\r
+///\r
+/// Class definitions\r
+/// Values of 4-127 are reserved for future use by this specification.\r
+/// Values in the range 127-255 are reserved for OEM use.\r
+///\r
+///@{\r
+#define EFI_COMPUTING_UNIT  0x00000000\r
+#define EFI_PERIPHERAL      0x01000000\r
+#define EFI_IO_BUS          0x02000000\r
+#define EFI_SOFTWARE        0x03000000\r
+///@}\r
+\r
+/// \r
+/// Computing Unit Subclass definitions.\r
+/// Values of 8-127 are reserved for future use by this specification.\r
+/// Values of 128-255 are reserved for OEM use.\r
+///\r
+///@{\r
+#define EFI_COMPUTING_UNIT_UNSPECIFIED        (EFI_COMPUTING_UNIT | 0x00000000)\r
+#define EFI_COMPUTING_UNIT_HOST_PROCESSOR     (EFI_COMPUTING_UNIT | 0x00010000)\r
+#define EFI_COMPUTING_UNIT_FIRMWARE_PROCESSOR (EFI_COMPUTING_UNIT | 0x00020000)\r
+#define EFI_COMPUTING_UNIT_IO_PROCESSOR       (EFI_COMPUTING_UNIT | 0x00030000)\r
+#define EFI_COMPUTING_UNIT_CACHE              (EFI_COMPUTING_UNIT | 0x00040000)\r
+#define EFI_COMPUTING_UNIT_MEMORY             (EFI_COMPUTING_UNIT | 0x00050000)\r
+#define EFI_COMPUTING_UNIT_CHIPSET            (EFI_COMPUTING_UNIT | 0x00060000)\r
+///@}\r
+\r
+///\r
+/// Computing Unit Class Progress Code definitions.\r
+/// These are shared by all subclasses.\r
+///\r
+///@{\r
+#define EFI_CU_PC_INIT_BEGIN  0x00000000\r
+#define EFI_CU_PC_INIT_END    0x00000001\r
+///@}\r
+\r
+//\r
+// Computing Unit Unspecified Subclass Progress Code definitions.\r
+//\r
+\r
+///\r
+/// Computing Unit Host Processor Subclass Progress Code definitions.\r
+///@{\r
+#define EFI_CU_HP_PC_POWER_ON_INIT          (EFI_SUBCLASS_SPECIFIC | 0x00000000)\r
+#define EFI_CU_HP_PC_CACHE_INIT             (EFI_SUBCLASS_SPECIFIC | 0x00000001)\r
+#define EFI_CU_HP_PC_RAM_INIT               (EFI_SUBCLASS_SPECIFIC | 0x00000002)\r
+#define EFI_CU_HP_PC_MEMORY_CONTROLLER_INIT (EFI_SUBCLASS_SPECIFIC | 0x00000003)\r
+#define EFI_CU_HP_PC_IO_INIT                (EFI_SUBCLASS_SPECIFIC | 0x00000004)\r
+#define EFI_CU_HP_PC_BSP_SELECT             (EFI_SUBCLASS_SPECIFIC | 0x00000005)\r
+#define EFI_CU_HP_PC_BSP_RESELECT           (EFI_SUBCLASS_SPECIFIC | 0x00000006)\r
+#define EFI_CU_HP_PC_AP_INIT                (EFI_SUBCLASS_SPECIFIC | 0x00000007)\r
+#define EFI_CU_HP_PC_SMM_INIT               (EFI_SUBCLASS_SPECIFIC | 0x00000008)\r
+///@}\r
+\r
+//\r
+// Computing Unit Firmware Processor Subclass Progress Code definitions.\r
+//\r
+\r
+//\r
+// Computing Unit IO Processor Subclass Progress Code definitions.\r
+//\r
+\r
+///\r
+/// Computing Unit Cache Subclass Progress Code definitions.\r
+///\r
+///@{\r
+#define EFI_CU_CACHE_PC_PRESENCE_DETECT (EFI_SUBCLASS_SPECIFIC | 0x00000000)\r
+#define EFI_CU_CACHE_PC_CONFIGURATION   (EFI_SUBCLASS_SPECIFIC | 0x00000001)\r
+///@}\r
+\r
+///\r
+/// Computing Unit Memory Subclass Progress Code definitions.\r
+///\r
+///@{\r
+#define EFI_CU_MEMORY_PC_SPD_READ         (EFI_SUBCLASS_SPECIFIC | 0x00000000)\r
+#define EFI_CU_MEMORY_PC_PRESENCE_DETECT  (EFI_SUBCLASS_SPECIFIC | 0x00000001)\r
+#define EFI_CU_MEMORY_PC_TIMING           (EFI_SUBCLASS_SPECIFIC | 0x00000002)\r
+#define EFI_CU_MEMORY_PC_CONFIGURING      (EFI_SUBCLASS_SPECIFIC | 0x00000003)\r
+#define EFI_CU_MEMORY_PC_OPTIMIZING       (EFI_SUBCLASS_SPECIFIC | 0x00000004)\r
+#define EFI_CU_MEMORY_PC_INIT             (EFI_SUBCLASS_SPECIFIC | 0x00000005)\r
+#define EFI_CU_MEMORY_PC_TEST             (EFI_SUBCLASS_SPECIFIC | 0x00000006)\r
+///@}\r
+\r
+//\r
+// Computing Unit Chipset Subclass Progress Code definitions.\r
+//\r
+\r
+///\r
+/// Computing Unit Class Error Code definitions.\r
+/// These are shared by all subclasses.\r
+///\r
+///@{\r
+#define EFI_CU_EC_NON_SPECIFIC    0x00000000\r
+#define EFI_CU_EC_DISABLED        0x00000001\r
+#define EFI_CU_EC_NOT_SUPPORTED   0x00000002\r
+#define EFI_CU_EC_NOT_DETECTED    0x00000003\r
+#define EFI_CU_EC_NOT_CONFIGURED  0x00000004\r
+///@}\r
+\r
+//\r
+// Computing Unit Unspecified Subclass Error Code definitions.\r
+//\r
+\r
+///\r
+/// Computing Unit Host Processor Subclass Error Code definitions.\r
+///\r
+///@{\r
+#define EFI_CU_HP_EC_INVALID_TYPE         (EFI_SUBCLASS_SPECIFIC | 0x00000000)\r
+#define EFI_CU_HP_EC_INVALID_SPEED        (EFI_SUBCLASS_SPECIFIC | 0x00000001)\r
+#define EFI_CU_HP_EC_MISMATCH             (EFI_SUBCLASS_SPECIFIC | 0x00000002)\r
+#define EFI_CU_HP_EC_TIMER_EXPIRED        (EFI_SUBCLASS_SPECIFIC | 0x00000003)\r
+#define EFI_CU_HP_EC_SELF_TEST            (EFI_SUBCLASS_SPECIFIC | 0x00000004)\r
+#define EFI_CU_HP_EC_INTERNAL             (EFI_SUBCLASS_SPECIFIC | 0x00000005)\r
+#define EFI_CU_HP_EC_THERMAL              (EFI_SUBCLASS_SPECIFIC | 0x00000006)\r
+#define EFI_CU_HP_EC_LOW_VOLTAGE          (EFI_SUBCLASS_SPECIFIC | 0x00000007)\r
+#define EFI_CU_HP_EC_HIGH_VOLTAGE         (EFI_SUBCLASS_SPECIFIC | 0x00000008)\r
+#define EFI_CU_HP_EC_CACHE                (EFI_SUBCLASS_SPECIFIC | 0x00000009)\r
+#define EFI_CU_HP_EC_MICROCODE_UPDATE     (EFI_SUBCLASS_SPECIFIC | 0x0000000A)\r
+#define EFI_CU_HP_EC_CORRECTABLE          (EFI_SUBCLASS_SPECIFIC | 0x0000000B)\r
+#define EFI_CU_HP_EC_UNCORRECTABLE        (EFI_SUBCLASS_SPECIFIC | 0x0000000C)\r
+#define EFI_CU_HP_EC_NO_MICROCODE_UPDATE  (EFI_SUBCLASS_SPECIFIC | 0x0000000D)\r
+///@}\r
+\r
+///\r
+/// Computing Unit Firmware Processor Subclass Error Code definitions.\r
+///\r
+///@{\r
+#define EFI_CU_FP_EC_HARD_FAIL  (EFI_SUBCLASS_SPECIFIC | 0x00000000)\r
+#define EFI_CU_FP_EC_SOFT_FAIL  (EFI_SUBCLASS_SPECIFIC | 0x00000001)\r
+#define EFI_CU_FP_EC_COMM_ERROR (EFI_SUBCLASS_SPECIFIC | 0x00000002)\r
+///@}\r
+\r
+//\r
+// Computing Unit IO Processor Subclass Error Code definitions.\r
+//\r
+\r
+///\r
+/// Computing Unit Cache Subclass Error Code definitions.\r
+///\r
+///@{\r
+#define EFI_CU_CACHE_EC_INVALID_TYPE  (EFI_SUBCLASS_SPECIFIC | 0x00000000)\r
+#define EFI_CU_CACHE_EC_INVALID_SPEED (EFI_SUBCLASS_SPECIFIC | 0x00000001)\r
+#define EFI_CU_CACHE_EC_INVALID_SIZE  (EFI_SUBCLASS_SPECIFIC | 0x00000002)\r
+#define EFI_CU_CACHE_EC_MISMATCH      (EFI_SUBCLASS_SPECIFIC | 0x00000003)\r
+///@}\r
+\r
+///\r
+/// Computing Unit Memory Subclass Error Code definitions.\r
+///\r
+///@{\r
+#define EFI_CU_MEMORY_EC_INVALID_TYPE   (EFI_SUBCLASS_SPECIFIC | 0x00000000)\r
+#define EFI_CU_MEMORY_EC_INVALID_SPEED  (EFI_SUBCLASS_SPECIFIC | 0x00000001)\r
+#define EFI_CU_MEMORY_EC_CORRECTABLE    (EFI_SUBCLASS_SPECIFIC | 0x00000002)\r
+#define EFI_CU_MEMORY_EC_UNCORRECTABLE  (EFI_SUBCLASS_SPECIFIC | 0x00000003)\r
+#define EFI_CU_MEMORY_EC_SPD_FAIL       (EFI_SUBCLASS_SPECIFIC | 0x00000004)\r
+#define EFI_CU_MEMORY_EC_INVALID_SIZE   (EFI_SUBCLASS_SPECIFIC | 0x00000005)\r
+#define EFI_CU_MEMORY_EC_MISMATCH       (EFI_SUBCLASS_SPECIFIC | 0x00000006)\r
+#define EFI_CU_MEMORY_EC_S3_RESUME_FAIL (EFI_SUBCLASS_SPECIFIC | 0x00000007)\r
+#define EFI_CU_MEMORY_EC_UPDATE_FAIL    (EFI_SUBCLASS_SPECIFIC | 0x00000008)\r
+#define EFI_CU_MEMORY_EC_NONE_DETECTED  (EFI_SUBCLASS_SPECIFIC | 0x00000009)\r
+#define EFI_CU_MEMORY_EC_NONE_USEFUL    (EFI_SUBCLASS_SPECIFIC | 0x0000000A)\r
+///@}\r
+\r
+///\r
+/// Computing Unit Chipset Subclass Error Code definitions.\r
+///\r
+///@{\r
+#define EFI_CHIPSET_EC_BAD_BATTERY      (EFI_SUBCLASS_SPECIFIC | 0x00000000)\r
+#define EFI_CHIPSET_EC_DXE_NB_ERROR     (EFI_SUBCLASS_SPECIFIC | 0x00000001)\r
+#define EFI_CHIPSET_EC_DXE_SB_ERROR     (EFI_SUBCLASS_SPECIFIC | 0x00000002)\r
+///@}\r
+\r
+///\r
+/// Peripheral Subclass definitions.\r
+/// Values of 12-127 are reserved for future use by this specification.\r
+/// Values of 128-255 are reserved for OEM use.\r
+///\r
+///@{\r
+#define EFI_PERIPHERAL_UNSPECIFIED      (EFI_PERIPHERAL | 0x00000000)\r
+#define EFI_PERIPHERAL_KEYBOARD         (EFI_PERIPHERAL | 0x00010000)\r
+#define EFI_PERIPHERAL_MOUSE            (EFI_PERIPHERAL | 0x00020000)\r
+#define EFI_PERIPHERAL_LOCAL_CONSOLE    (EFI_PERIPHERAL | 0x00030000)\r
+#define EFI_PERIPHERAL_REMOTE_CONSOLE   (EFI_PERIPHERAL | 0x00040000)\r
+#define EFI_PERIPHERAL_SERIAL_PORT      (EFI_PERIPHERAL | 0x00050000)\r
+#define EFI_PERIPHERAL_PARALLEL_PORT    (EFI_PERIPHERAL | 0x00060000)\r
+#define EFI_PERIPHERAL_FIXED_MEDIA      (EFI_PERIPHERAL | 0x00070000)\r
+#define EFI_PERIPHERAL_REMOVABLE_MEDIA  (EFI_PERIPHERAL | 0x00080000)\r
+#define EFI_PERIPHERAL_AUDIO_INPUT      (EFI_PERIPHERAL | 0x00090000)\r
+#define EFI_PERIPHERAL_AUDIO_OUTPUT     (EFI_PERIPHERAL | 0x000A0000)\r
+#define EFI_PERIPHERAL_LCD_DEVICE       (EFI_PERIPHERAL | 0x000B0000)\r
+#define EFI_PERIPHERAL_NETWORK          (EFI_PERIPHERAL | 0x000C0000)\r
+///@}\r
+\r
+///\r
+/// Peripheral Class Progress Code definitions.\r
+/// These are shared by all subclasses.\r
+///\r
+///@{\r
+#define EFI_P_PC_INIT             0x00000000\r
+#define EFI_P_PC_RESET            0x00000001\r
+#define EFI_P_PC_DISABLE          0x00000002\r
+#define EFI_P_PC_PRESENCE_DETECT  0x00000003\r
+#define EFI_P_PC_ENABLE           0x00000004\r
+#define EFI_P_PC_RECONFIG         0x00000005\r
+#define EFI_P_PC_DETECTED         0x00000006\r
+///@}\r
+\r
+//\r
+// Peripheral Class Unspecified Subclass Progress Code definitions.\r
+//\r
+\r
+///\r
+/// Peripheral Class Keyboard Subclass Progress Code definitions.\r
+///\r
+///@{\r
+#define EFI_P_KEYBOARD_PC_CLEAR_BUFFER  (EFI_SUBCLASS_SPECIFIC | 0x00000000)\r
+#define EFI_P_KEYBOARD_PC_SELF_TEST     (EFI_SUBCLASS_SPECIFIC | 0x00000001)\r
+///@}\r
+\r
+///\r
+/// Peripheral Class Mouse Subclass Progress Code definitions.\r
+///\r
+///@{\r
+#define EFI_P_MOUSE_PC_SELF_TEST  (EFI_SUBCLASS_SPECIFIC | 0x00000000)\r
+///@}\r
+\r
+//\r
+// Peripheral Class Local Console Subclass Progress Code definitions.\r
+//\r
+\r
+//\r
+// Peripheral Class Remote Console Subclass Progress Code definitions.\r
+//\r
+\r
+///\r
+/// Peripheral Class Serial Port Subclass Progress Code definitions.\r
+///\r
+///@{\r
+#define EFI_P_SERIAL_PORT_PC_CLEAR_BUFFER (EFI_SUBCLASS_SPECIFIC | 0x00000000)\r
+///@}\r
+\r
+//\r
+// Peripheral Class Parallel Port Subclass Progress Code definitions.\r
+//\r
+\r
+//\r
+// Peripheral Class Fixed Media Subclass Progress Code definitions.\r
+//\r
+\r
+//\r
+// Peripheral Class Removable Media Subclass Progress Code definitions.\r
+//\r
+\r
+//\r
+// Peripheral Class Audio Input Subclass Progress Code definitions.\r
+//\r
+\r
+//\r
+// Peripheral Class Audio Output Subclass Progress Code definitions.\r
+//\r
+\r
+//\r
+// Peripheral Class LCD Device Subclass Progress Code definitions.\r
+//\r
+\r
+//\r
+// Peripheral Class Network Subclass Progress Code definitions.\r
+//\r
+\r
+///\r
+/// Peripheral Class Error Code definitions.\r
+/// These are shared by all subclasses.\r
+///\r
+///@{\r
+#define EFI_P_EC_NON_SPECIFIC       0x00000000\r
+#define EFI_P_EC_DISABLED           0x00000001\r
+#define EFI_P_EC_NOT_SUPPORTED      0x00000002\r
+#define EFI_P_EC_NOT_DETECTED       0x00000003\r
+#define EFI_P_EC_NOT_CONFIGURED     0x00000004\r
+#define EFI_P_EC_INTERFACE_ERROR    0x00000005\r
+#define EFI_P_EC_CONTROLLER_ERROR   0x00000006\r
+#define EFI_P_EC_INPUT_ERROR        0x00000007\r
+#define EFI_P_EC_OUTPUT_ERROR       0x00000008\r
+#define EFI_P_EC_RESOURCE_CONFLICT  0x00000009\r
+///@}\r
+\r
+//\r
+// Peripheral Class Unspecified Subclass Error Code definitions.\r
+//\r
+\r
+///\r
+/// Peripheral Class Keyboard Subclass Error Code definitions.\r
+///\r
+///@{\r
+#define EFI_P_KEYBOARD_EC_LOCKED    (EFI_SUBCLASS_SPECIFIC | 0x00000000)\r
+#define EFI_P_KEYBOARD_EC_STUCK_KEY (EFI_SUBCLASS_SPECIFIC | 0x00000001)\r
+///@}\r
+\r
+///\r
+/// Peripheral Class Mouse Subclass Error Code definitions.\r
+///\r
+///@{\r
+#define EFI_P_MOUSE_EC_LOCKED (EFI_SUBCLASS_SPECIFIC | 0x00000000)\r
+///@}\r
+\r
+//\r
+// Peripheral Class Local Console Subclass Error Code definitions.\r
+//\r
+\r
+//\r
+// Peripheral Class Remote Console Subclass Error Code definitions.\r
+//\r
+\r
+//\r
+// Peripheral Class Serial Port Subclass Error Code definitions.\r
+//\r
+\r
+//\r
+// Peripheral Class Parallel Port Subclass Error Code definitions.\r
+//\r
+\r
+//\r
+// Peripheral Class Fixed Media Subclass Error Code definitions.\r
+//\r
+\r
+//\r
+// Peripheral Class Removable Media Subclass Error Code definitions.\r
+//\r
+\r
+//\r
+// Peripheral Class Audio Input Subclass Error Code definitions.\r
+//\r
+\r
+//\r
+// Peripheral Class Audio Output Subclass Error Code definitions.\r
+//\r
+\r
+//\r
+// Peripheral Class LCD Device Subclass Error Code definitions.\r
+//\r
+\r
+//\r
+// Peripheral Class Network Subclass Error Code definitions.\r
+//\r
+\r
+///\r
+/// IO Bus Subclass definitions.\r
+/// Values of 14-127 are reserved for future use by this specification.\r
+/// Values of 128-255 are reserved for OEM use.\r
+///\r
+///@{\r
+#define EFI_IO_BUS_UNSPECIFIED  (EFI_IO_BUS | 0x00000000)\r
+#define EFI_IO_BUS_PCI          (EFI_IO_BUS | 0x00010000)\r
+#define EFI_IO_BUS_USB          (EFI_IO_BUS | 0x00020000)\r
+#define EFI_IO_BUS_IBA          (EFI_IO_BUS | 0x00030000)\r
+#define EFI_IO_BUS_AGP          (EFI_IO_BUS | 0x00040000)\r
+#define EFI_IO_BUS_PC_CARD      (EFI_IO_BUS | 0x00050000)\r
+#define EFI_IO_BUS_LPC          (EFI_IO_BUS | 0x00060000)\r
+#define EFI_IO_BUS_SCSI         (EFI_IO_BUS | 0x00070000)\r
+#define EFI_IO_BUS_ATA_ATAPI    (EFI_IO_BUS | 0x00080000)\r
+#define EFI_IO_BUS_FC           (EFI_IO_BUS | 0x00090000)\r
+#define EFI_IO_BUS_IP_NETWORK   (EFI_IO_BUS | 0x000A0000)\r
+#define EFI_IO_BUS_SMBUS        (EFI_IO_BUS | 0x000B0000)\r
+#define EFI_IO_BUS_I2C          (EFI_IO_BUS | 0x000C0000)\r
+///@}\r
+\r
+///\r
+/// IO Bus Class Progress Code definitions.\r
+/// These are shared by all subclasses.\r
+///\r
+///@{\r
+#define EFI_IOB_PC_INIT     0x00000000\r
+#define EFI_IOB_PC_RESET    0x00000001\r
+#define EFI_IOB_PC_DISABLE  0x00000002\r
+#define EFI_IOB_PC_DETECT   0x00000003\r
+#define EFI_IOB_PC_ENABLE   0x00000004\r
+#define EFI_IOB_PC_RECONFIG 0x00000005\r
+#define EFI_IOB_PC_HOTPLUG  0x00000006\r
+///@}\r
+\r
+//\r
+// IO Bus Class Unspecified Subclass Progress Code definitions.\r
+//\r
+\r
+///\r
+/// IO Bus Class PCI Subclass Progress Code definitions.\r
+///\r
+///@{\r
+#define EFI_IOB_PCI_PC_BUS_ENUM   (EFI_SUBCLASS_SPECIFIC | 0x00000000)\r
+#define EFI_IOB_PCI_PC_RES_ALLOC  (EFI_SUBCLASS_SPECIFIC | 0x00000001)\r
+#define EFI_IOB_PCI_PC_HPC_INIT   (EFI_SUBCLASS_SPECIFIC | 0x00000002)\r
+///@}\r
+\r
+//\r
+// IO Bus Class USB Subclass Progress Code definitions.\r
+//\r
+\r
+//\r
+// IO Bus Class IBA Subclass Progress Code definitions.\r
+//\r
+\r
+//\r
+// IO Bus Class AGP Subclass Progress Code definitions.\r
+//\r
+\r
+//\r
+// IO Bus Class PC Card Subclass Progress Code definitions.\r
+//\r
+\r
+//\r
+// IO Bus Class LPC Subclass Progress Code definitions.\r
+//\r
+\r
+//\r
+// IO Bus Class SCSI Subclass Progress Code definitions.\r
+//\r
+\r
+//\r
+// IO Bus Class ATA/ATAPI Subclass Progress Code definitions.\r
+//\r
+\r
+//\r
+// IO Bus Class FC Subclass Progress Code definitions.\r
+//\r
+\r
+//\r
+// IO Bus Class IP Network Subclass Progress Code definitions.\r
+//\r
+\r
+//\r
+// IO Bus Class SMBUS Subclass Progress Code definitions.\r
+//\r
+\r
+//\r
+// IO Bus Class I2C Subclass Progress Code definitions.\r
+//\r
+\r
+///\r
+/// IO Bus Class Error Code definitions.\r
+/// These are shared by all subclasses.\r
+///\r
+///@{\r
+#define EFI_IOB_EC_NON_SPECIFIC       0x00000000\r
+#define EFI_IOB_EC_DISABLED           0x00000001\r
+#define EFI_IOB_EC_NOT_SUPPORTED      0x00000002\r
+#define EFI_IOB_EC_NOT_DETECTED       0x00000003\r
+#define EFI_IOB_EC_NOT_CONFIGURED     0x00000004\r
+#define EFI_IOB_EC_INTERFACE_ERROR    0x00000005\r
+#define EFI_IOB_EC_CONTROLLER_ERROR   0x00000006\r
+#define EFI_IOB_EC_READ_ERROR         0x00000007\r
+#define EFI_IOB_EC_WRITE_ERROR        0x00000008\r
+#define EFI_IOB_EC_RESOURCE_CONFLICT  0x00000009\r
+///@}\r
+\r
+//\r
+// IO Bus Class Unspecified Subclass Error Code definitions.\r
+//\r
+\r
+///\r
+/// IO Bus Class PCI Subclass Error Code definitions.\r
+///\r
+///@{\r
+#define EFI_IOB_PCI_EC_PERR (EFI_SUBCLASS_SPECIFIC | 0x00000000)\r
+#define EFI_IOB_PCI_EC_SERR (EFI_SUBCLASS_SPECIFIC | 0x00000001)\r
+///@}\r
+\r
+//\r
+// IO Bus Class USB Subclass Error Code definitions.\r
+//\r
+\r
+//\r
+// IO Bus Class IBA Subclass Error Code definitions.\r
+//\r
+\r
+//\r
+// IO Bus Class AGP Subclass Error Code definitions.\r
+//\r
+\r
+//\r
+// IO Bus Class PC Card Subclass Error Code definitions.\r
+//\r
+\r
+//\r
+// IO Bus Class LPC Subclass Error Code definitions.\r
+//\r
+\r
+//\r
+// IO Bus Class SCSI Subclass Error Code definitions.\r
+//\r
+\r
+//\r
+// IO Bus Class ATA/ATAPI Subclass Error Code definitions.\r
+//\r
+\r
+//\r
+// IO Bus Class FC Subclass Error Code definitions.\r
+//\r
+\r
+//\r
+// IO Bus Class IP Network Subclass Error Code definitions.\r
+//\r
+\r
+//\r
+// IO Bus Class SMBUS Subclass Error Code definitions.\r
+//\r
+\r
+//\r
+// IO Bus Class I2C Subclass Error Code definitions.\r
+//\r
+\r
+///\r
+/// Software Subclass definitions.\r
+/// Values of 14-127 are reserved for future use by this specification.\r
+/// Values of 128-255 are reserved for OEM use.\r
+///\r
+///@{\r
+#define EFI_SOFTWARE_UNSPECIFIED          (EFI_SOFTWARE | 0x00000000)\r
+#define EFI_SOFTWARE_SEC                  (EFI_SOFTWARE | 0x00010000)\r
+#define EFI_SOFTWARE_PEI_CORE             (EFI_SOFTWARE | 0x00020000)\r
+#define EFI_SOFTWARE_PEI_MODULE           (EFI_SOFTWARE | 0x00030000)\r
+#define EFI_SOFTWARE_DXE_CORE             (EFI_SOFTWARE | 0x00040000)\r
+#define EFI_SOFTWARE_DXE_BS_DRIVER        (EFI_SOFTWARE | 0x00050000)\r
+#define EFI_SOFTWARE_DXE_RT_DRIVER        (EFI_SOFTWARE | 0x00060000)\r
+#define EFI_SOFTWARE_SMM_DRIVER           (EFI_SOFTWARE | 0x00070000)\r
+#define EFI_SOFTWARE_EFI_APPLICATION      (EFI_SOFTWARE | 0x00080000)\r
+#define EFI_SOFTWARE_EFI_OS_LOADER        (EFI_SOFTWARE | 0x00090000)\r
+#define EFI_SOFTWARE_RT                   (EFI_SOFTWARE | 0x000A0000)\r
+#define EFI_SOFTWARE_AL                   (EFI_SOFTWARE | 0x000B0000)\r
+#define EFI_SOFTWARE_EBC_EXCEPTION        (EFI_SOFTWARE | 0x000C0000)\r
+#define EFI_SOFTWARE_IA32_EXCEPTION       (EFI_SOFTWARE | 0x000D0000)\r
+#define EFI_SOFTWARE_IPF_EXCEPTION        (EFI_SOFTWARE | 0x000E0000)\r
+#define EFI_SOFTWARE_PEI_SERVICE          (EFI_SOFTWARE | 0x000F0000)\r
+#define EFI_SOFTWARE_EFI_BOOT_SERVICE     (EFI_SOFTWARE | 0x00100000)\r
+#define EFI_SOFTWARE_EFI_RUNTIME_SERVICE  (EFI_SOFTWARE | 0x00110000)\r
+#define EFI_SOFTWARE_EFI_DXE_SERVICE      (EFI_SOFTWARE | 0x00120000)\r
+///@}\r
 \r
 ///\r
-/// Bit values for Authentication Status\r
+/// Software Class Progress Code definitions.\r
+/// These are shared by all subclasses.\r
 ///\r
-/// xx00 Image was not signed.\r
-/// xxx1 Platform security policy override. Assumes same meaning as 0010 (the image was signed, the\r
-///      signature was tested, and the signature passed authentication test).\r
-/// 0010 Image was signed, the signature was tested, and the signature passed authentication test.\r
-/// 0110 Image was signed and the signature was not tested.\r
-/// 1010 Image was signed, the signature was tested, and the signature failed the authentication test.\r
+///@{\r
+#define EFI_SW_PC_INIT                0x00000000\r
+#define EFI_SW_PC_LOAD                0x00000001\r
+#define EFI_SW_PC_INIT_BEGIN          0x00000002\r
+#define EFI_SW_PC_INIT_END            0x00000003\r
+#define EFI_SW_PC_AUTHENTICATE_BEGIN  0x00000004\r
+#define EFI_SW_PC_AUTHENTICATE_END    0x00000005\r
+#define EFI_SW_PC_INPUT_WAIT          0x00000006\r
+#define EFI_SW_PC_USER_SETUP          0x00000007\r
+///@}\r
+\r
+//\r
+// Software Class Unspecified Subclass Progress Code definitions.\r
+//\r
+\r
+///\r
+/// Software Class SEC Subclass Progress Code definitions.\r
+///\r
+///@{\r
+#define EFI_SW_SEC_PC_ENTRY_POINT     (EFI_SUBCLASS_SPECIFIC | 0x00000000)\r
+#define EFI_SW_SEC_PC_HANDOFF_TO_NEXT (EFI_SUBCLASS_SPECIFIC | 0x00000001)\r
+///@}\r
+\r
+///\r
+/// Software Class PEI Core Subclass Progress Code definitions.\r
+///\r
+///@{\r
+#define EFI_SW_PEI_CORE_PC_ENTRY_POINT      (EFI_SUBCLASS_SPECIFIC | 0x00000000)\r
+#define EFI_SW_PEI_CORE_PC_HANDOFF_TO_NEXT  (EFI_SUBCLASS_SPECIFIC | 0x00000001)\r
+#define EFI_SW_PEI_CORE_PC_RETURN_TO_LAST   (EFI_SUBCLASS_SPECIFIC | 0x00000002)\r
+///@}\r
+\r
+///\r
+/// Software Class PEI Module Subclass Progress Code definitions.\r
 ///\r
-#define EFI_AUTH_STATUS_PLATFORM_OVERRIDE   0x01\r
-#define EFI_AUTH_STATUS_IMAGE_SIGNED        0x02\r
-#define EFI_AUTH_STATUS_NOT_TESTED          0x04\r
-#define EFI_AUTH_STATUS_TEST_FAILED         0x08\r
-#define EFI_AUTH_STATUS_ALL                 0x0f\r
+///@{\r
+#define EFI_SW_PEIM_PC_RECOVERY_BEGIN (EFI_SUBCLASS_SPECIFIC | 0x00000000)\r
+#define EFI_SW_PEIM_PC_CAPSULE_LOAD   (EFI_SUBCLASS_SPECIFIC | 0x00000001)\r
+#define EFI_SW_PEIM_PC_CAPSULE_START  (EFI_SUBCLASS_SPECIFIC | 0x00000002)\r
+#define EFI_SW_PEIM_PC_RECOVERY_USER  (EFI_SUBCLASS_SPECIFIC | 0x00000003)\r
+#define EFI_SW_PEIM_PC_RECOVERY_AUTO  (EFI_SUBCLASS_SPECIFIC | 0x00000004)\r
+///@}\r
+\r
+///\r
+/// Software Class DXE Core Subclass Progress Code definitions.\r
+///\r
+///@{\r
+#define EFI_SW_DXE_CORE_PC_ENTRY_POINT      (EFI_SUBCLASS_SPECIFIC | 0x00000000)\r
+#define EFI_SW_DXE_CORE_PC_HANDOFF_TO_NEXT  (EFI_SUBCLASS_SPECIFIC | 0x00000001)\r
+#define EFI_SW_DXE_CORE_PC_RETURN_TO_LAST   (EFI_SUBCLASS_SPECIFIC | 0x00000002)\r
+#define EFI_SW_DXE_CORE_PC_START_DRIVER     (EFI_SUBCLASS_SPECIFIC | 0x00000003)\r
+#define EFI_SW_DXE_CORE_PC_ARCH_READY       (EFI_SUBCLASS_SPECIFIC | 0x00000004)\r
+///@}\r
+\r
+///\r
+/// Software Class DXE BS Driver Subclass Progress Code definitions.\r
+///\r
+///@{\r
+#define EFI_SW_DXE_BS_PC_LEGACY_OPROM_INIT            (EFI_SUBCLASS_SPECIFIC | 0x00000000)\r
+#define EFI_SW_DXE_BS_PC_READY_TO_BOOT_EVENT          (EFI_SUBCLASS_SPECIFIC | 0x00000001)\r
+#define EFI_SW_DXE_BS_PC_LEGACY_BOOT_EVENT            (EFI_SUBCLASS_SPECIFIC | 0x00000002)\r
+#define EFI_SW_DXE_BS_PC_EXIT_BOOT_SERVICES_EVENT     (EFI_SUBCLASS_SPECIFIC | 0x00000003)\r
+#define EFI_SW_DXE_BS_PC_VIRTUAL_ADDRESS_CHANGE_EVENT (EFI_SUBCLASS_SPECIFIC | 0x00000004)\r
+///@}\r
+\r
+//\r
+// Software Class SMM Driver Subclass Progress Code definitions.\r
+//\r
+\r
+//\r
+// Software Class EFI Application Subclass Progress Code definitions.\r
+//\r
+\r
+//\r
+// Software Class EFI OS Loader Subclass Progress Code definitions.\r
+//\r
+\r
+///\r
+/// Software Class EFI RT Subclass Progress Code definitions.\r
+///\r
+///@{\r
+#define EFI_SW_RT_PC_ENTRY_POINT      (EFI_SUBCLASS_SPECIFIC | 0x00000000)\r
+#define EFI_SW_RT_PC_HANDOFF_TO_NEXT  (EFI_SUBCLASS_SPECIFIC | 0x00000001)\r
+#define EFI_SW_RT_PC_RETURN_TO_LAST   (EFI_SUBCLASS_SPECIFIC | 0x00000002)\r
+///@}\r
+\r
+//\r
+// Software Class EBC Exception Subclass Progress Code definitions.\r
+//\r
+\r
+//\r
+// Software Class IA32 Exception Subclass Progress Code definitions.\r
+//\r
+\r
+//\r
+// Software Class X64 Exception Subclass Progress Code definitions.\r
+//\r
+\r
+//\r
+// Software Class IPF Exception Subclass Progress Code definitions.\r
+//\r
+\r
+///\r
+/// Software Class PEI Services Subclass Progress Code definitions.\r
+///\r
+///@{\r
+#define EFI_SW_PS_PC_INSTALL_PPI              (EFI_SUBCLASS_SPECIFIC | 0x00000000)\r
+#define EFI_SW_PS_PC_REINSTALL_PPI            (EFI_SUBCLASS_SPECIFIC | 0x00000001)\r
+#define EFI_SW_PS_PC_LOCATE_PPI               (EFI_SUBCLASS_SPECIFIC | 0x00000002)\r
+#define EFI_SW_PS_PC_NOTIFY_PPI               (EFI_SUBCLASS_SPECIFIC | 0x00000003)\r
+#define EFI_SW_PS_PC_GET_BOOT_MODE            (EFI_SUBCLASS_SPECIFIC | 0x00000004)\r
+#define EFI_SW_PS_PC_SET_BOOT_MODE            (EFI_SUBCLASS_SPECIFIC | 0x00000005)\r
+#define EFI_SW_PS_PC_GET_HOB_LIST             (EFI_SUBCLASS_SPECIFIC | 0x00000006)\r
+#define EFI_SW_PS_PC_CREATE_HOB               (EFI_SUBCLASS_SPECIFIC | 0x00000007)\r
+#define EFI_SW_PS_PC_FFS_FIND_NEXT_VOLUME     (EFI_SUBCLASS_SPECIFIC | 0x00000008)\r
+#define EFI_SW_PS_PC_FFS_FIND_NEXT_FILE       (EFI_SUBCLASS_SPECIFIC | 0x00000009)\r
+#define EFI_SW_PS_PC_FFS_FIND_SECTION_DATA    (EFI_SUBCLASS_SPECIFIC | 0x0000000A)\r
+#define EFI_SW_PS_PC_INSTALL_PEI_MEMORY       (EFI_SUBCLASS_SPECIFIC | 0x0000000B)\r
+#define EFI_SW_PS_PC_ALLOCATE_PAGES           (EFI_SUBCLASS_SPECIFIC | 0x0000000C)\r
+#define EFI_SW_PS_PC_ALLOCATE_POOL            (EFI_SUBCLASS_SPECIFIC | 0x0000000D)\r
+#define EFI_SW_PS_PC_COPY_MEM                 (EFI_SUBCLASS_SPECIFIC | 0x0000000E)\r
+#define EFI_SW_PS_PC_SET_MEM                  (EFI_SUBCLASS_SPECIFIC | 0x0000000F)\r
+#define EFI_SW_PS_PC_RESET_SYSTEM             (EFI_SUBCLASS_SPECIFIC | 0x00000010)\r
+#define EFI_SW_PS_PC_FFS_FIND_FILE_BY_NAME    (EFI_SUBCLASS_SPECIFIC | 0x00000013)\r
+#define EFI_SW_PS_PC_FFS_GET_FILE_INFO        (EFI_SUBCLASS_SPECIFIC | 0x00000014)\r
+#define EFI_SW_PS_PC_FFS_GET_VOLUME_INFO      (EFI_SUBCLASS_SPECIFIC | 0x00000015)\r
+#define EFI_SW_PS_PC_FFS_REGISTER_FOR_SHADOW  (EFI_SUBCLASS_SPECIFIC | 0x00000016)\r
+///@}\r
+\r
+///\r
+/// Software Class EFI Boot Services Subclass Progress Code definitions.\r
+///\r
+///@{\r
+#define EFI_SW_BS_PC_RAISE_TPL                      (EFI_SUBCLASS_SPECIFIC | 0x00000000)\r
+#define EFI_SW_BS_PC_RESTORE_TPL                    (EFI_SUBCLASS_SPECIFIC | 0x00000001)\r
+#define EFI_SW_BS_PC_ALLOCATE_PAGES                 (EFI_SUBCLASS_SPECIFIC | 0x00000002)\r
+#define EFI_SW_BS_PC_FREE_PAGES                     (EFI_SUBCLASS_SPECIFIC | 0x00000003)\r
+#define EFI_SW_BS_PC_GET_MEMORY_MAP                 (EFI_SUBCLASS_SPECIFIC | 0x00000004)\r
+#define EFI_SW_BS_PC_ALLOCATE_POOL                  (EFI_SUBCLASS_SPECIFIC | 0x00000005)\r
+#define EFI_SW_BS_PC_FREE_POOL                      (EFI_SUBCLASS_SPECIFIC | 0x00000006)\r
+#define EFI_SW_BS_PC_CREATE_EVENT                   (EFI_SUBCLASS_SPECIFIC | 0x00000007)\r
+#define EFI_SW_BS_PC_SET_TIMER                      (EFI_SUBCLASS_SPECIFIC | 0x00000008)\r
+#define EFI_SW_BS_PC_WAIT_FOR_EVENT                 (EFI_SUBCLASS_SPECIFIC | 0x00000009)\r
+#define EFI_SW_BS_PC_SIGNAL_EVENT                   (EFI_SUBCLASS_SPECIFIC | 0x0000000A)\r
+#define EFI_SW_BS_PC_CLOSE_EVENT                    (EFI_SUBCLASS_SPECIFIC | 0x0000000B)\r
+#define EFI_SW_BS_PC_CHECK_EVENT                    (EFI_SUBCLASS_SPECIFIC | 0x0000000C)\r
+#define EFI_SW_BS_PC_INSTALL_PROTOCOL_INTERFACE     (EFI_SUBCLASS_SPECIFIC | 0x0000000D)\r
+#define EFI_SW_BS_PC_REINSTALL_PROTOCOL_INTERFACE   (EFI_SUBCLASS_SPECIFIC | 0x0000000E)\r
+#define EFI_SW_BS_PC_UNINSTALL_PROTOCOL_INTERFACE   (EFI_SUBCLASS_SPECIFIC | 0x0000000F)\r
+#define EFI_SW_BS_PC_HANDLE_PROTOCOL                (EFI_SUBCLASS_SPECIFIC | 0x00000010)\r
+#define EFI_SW_BS_PC_PC_HANDLE_PROTOCOL             (EFI_SUBCLASS_SPECIFIC | 0x00000011)\r
+#define EFI_SW_BS_PC_REGISTER_PROTOCOL_NOTIFY       (EFI_SUBCLASS_SPECIFIC | 0x00000012)\r
+#define EFI_SW_BS_PC_LOCATE_HANDLE                  (EFI_SUBCLASS_SPECIFIC | 0x00000013)\r
+#define EFI_SW_BS_PC_INSTALL_CONFIGURATION_TABLE    (EFI_SUBCLASS_SPECIFIC | 0x00000014)\r
+#define EFI_SW_BS_PC_LOAD_IMAGE                     (EFI_SUBCLASS_SPECIFIC | 0x00000015)\r
+#define EFI_SW_BS_PC_START_IMAGE                    (EFI_SUBCLASS_SPECIFIC | 0x00000016)\r
+#define EFI_SW_BS_PC_EXIT                           (EFI_SUBCLASS_SPECIFIC | 0x00000017)\r
+#define EFI_SW_BS_PC_UNLOAD_IMAGE                   (EFI_SUBCLASS_SPECIFIC | 0x00000018)\r
+#define EFI_SW_BS_PC_EXIT_BOOT_SERVICES             (EFI_SUBCLASS_SPECIFIC | 0x00000019)\r
+#define EFI_SW_BS_PC_GET_NEXT_MONOTONIC_COUNT       (EFI_SUBCLASS_SPECIFIC | 0x0000001A)\r
+#define EFI_SW_BS_PC_STALL                          (EFI_SUBCLASS_SPECIFIC | 0x0000001B)\r
+#define EFI_SW_BS_PC_SET_WATCHDOG_TIMER             (EFI_SUBCLASS_SPECIFIC | 0x0000001C)\r
+#define EFI_SW_BS_PC_CONNECT_CONTROLLER             (EFI_SUBCLASS_SPECIFIC | 0x0000001D)\r
+#define EFI_SW_BS_PC_DISCONNECT_CONTROLLER          (EFI_SUBCLASS_SPECIFIC | 0x0000001E)\r
+#define EFI_SW_BS_PC_OPEN_PROTOCOL                  (EFI_SUBCLASS_SPECIFIC | 0x0000001F)\r
+#define EFI_SW_BS_PC_CLOSE_PROTOCOL                 (EFI_SUBCLASS_SPECIFIC | 0x00000020)\r
+#define EFI_SW_BS_PC_OPEN_PROTOCOL_INFORMATION      (EFI_SUBCLASS_SPECIFIC | 0x00000021)\r
+#define EFI_SW_BS_PC_PROTOCOLS_PER_HANDLE           (EFI_SUBCLASS_SPECIFIC | 0x00000022)\r
+#define EFI_SW_BS_PC_LOCATE_HANDLE_BUFFER           (EFI_SUBCLASS_SPECIFIC | 0x00000023)\r
+#define EFI_SW_BS_PC_LOCATE_PROTOCOL                (EFI_SUBCLASS_SPECIFIC | 0x00000024)\r
+#define EFI_SW_BS_PC_INSTALL_MULTIPLE_INTERFACES    (EFI_SUBCLASS_SPECIFIC | 0x00000025)\r
+#define EFI_SW_BS_PC_UNINSTALL_MULTIPLE_INTERFACES  (EFI_SUBCLASS_SPECIFIC | 0x00000026)\r
+#define EFI_SW_BS_PC_CALCULATE_CRC_32               (EFI_SUBCLASS_SPECIFIC | 0x00000027)\r
+#define EFI_SW_BS_PC_COPY_MEM                       (EFI_SUBCLASS_SPECIFIC | 0x00000028)\r
+#define EFI_SW_BS_PC_SET_MEM                        (EFI_SUBCLASS_SPECIFIC | 0x00000029)\r
+#define EFI_SW_BS_PC_CREATE_EVENT_EX                (EFI_SUBCLASS_SPECIFIC | 0x0000002A)\r
+///@}\r
+\r
+///\r
+/// Software Class EFI Runtime Services Subclass Progress Code definitions.\r
+///\r
+///@{\r
+#define EFI_SW_RS_PC_GET_TIME                       (EFI_SUBCLASS_SPECIFIC | 0x00000000)\r
+#define EFI_SW_RS_PC_SET_TIME                       (EFI_SUBCLASS_SPECIFIC | 0x00000001)\r
+#define EFI_SW_RS_PC_GET_WAKEUP_TIME                (EFI_SUBCLASS_SPECIFIC | 0x00000002)\r
+#define EFI_SW_RS_PC_SET_WAKEUP_TIME                (EFI_SUBCLASS_SPECIFIC | 0x00000003)\r
+#define EFI_SW_RS_PC_SET_VIRTUAL_ADDRESS_MAP        (EFI_SUBCLASS_SPECIFIC | 0x00000004)\r
+#define EFI_SW_RS_PC_CONVERT_POINTER                (EFI_SUBCLASS_SPECIFIC | 0x00000005)\r
+#define EFI_SW_RS_PC_GET_VARIABLE                   (EFI_SUBCLASS_SPECIFIC | 0x00000006)\r
+#define EFI_SW_RS_PC_GET_NEXT_VARIABLE_NAME         (EFI_SUBCLASS_SPECIFIC | 0x00000007)\r
+#define EFI_SW_RS_PC_SET_VARIABLE                   (EFI_SUBCLASS_SPECIFIC | 0x00000008)\r
+#define EFI_SW_RS_PC_GET_NEXT_HIGH_MONOTONIC_COUNT  (EFI_SUBCLASS_SPECIFIC | 0x00000009)\r
+#define EFI_SW_RS_PC_RESET_SYSTEM                   (EFI_SUBCLASS_SPECIFIC | 0x0000000A)\r
+#define EFI_SW_RS_PC_UPDATE_CAPSULE                 (EFI_SUBCLASS_SPECIFIC | 0x0000000B)\r
+#define EFI_SW_RS_PC_QUERY_CAPSULE_CAPABILITIES     (EFI_SUBCLASS_SPECIFIC | 0x0000000C)\r
+#define EFI_SW_RS_PC_QUERY_VARIABLE_INFO            (EFI_SUBCLASS_SPECIFIC | 0x0000000D)\r
+///@}\r
+\r
+///\r
+/// Software Class EFI DXE Services Subclass Progress Code definitions\r
+///\r
+///@{\r
+#define EFI_SW_DS_PC_ADD_MEMORY_SPACE             (EFI_SUBCLASS_SPECIFIC | 0x00000000)\r
+#define EFI_SW_DS_PC_ALLOCATE_MEMORY_SPACE        (EFI_SUBCLASS_SPECIFIC | 0x00000001)\r
+#define EFI_SW_DS_PC_FREE_MEMORY_SPACE            (EFI_SUBCLASS_SPECIFIC | 0x00000002)\r
+#define EFI_SW_DS_PC_REMOVE_MEMORY_SPACE          (EFI_SUBCLASS_SPECIFIC | 0x00000003)\r
+#define EFI_SW_DS_PC_GET_MEMORY_SPACE_DESCRIPTOR  (EFI_SUBCLASS_SPECIFIC | 0x00000004)\r
+#define EFI_SW_DS_PC_SET_MEMORY_SPACE_ATTRIBUTES  (EFI_SUBCLASS_SPECIFIC | 0x00000005)\r
+#define EFI_SW_DS_PC_GET_MEMORY_SPACE_MAP         (EFI_SUBCLASS_SPECIFIC | 0x00000006)\r
+#define EFI_SW_DS_PC_ADD_IO_SPACE                 (EFI_SUBCLASS_SPECIFIC | 0x00000007)\r
+#define EFI_SW_DS_PC_ALLOCATE_IO_SPACE            (EFI_SUBCLASS_SPECIFIC | 0x00000008)\r
+#define EFI_SW_DS_PC_FREE_IO_SPACE                (EFI_SUBCLASS_SPECIFIC | 0x00000009)\r
+#define EFI_SW_DS_PC_REMOVE_IO_SPACE              (EFI_SUBCLASS_SPECIFIC | 0x0000000A)\r
+#define EFI_SW_DS_PC_GET_IO_SPACE_DESCRIPTOR      (EFI_SUBCLASS_SPECIFIC | 0x0000000B)\r
+#define EFI_SW_DS_PC_GET_IO_SPACE_MAP             (EFI_SUBCLASS_SPECIFIC | 0x0000000C)\r
+#define EFI_SW_DS_PC_DISPATCH                     (EFI_SUBCLASS_SPECIFIC | 0x0000000D)\r
+#define EFI_SW_DS_PC_SCHEDULE                     (EFI_SUBCLASS_SPECIFIC | 0x0000000E)\r
+#define EFI_SW_DS_PC_TRUST                        (EFI_SUBCLASS_SPECIFIC | 0x0000000F)\r
+#define EFI_SW_DS_PC_PROCESS_FIRMWARE_VOLUME      (EFI_SUBCLASS_SPECIFIC | 0x00000010)\r
+///@}\r
+\r
+///\r
+/// Software Class Error Code definitions.\r
+/// These are shared by all subclasses.\r
+///\r
+///@{\r
+#define EFI_SW_EC_NON_SPECIFIC            0x00000000\r
+#define EFI_SW_EC_LOAD_ERROR              0x00000001\r
+#define EFI_SW_EC_INVALID_PARAMETER       0x00000002\r
+#define EFI_SW_EC_UNSUPPORTED             0x00000003\r
+#define EFI_SW_EC_INVALID_BUFFER          0x00000004\r
+#define EFI_SW_EC_OUT_OF_RESOURCES        0x00000005\r
+#define EFI_SW_EC_ABORTED                 0x00000006\r
+#define EFI_SW_EC_ILLEGAL_SOFTWARE_STATE  0x00000007\r
+#define EFI_SW_EC_ILLEGAL_HARDWARE_STATE  0x00000008\r
+#define EFI_SW_EC_START_ERROR             0x00000009\r
+#define EFI_SW_EC_BAD_DATE_TIME           0x0000000A\r
+#define EFI_SW_EC_CFG_INVALID             0x0000000B\r
+#define EFI_SW_EC_CFG_CLR_REQUEST         0x0000000C\r
+#define EFI_SW_EC_CFG_DEFAULT             0x0000000D\r
+#define EFI_SW_EC_PWD_INVALID             0x0000000E\r
+#define EFI_SW_EC_PWD_CLR_REQUEST         0x0000000F\r
+#define EFI_SW_EC_PWD_CLEARED             0x00000010\r
+#define EFI_SW_EC_EVENT_LOG_FULL          0x00000011\r
+///@}\r
+\r
+//\r
+// Software Class Unspecified Subclass Error Code definitions.\r
+//\r
+\r
+//\r
+// Software Class SEC Subclass Error Code definitions.\r
+//\r
+\r
+///\r
+/// Software Class PEI Core Subclass Error Code definitions.\r
+///\r
+///@{\r
+#define EFI_SW_PEI_CORE_EC_DXE_CORRUPT           (EFI_SUBCLASS_SPECIFIC | 0x00000000)\r
+#define EFI_SW_PEI_CORE_EC_DXEIPL_NOT_FOUND      (EFI_SUBCLASS_SPECIFIC | 0x00000001)\r
+#define EFI_SW_PEI_CORE_EC_MEMORY_NOT_INSTALLED  (EFI_SUBCLASS_SPECIFIC | 0x00000002)\r
+///@}\r
+\r
+///\r
+/// Software Class PEI Module Subclass Error Code definitions.\r
+///\r
+///@{\r
+#define EFI_SW_PEIM_EC_NO_RECOVERY_CAPSULE         (EFI_SUBCLASS_SPECIFIC | 0x00000000)\r
+#define EFI_SW_PEIM_EC_INVALID_CAPSULE_DESCRIPTOR  (EFI_SUBCLASS_SPECIFIC | 0x00000001)\r
+#define EFI_SW_PEI_EC_S3_RESUME_PPI_NOT_FOUND      (EFI_SUBCLASS_SPECIFIC | 0x00000002)\r
+#define EFI_SW_PEI_EC_S3_BOOT_SCRIPT_ERROR         (EFI_SUBCLASS_SPECIFIC | 0x00000003)\r
+#define EFI_SW_PEI_EC_S3_OS_WAKE_ERROR             (EFI_SUBCLASS_SPECIFIC | 0x00000004)\r
+#define EFI_SW_PEI_EC_S3_RESUME_FAILED             (EFI_SUBCLASS_SPECIFIC | 0x00000005)\r
+#define EFI_SW_PEI_EC_RECOVERY_PPI_NOT_FOUND       (EFI_SUBCLASS_SPECIFIC | 0x00000006)\r
+#define EFI_SW_PEI_EC_RECOVERY_FAILED              (EFI_SUBCLASS_SPECIFIC | 0x00000007)\r
+///@}\r
+\r
+///\r
+/// Software Class DXE Foundation Subclass Error Code definitions.\r
+///\r
+///@{\r
+#define EFI_SW_DXE_CORE_EC_NO_ARCH                (EFI_SUBCLASS_SPECIFIC | 0x00000000)\r
+///@}\r
+\r
+\r
+///\r
+/// Software Class DXE Boot Service Driver Subclass Error Code definitions.\r
+///\r
+///@{\r
+#define EFI_SW_DXE_BS_EC_LEGACY_OPROM_NO_SPACE   (EFI_SUBCLASS_SPECIFIC | 0x00000000)\r
+#define EFI_SW_DXE_BS_EC_INVALID_PASSWORD        (EFI_SUBCLASS_SPECIFIC | 0x00000001)\r
+#define EFI_SW_DXE_BS_EC_BOOT_OPTION_LOAD_ERROR  (EFI_SUBCLASS_SPECIFIC | 0x00000002)\r
+#define EFI_SW_DXE_BS_EC_BOOT_OPTION_FAILED      (EFI_SUBCLASS_SPECIFIC | 0x00000003)\r
+#define EFI_SW_DXE_BS_EC_INVALID_IDE_PASSWORD    (EFI_SUBCLASS_SPECIFIC | 0x00000004)\r
+///@}\r
+\r
+//\r
+// Software Class DXE Runtime Service Driver Subclass Error Code definitions.\r
+//\r
+\r
+//\r
+// Software Class SMM Driver Subclass Error Code definitions.\r
+//\r
+\r
+//\r
+// Software Class EFI Application Subclass Error Code definitions.\r
+//\r
+\r
+//\r
+// Software Class EFI OS Loader Subclass Error Code definitions.\r
+//\r
+\r
+//\r
+// Software Class EFI RT Subclass Error Code definitions.\r
+//\r
+\r
+//\r
+// Software Class EFI AL Subclass Error Code definitions.\r
+//\r
+\r
+///\r
+/// Software Class EBC Exception Subclass Error Code definitions.\r
+/// These exceptions are derived from the debug protocol definitions in the EFI\r
+/// specification.\r
+///\r
+///@{\r
+#define EFI_SW_EC_EBC_UNDEFINED             0x00000000\r
+#define EFI_SW_EC_EBC_DIVIDE_ERROR          EXCEPT_EBC_DIVIDE_ERROR\r
+#define EFI_SW_EC_EBC_DEBUG                 EXCEPT_EBC_DEBUG\r
+#define EFI_SW_EC_EBC_BREAKPOINT            EXCEPT_EBC_BREAKPOINT\r
+#define EFI_SW_EC_EBC_OVERFLOW              EXCEPT_EBC_OVERFLOW\r
+#define EFI_SW_EC_EBC_INVALID_OPCODE        EXCEPT_EBC_INVALID_OPCODE\r
+#define EFI_SW_EC_EBC_STACK_FAULT           EXCEPT_EBC_STACK_FAULT\r
+#define EFI_SW_EC_EBC_ALIGNMENT_CHECK       EXCEPT_EBC_ALIGNMENT_CHECK\r
+#define EFI_SW_EC_EBC_INSTRUCTION_ENCODING  EXCEPT_EBC_INSTRUCTION_ENCODING\r
+#define EFI_SW_EC_EBC_BAD_BREAK             EXCEPT_EBC_BAD_BREAK\r
+#define EFI_SW_EC_EBC_STEP                  EXCEPT_EBC_STEP\r
+///@}\r
+\r
+///\r
+/// Software Class IA32 Exception Subclass Error Code definitions.\r
+/// These exceptions are derived from the debug protocol definitions in the EFI\r
+/// specification.\r
+///\r
+///@{\r
+#define EFI_SW_EC_IA32_DIVIDE_ERROR     EXCEPT_IA32_DIVIDE_ERROR\r
+#define EFI_SW_EC_IA32_DEBUG            EXCEPT_IA32_DEBUG\r
+#define EFI_SW_EC_IA32_NMI              EXCEPT_IA32_NMI\r
+#define EFI_SW_EC_IA32_BREAKPOINT       EXCEPT_IA32_BREAKPOINT\r
+#define EFI_SW_EC_IA32_OVERFLOW         EXCEPT_IA32_OVERFLOW\r
+#define EFI_SW_EC_IA32_BOUND            EXCEPT_IA32_BOUND\r
+#define EFI_SW_EC_IA32_INVALID_OPCODE   EXCEPT_IA32_INVALID_OPCODE\r
+#define EFI_SW_EC_IA32_DOUBLE_FAULT     EXCEPT_IA32_DOUBLE_FAULT\r
+#define EFI_SW_EC_IA32_INVALID_TSS      EXCEPT_IA32_INVALID_TSS\r
+#define EFI_SW_EC_IA32_SEG_NOT_PRESENT  EXCEPT_IA32_SEG_NOT_PRESENT\r
+#define EFI_SW_EC_IA32_STACK_FAULT      EXCEPT_IA32_STACK_FAULT\r
+#define EFI_SW_EC_IA32_GP_FAULT         EXCEPT_IA32_GP_FAULT\r
+#define EFI_SW_EC_IA32_PAGE_FAULT       EXCEPT_IA32_PAGE_FAULT\r
+#define EFI_SW_EC_IA32_FP_ERROR         EXCEPT_IA32_FP_ERROR\r
+#define EFI_SW_EC_IA32_ALIGNMENT_CHECK  EXCEPT_IA32_ALIGNMENT_CHECK\r
+#define EFI_SW_EC_IA32_MACHINE_CHECK    EXCEPT_IA32_MACHINE_CHECK\r
+#define EFI_SW_EC_IA32_SIMD             EXCEPT_IA32_SIMD\r
+///@}\r
+\r
+///\r
+/// Software Class IPF Exception Subclass Error Code definitions.\r
+/// These exceptions are derived from the debug protocol definitions in the EFI\r
+/// specification.\r
+///\r
+///@{\r
+#define EFI_SW_EC_IPF_ALT_DTLB            EXCEPT_IPF_ALT_DTLB\r
+#define EFI_SW_EC_IPF_DNESTED_TLB         EXCEPT_IPF_DNESTED_TLB\r
+#define EFI_SW_EC_IPF_BREAKPOINT          EXCEPT_IPF_BREAKPOINT\r
+#define EFI_SW_EC_IPF_EXTERNAL_INTERRUPT  EXCEPT_IPF_EXTERNAL_INTERRUPT\r
+#define EFI_SW_EC_IPF_GEN_EXCEPT          EXCEPT_IPF_GEN_EXCEPT\r
+#define EFI_SW_EC_IPF_NAT_CONSUMPTION     EXCEPT_IPF_NAT_CONSUMPTION\r
+#define EFI_SW_EC_IPF_DEBUG_EXCEPT        EXCEPT_IPF_DEBUG_EXCEPT\r
+#define EFI_SW_EC_IPF_UNALIGNED_ACCESS    EXCEPT_IPF_UNALIGNED_ACCESS\r
+#define EFI_SW_EC_IPF_FP_FAULT            EXCEPT_IPF_FP_FAULT\r
+#define EFI_SW_EC_IPF_FP_TRAP             EXCEPT_IPF_FP_TRAP\r
+#define EFI_SW_EC_IPF_TAKEN_BRANCH        EXCEPT_IPF_TAKEN_BRANCH\r
+#define EFI_SW_EC_IPF_SINGLE_STEP         EXCEPT_IPF_SINGLE_STEP\r
+///@}\r
+\r
+///\r
+/// Software Class PEI Service Subclass Error Code definitions.\r
+///\r
+///@{\r
+#define EFI_SW_PS_EC_RESET_NOT_AVAILABLE     (EFI_SUBCLASS_SPECIFIC | 0x00000000)\r
+#define EFI_SW_PS_EC_MEMORY_INSTALLED_TWICE  (EFI_SUBCLASS_SPECIFIC | 0x00000001)\r
+///@}\r
+\r
+//\r
+// Software Class EFI Boot Service Subclass Error Code definitions.\r
+//\r
+\r
+//\r
+// Software Class EFI Runtime Service Subclass Error Code definitions.\r
+//\r
+\r
+//\r
+// Software Class EFI DXE Service Subclass Error Code definitions.\r
+//\r
 \r
 #endif\r
index a03f67f2e30cd028860386d74376404c85a5ecc4..a143f9d3019f5ed4538ce3fa6b7dca14c13c1897 100644 (file)
   ## Guid for EFI_DISK_INFO_PROTOCOL.Interface to specify Ahci interface.\r
   ## Include/Protocol/DiskInfo.h\r
   gEfiDiskInfoAhciInterfaceGuid  = { 0x9e498932, 0x4abc, 0x45af, { 0xa3, 0x4d, 0x02, 0x47, 0x78, 0x7b, 0xe7, 0xc6 }}\r
+\r
+  ## Include/Guid/StatusCodeDataTypeId.h\r
+  gEfiStatusCodeDataTypeStringGuid = { 0x92D11080, 0x496F, 0x4D95, { 0xBE, 0x7E, 0x03, 0x74, 0x88, 0x38, 0x2B, 0x0A }}\r
+  \r
+  ## Include/Guid/StatusCodeDataTypeId.h\r
+  gEfiStatusCodeSpecificDataGuid   = { 0x335984BD, 0xE805, 0x409A, { 0xB8, 0xF8, 0xD2, 0x7E, 0xCE, 0x5F, 0xF7, 0xA6 }}\r
   \r
 [Ppis]\r
   ## Include/Ppi/MasterBootMode.h\r