| /** @file | |
| STM Status Codes | |
| Copyright (c) 2015 - 2016, Intel Corporation. All rights reserved.<BR> | |
| This program and the accompanying materials | |
| are licensed and made available under the terms and conditions of the BSD License | |
| which accompanies this distribution. The full text of the license may be found at | |
| http://opensource.org/licenses/bsd-license.php. | |
| THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, | |
| WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | |
| @par Specification Reference: | |
| SMI Transfer Monitor (STM) User Guide Revision 1.00 | |
| **/ | |
| #ifndef _STM_STATUS_CODE_H_ | |
| #define _STM_STATUS_CODE_H_ | |
| /** | |
| STM Status Codes | |
| **/ | |
| typedef UINT32 STM_STATUS; | |
| /** | |
| Success code have BIT31 clear. | |
| All error codes have BIT31 set. | |
| STM errors have BIT16 set. | |
| SMM errors have BIT17 set | |
| Errors that apply to both STM and SMM have bits BIT15, BT16, and BIT17 set. | |
| STM TXT.ERRORCODE codes have BIT30 set. | |
| @{ | |
| **/ | |
| #define STM_SUCCESS 0x00000000 | |
| #define SMM_SUCCESS 0x00000000 | |
| #define ERROR_STM_SECURITY_VIOLATION (BIT31 | BIT16 | 0x0001) | |
| #define ERROR_STM_CACHE_TYPE_NOT_SUPPORTED (BIT31 | BIT16 | 0x0002) | |
| #define ERROR_STM_PAGE_NOT_FOUND (BIT31 | BIT16 | 0x0003) | |
| #define ERROR_STM_BAD_CR3 (BIT31 | BIT16 | 0x0004) | |
| #define ERROR_STM_PHYSICAL_OVER_4G (BIT31 | BIT16 | 0x0005) | |
| #define ERROR_STM_VIRTUAL_SPACE_TOO_SMALL (BIT31 | BIT16 | 0x0006) | |
| #define ERROR_STM_UNPROTECTABLE_RESOURCE (BIT31 | BIT16 | 0x0007) | |
| #define ERROR_STM_ALREADY_STARTED (BIT31 | BIT16 | 0x0008) | |
| #define ERROR_STM_WITHOUT_SMX_UNSUPPORTED (BIT31 | BIT16 | 0x0009) | |
| #define ERROR_STM_STOPPED (BIT31 | BIT16 | 0x000A) | |
| #define ERROR_STM_BUFFER_TOO_SMALL (BIT31 | BIT16 | 0x000B) | |
| #define ERROR_STM_INVALID_VMCS_DATABASE (BIT31 | BIT16 | 0x000C) | |
| #define ERROR_STM_MALFORMED_RESOURCE_LIST (BIT31 | BIT16 | 0x000D) | |
| #define ERROR_STM_INVALID_PAGECOUNT (BIT31 | BIT16 | 0x000E) | |
| #define ERROR_STM_LOG_ALLOCATED (BIT31 | BIT16 | 0x000F) | |
| #define ERROR_STM_LOG_NOT_ALLOCATED (BIT31 | BIT16 | 0x0010) | |
| #define ERROR_STM_LOG_NOT_STOPPED (BIT31 | BIT16 | 0x0011) | |
| #define ERROR_STM_LOG_NOT_STARTED (BIT31 | BIT16 | 0x0012) | |
| #define ERROR_STM_RESERVED_BIT_SET (BIT31 | BIT16 | 0x0013) | |
| #define ERROR_STM_NO_EVENTS_ENABLED (BIT31 | BIT16 | 0x0014) | |
| #define ERROR_STM_OUT_OF_RESOURCES (BIT31 | BIT16 | 0x0015) | |
| #define ERROR_STM_FUNCTION_NOT_SUPPORTED (BIT31 | BIT16 | 0x0016) | |
| #define ERROR_STM_UNPROTECTABLE (BIT31 | BIT16 | 0x0017) | |
| #define ERROR_STM_UNSUPPORTED_MSR_BIT (BIT31 | BIT16 | 0x0018) | |
| #define ERROR_STM_UNSPECIFIED (BIT31 | BIT16 | 0xFFFF) | |
| #define ERROR_SMM_BAD_BUFFER (BIT31 | BIT17 | 0x0001) | |
| #define ERROR_SMM_INVALID_RSC (BIT31 | BIT17 | 0x0004) | |
| #define ERROR_SMM_INVALID_BUFFER_SIZE (BIT31 | BIT17 | 0x0005) | |
| #define ERROR_SMM_BUFFER_TOO_SHORT (BIT31 | BIT17 | 0x0006) | |
| #define ERROR_SMM_INVALID_LIST (BIT31 | BIT17 | 0x0007) | |
| #define ERROR_SMM_OUT_OF_MEMORY (BIT31 | BIT17 | 0x0008) | |
| #define ERROR_SMM_AFTER_INIT (BIT31 | BIT17 | 0x0009) | |
| #define ERROR_SMM_UNSPECIFIED (BIT31 | BIT17 | 0xFFFF) | |
| #define ERROR_INVALID_API (BIT31 | BIT17 | BIT16 | BIT15 | 0x0001) | |
| #define ERROR_INVALID_PARAMETER (BIT31 | BIT17 | BIT16 | BIT15 | 0x0002) | |
| #define STM_CRASH_PROTECTION_EXCEPTION (BIT31 | BIT30 | 0xF001) | |
| #define STM_CRASH_PROTECTION_EXCEPTION_FAILURE (BIT31 | BIT30 | 0xF002) | |
| #define STM_CRASH_DOMAIN_DEGRADATION_FAILURE (BIT31 | BIT30 | 0xF003) | |
| #define STM_CRASH_BIOS_PANIC (BIT31 | BIT30 | 0xE000) | |
| /// @} | |
| #endif |