BZ: https://bugzilla.tianocore.org/show_bug.cgi?id=3275 Virtual Machine Privilege Level (VMPL) feature in the SEV-SNP architecture allows a guest VM to divide its address space into four levels. The level can be used to provide the hardware isolated abstraction layers with a VM. The VMPL0 is the highest privilege, and VMPL3 is the least privilege. Certain operations must be done by the VMPL0 software, such as: * Validate or invalidate memory range (PVALIDATE instruction) * Allocate VMSA page (RMPADJUST instruction when VMSA=1) The initial SEV-SNP support assumes that the guest is running on VMPL0. Let's add function in the MemEncryptSevLib that can be used for checking whether guest is booted under the VMPL0. Cc: Michael Roth <michael.roth@amd.com> Cc: James Bottomley <jejb@linux.ibm.com> Cc: Min Xu <min.m.xu@intel.com> Cc: Jiewen Yao <jiewen.yao@intel.com> Cc: Tom Lendacky <thomas.lendacky@amd.com> Cc: Jordan Justen <jordan.l.justen@intel.com> Cc: Ard Biesheuvel <ardb+tianocore@kernel.org> Cc: Erdem Aktas <erdemaktas@google.com> Cc: Gerd Hoffmann <kraxel@redhat.com> Acked-by: Gerd Hoffmann <kraxel@redhat.com> Signed-off-by: Brijesh Singh <brijesh.singh@amd.com>
		
			
				
	
	
		
			36 lines
		
	
	
		
			623 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			36 lines
		
	
	
		
			623 B
		
	
	
	
		
			C
		
	
	
	
	
	
| /** @file
 | |
| 
 | |
|   SEV-SNP Page Validation functions.
 | |
| 
 | |
|   Copyright (c) 2021 AMD Incorporated. All rights reserved.<BR>
 | |
| 
 | |
|   SPDX-License-Identifier: BSD-2-Clause-Patent
 | |
| 
 | |
| **/
 | |
| 
 | |
| #ifndef SNP_PAGE_STATE_INTERNAL_H_
 | |
| #define SNP_PAGE_STATE_INTERNAL_H_
 | |
| 
 | |
| //
 | |
| // SEV-SNP Page states
 | |
| //
 | |
| typedef enum {
 | |
|   SevSnpPagePrivate,
 | |
|   SevSnpPageShared,
 | |
| } SEV_SNP_PAGE_STATE;
 | |
| 
 | |
| VOID
 | |
| InternalSetPageState (
 | |
|   IN EFI_PHYSICAL_ADDRESS  BaseAddress,
 | |
|   IN UINTN                 NumPages,
 | |
|   IN SEV_SNP_PAGE_STATE    State,
 | |
|   IN BOOLEAN               UseLargeEntry
 | |
|   );
 | |
| 
 | |
| VOID
 | |
| SnpPageStateFailureTerminate (
 | |
|   VOID
 | |
|   );
 | |
| 
 | |
| #endif
 |