diff options
author | Evgeniy Baskov <baskov@ispras.ru> | 2022-11-22 14:12:31 +0300 |
---|---|---|
committer | Ard Biesheuvel <ardb@kernel.org> | 2023-01-30 13:11:34 +0100 |
commit | 79729f26b074a5d2722c27fa76cc45ef721e65cd (patch) | |
tree | e99860079f0772921c2c1b96dcac9166353eedf7 /drivers/firmware/efi | |
parent | 0217a40d7ba6e71d7f3422fbe89b436e8ee7ece7 (diff) | |
download | linux-79729f26b074a5d2722c27fa76cc45ef721e65cd.tar.gz linux-79729f26b074a5d2722c27fa76cc45ef721e65cd.tar.bz2 linux-79729f26b074a5d2722c27fa76cc45ef721e65cd.zip |
efi/libstub: Add memory attribute protocol definitions
EFI_MEMORY_ATTRIBUTE_PROTOCOL servers as a better alternative to
DXE services for setting memory attributes in EFI Boot Services
environment. This protocol is better since it is a part of UEFI
specification itself and not UEFI PI specification like DXE
services.
Add EFI_MEMORY_ATTRIBUTE_PROTOCOL definitions.
Support mixed mode properly for its calls.
Tested-by: Mario Limonciello <mario.limonciello@amd.com>
Signed-off-by: Evgeniy Baskov <baskov@ispras.ru>
Signed-off-by: Ard Biesheuvel <ardb@kernel.org>
Diffstat (limited to 'drivers/firmware/efi')
-rw-r--r-- | drivers/firmware/efi/libstub/efistub.h | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/drivers/firmware/efi/libstub/efistub.h b/drivers/firmware/efi/libstub/efistub.h index 5b8f2c411ed8..5388c7a9eb16 100644 --- a/drivers/firmware/efi/libstub/efistub.h +++ b/drivers/firmware/efi/libstub/efistub.h @@ -442,6 +442,26 @@ union efi_dxe_services_table { } mixed_mode; }; +typedef union efi_memory_attribute_protocol efi_memory_attribute_protocol_t; + +union efi_memory_attribute_protocol { + struct { + efi_status_t (__efiapi *get_memory_attributes)( + efi_memory_attribute_protocol_t *, efi_physical_addr_t, u64, u64 *); + + efi_status_t (__efiapi *set_memory_attributes)( + efi_memory_attribute_protocol_t *, efi_physical_addr_t, u64, u64); + + efi_status_t (__efiapi *clear_memory_attributes)( + efi_memory_attribute_protocol_t *, efi_physical_addr_t, u64, u64); + }; + struct { + u32 get_memory_attributes; + u32 set_memory_attributes; + u32 clear_memory_attributes; + } mixed_mode; +}; + typedef union efi_uga_draw_protocol efi_uga_draw_protocol_t; union efi_uga_draw_protocol { |