2017-07-06 15:21:12 +02:00
|
|
|
/** @file
|
|
|
|
|
|
|
|
Virtual Memory Management Services to set or clear the memory encryption bit
|
|
|
|
|
2018-03-01 14:32:23 +01:00
|
|
|
Copyright (c) 2006 - 2016, Intel Corporation. All rights reserved.<BR>
|
2021-01-07 19:48:22 +01:00
|
|
|
Copyright (c) 2017 - 2020, AMD Incorporated. All rights reserved.<BR>
|
2017-07-06 15:21:12 +02:00
|
|
|
|
2019-04-04 01:06:33 +02:00
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
2017-07-06 15:21:12 +02:00
|
|
|
|
2018-03-01 14:32:23 +01:00
|
|
|
Code is derived from MdeModulePkg/Core/DxeIplPeim/X64/VirtualMemory.h
|
2017-07-06 15:21:12 +02:00
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
#ifndef __VIRTUAL_MEMORY__
|
|
|
|
#define __VIRTUAL_MEMORY__
|
|
|
|
|
2021-04-12 15:30:00 +02:00
|
|
|
#include <IndustryStandard/PageTable.h>
|
2017-07-06 15:21:12 +02:00
|
|
|
#include <Library/BaseLib.h>
|
|
|
|
#include <Library/BaseMemoryLib.h>
|
2018-03-01 15:02:11 +01:00
|
|
|
#include <Library/CacheMaintenanceLib.h>
|
2017-07-06 15:21:12 +02:00
|
|
|
#include <Library/DebugLib.h>
|
|
|
|
#include <Library/MemoryAllocationLib.h>
|
2018-03-01 15:02:11 +01:00
|
|
|
#include <Uefi.h>
|
2017-07-06 15:21:12 +02:00
|
|
|
|
|
|
|
#define SYS_CODE64_SEL 0x38
|
|
|
|
|
2018-01-11 20:51:01 +01:00
|
|
|
#define PAGE_TABLE_POOL_ALIGNMENT BASE_2MB
|
|
|
|
#define PAGE_TABLE_POOL_UNIT_SIZE SIZE_2MB
|
2018-03-01 14:32:23 +01:00
|
|
|
#define PAGE_TABLE_POOL_UNIT_PAGES \
|
|
|
|
EFI_SIZE_TO_PAGES (PAGE_TABLE_POOL_UNIT_SIZE)
|
2018-01-11 20:51:01 +01:00
|
|
|
#define PAGE_TABLE_POOL_ALIGN_MASK \
|
|
|
|
(~(EFI_PHYSICAL_ADDRESS)(PAGE_TABLE_POOL_ALIGNMENT - 1))
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
VOID *NextPool;
|
|
|
|
UINTN Offset;
|
|
|
|
UINTN FreePages;
|
|
|
|
} PAGE_TABLE_POOL;
|
|
|
|
|
2021-01-07 19:48:22 +01:00
|
|
|
/**
|
|
|
|
Return the pagetable memory encryption mask.
|
2018-01-11 20:51:01 +01:00
|
|
|
|
2021-01-07 19:48:22 +01:00
|
|
|
@return The pagetable memory encryption mask.
|
|
|
|
|
|
|
|
**/
|
|
|
|
UINT64
|
|
|
|
EFIAPI
|
|
|
|
InternalGetMemEncryptionAddressMask (
|
|
|
|
VOID
|
|
|
|
);
|
2018-01-11 20:51:01 +01:00
|
|
|
|
2017-07-06 15:21:12 +02:00
|
|
|
/**
|
2018-03-01 14:32:23 +01:00
|
|
|
This function clears memory encryption bit for the memory region specified by
|
2018-03-01 15:15:39 +01:00
|
|
|
PhysicalAddress and Length from the current page table context.
|
2017-07-06 15:21:12 +02:00
|
|
|
|
2018-03-01 15:15:39 +01:00
|
|
|
@param[in] Cr3BaseAddress Cr3 Base Address (if zero then use
|
|
|
|
current CR3)
|
2018-03-01 14:32:23 +01:00
|
|
|
@param[in] PhysicalAddress The physical address that is the start
|
|
|
|
address of a memory region.
|
2017-07-06 15:21:12 +02:00
|
|
|
@param[in] Length The length of memory region
|
|
|
|
|
2018-03-01 14:32:23 +01:00
|
|
|
@retval RETURN_SUCCESS The attributes were cleared for the
|
|
|
|
memory region.
|
2017-07-06 15:21:12 +02:00
|
|
|
@retval RETURN_INVALID_PARAMETER Number of pages is zero.
|
2018-03-01 15:15:39 +01:00
|
|
|
@retval RETURN_UNSUPPORTED Clearing the memory encyrption attribute
|
2018-03-01 14:32:23 +01:00
|
|
|
is not supported
|
2017-07-06 15:21:12 +02:00
|
|
|
**/
|
|
|
|
RETURN_STATUS
|
|
|
|
EFIAPI
|
|
|
|
InternalMemEncryptSevSetMemoryDecrypted (
|
2018-03-01 15:15:39 +01:00
|
|
|
IN PHYSICAL_ADDRESS Cr3BaseAddress,
|
|
|
|
IN PHYSICAL_ADDRESS PhysicalAddress,
|
2021-05-19 20:19:49 +02:00
|
|
|
IN UINTN Length
|
2017-07-06 15:21:12 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
This function sets memory encryption bit for the memory region specified by
|
2018-03-01 15:15:39 +01:00
|
|
|
PhysicalAddress and Length from the current page table context.
|
2017-07-06 15:21:12 +02:00
|
|
|
|
2018-03-01 15:15:39 +01:00
|
|
|
@param[in] Cr3BaseAddress Cr3 Base Address (if zero then use
|
|
|
|
current CR3)
|
2018-03-01 14:32:23 +01:00
|
|
|
@param[in] PhysicalAddress The physical address that is the start
|
|
|
|
address of a memory region.
|
2017-07-06 15:21:12 +02:00
|
|
|
@param[in] Length The length of memory region
|
|
|
|
|
2018-03-01 15:15:39 +01:00
|
|
|
@retval RETURN_SUCCESS The attributes were set for the memory
|
|
|
|
region.
|
2017-07-06 15:21:12 +02:00
|
|
|
@retval RETURN_INVALID_PARAMETER Number of pages is zero.
|
2018-03-01 14:32:23 +01:00
|
|
|
@retval RETURN_UNSUPPORTED Setting the memory encyrption attribute
|
|
|
|
is not supported
|
2017-07-06 15:21:12 +02:00
|
|
|
**/
|
|
|
|
RETURN_STATUS
|
|
|
|
EFIAPI
|
|
|
|
InternalMemEncryptSevSetMemoryEncrypted (
|
2018-03-01 15:15:39 +01:00
|
|
|
IN PHYSICAL_ADDRESS Cr3BaseAddress,
|
|
|
|
IN PHYSICAL_ADDRESS PhysicalAddress,
|
2021-05-19 20:19:49 +02:00
|
|
|
IN UINTN Length
|
2017-07-06 15:21:12 +02:00
|
|
|
);
|
|
|
|
|
2021-01-07 19:48:22 +01:00
|
|
|
/**
|
|
|
|
Returns the encryption state of the specified virtual address range.
|
|
|
|
|
|
|
|
@param[in] Cr3BaseAddress Cr3 Base Address (if zero then use
|
|
|
|
current CR3)
|
|
|
|
@param[in] BaseAddress Base address to check
|
|
|
|
@param[in] Length Length of virtual address range
|
|
|
|
|
|
|
|
@retval MemEncryptSevAddressRangeUnencrypted Address range is mapped
|
|
|
|
unencrypted
|
|
|
|
@retval MemEncryptSevAddressRangeEncrypted Address range is mapped
|
|
|
|
encrypted
|
|
|
|
@retval MemEncryptSevAddressRangeMixed Address range is mapped mixed
|
|
|
|
@retval MemEncryptSevAddressRangeError Address range is not mapped
|
|
|
|
**/
|
|
|
|
MEM_ENCRYPT_SEV_ADDRESS_RANGE_STATE
|
|
|
|
EFIAPI
|
|
|
|
InternalMemEncryptSevGetAddressRangeState (
|
|
|
|
IN PHYSICAL_ADDRESS Cr3BaseAddress,
|
|
|
|
IN PHYSICAL_ADDRESS BaseAddress,
|
|
|
|
IN UINTN Length
|
|
|
|
);
|
|
|
|
|
2021-05-19 20:19:45 +02:00
|
|
|
/**
|
|
|
|
This function clears memory encryption bit for the MMIO region specified by
|
|
|
|
PhysicalAddress and Length.
|
|
|
|
|
|
|
|
@param[in] Cr3BaseAddress Cr3 Base Address (if zero then use
|
|
|
|
current CR3)
|
|
|
|
@param[in] PhysicalAddress The physical address that is the start
|
|
|
|
address of a MMIO region.
|
|
|
|
@param[in] Length The length of memory region
|
|
|
|
|
|
|
|
@retval RETURN_SUCCESS The attributes were cleared for the
|
|
|
|
memory region.
|
|
|
|
@retval RETURN_INVALID_PARAMETER Length is zero.
|
|
|
|
@retval RETURN_UNSUPPORTED Clearing the memory encyrption attribute
|
|
|
|
is not supported
|
|
|
|
**/
|
|
|
|
RETURN_STATUS
|
|
|
|
EFIAPI
|
|
|
|
InternalMemEncryptSevClearMmioPageEncMask (
|
|
|
|
IN PHYSICAL_ADDRESS Cr3BaseAddress,
|
|
|
|
IN PHYSICAL_ADDRESS PhysicalAddress,
|
|
|
|
IN UINTN Length
|
|
|
|
);
|
2021-12-05 23:54:09 +01:00
|
|
|
|
2021-12-09 04:27:45 +01:00
|
|
|
/**
|
|
|
|
Create 1GB identity mapping for the specified virtual address range.
|
|
|
|
|
|
|
|
The function is preliminary used by the SEV-SNP page state change
|
|
|
|
APIs to build the page table required before issuing the PVALIDATE
|
|
|
|
instruction. The function must be removed after the EDK2 core is
|
|
|
|
enhanced to do the lazy validation.
|
|
|
|
|
|
|
|
@param[in] Cr3BaseAddress Cr3 Base Address (if zero then use
|
|
|
|
current CR3)
|
|
|
|
@param[in] VirtualAddress Virtual address
|
|
|
|
@param[in] Length Length of virtual address range
|
|
|
|
|
|
|
|
@retval RETURN_INVALID_PARAMETER Number of pages is zero.
|
|
|
|
|
|
|
|
**/
|
|
|
|
RETURN_STATUS
|
|
|
|
EFIAPI
|
|
|
|
InternalMemEncryptSevCreateIdentityMap1G (
|
|
|
|
IN PHYSICAL_ADDRESS Cr3BaseAddress,
|
|
|
|
IN PHYSICAL_ADDRESS PhysicalAddress,
|
|
|
|
IN UINTN Length
|
|
|
|
);
|
|
|
|
|
2017-07-06 15:21:12 +02:00
|
|
|
#endif
|