mirror of https://github.com/acidanthera/audk.git
67 lines
2.4 KiB
C
67 lines
2.4 KiB
C
/** @file
|
|
Guid & data structure for EFI_RT _PROPERTIES_TABLE, designed to be published by a
|
|
platform if it no longer supports all EFI runtime services once ExitBootServices()
|
|
has been called by the OS. Introduced in UEFI 2.8a.
|
|
|
|
|
|
Copyright (c) 2020, American Megatrends International LLC. All rights reserved.<BR>
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
|
|
|
**/
|
|
|
|
#ifndef __RT_PROPERTIES_TABLE_GUID_H__
|
|
#define __RT_PROPERTIES_TABLE_GUID_H__
|
|
|
|
//
|
|
// Table, defined here, should be published by a platform if it no longer supports all EFI runtime
|
|
// services once ExitBootServices() has been called by the OS. Note that this is merely a hint
|
|
// to the OS, which it is free to ignore, and so the platform is still required to provide callable
|
|
// implementations of unsupported runtime services that simply return EFI_UNSUPPORTED.
|
|
//
|
|
#define EFI_RT_PROPERTIES_TABLE_GUID \
|
|
{ 0xeb66918a, 0x7eef, 0x402a, \
|
|
{ 0x84, 0x2e, 0x93, 0x1d, 0x21, 0xc3, 0x8a, 0xe9 }}
|
|
|
|
#pragma pack(1)
|
|
|
|
typedef struct {
|
|
///
|
|
/// Version of the structure, must be 0x1.
|
|
///
|
|
UINT16 Version;
|
|
|
|
///
|
|
/// Size in bytes of the entire EFI_RT_PROPERTIES_TABLE, must be 8.
|
|
///
|
|
UINT16 Length;
|
|
|
|
///
|
|
/// Bitmask of which calls are or are not supported, where a bit set to 1 indicates
|
|
/// that the call is supported, and 0 indicates that it is not.
|
|
///
|
|
UINT32 RuntimeServicesSupported;
|
|
} EFI_RT_PROPERTIES_TABLE;
|
|
|
|
#pragma pack()
|
|
|
|
#define EFI_RT_PROPERTIES_TABLE_VERSION 0x1
|
|
|
|
#define EFI_RT_SUPPORTED_GET_TIME 0x0001
|
|
#define EFI_RT_SUPPORTED_SET_TIME 0x0002
|
|
#define EFI_RT_SUPPORTED_GET_WAKEUP_TIME 0x0004
|
|
#define EFI_RT_SUPPORTED_SET_WAKEUP_TIME 0x0008
|
|
#define EFI_RT_SUPPORTED_GET_VARIABLE 0x0010
|
|
#define EFI_RT_SUPPORTED_GET_NEXT_VARIABLE_NAME 0x0020
|
|
#define EFI_RT_SUPPORTED_SET_VARIABLE 0x0040
|
|
#define EFI_RT_SUPPORTED_SET_VIRTUAL_ADDRESS_MAP 0x0080
|
|
#define EFI_RT_SUPPORTED_CONVERT_POINTER 0x0100
|
|
#define EFI_RT_SUPPORTED_GET_NEXT_HIGH_MONOTONIC_COUNT 0x0200
|
|
#define EFI_RT_SUPPORTED_RESET_SYSTEM 0x0400
|
|
#define EFI_RT_SUPPORTED_UPDATE_CAPSULE 0x0800
|
|
#define EFI_RT_SUPPORTED_QUERY_CAPSULE_CAPABILITIES 0x1000
|
|
#define EFI_RT_SUPPORTED_QUERY_VARIABLE_INFO 0x2000
|
|
|
|
extern EFI_GUID gEfiRtPropertiesTableGuid;
|
|
|
|
#endif
|