--- /dev/null
+/** @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
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
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