BZ: https://bugzilla.tianocore.org/show_bug.cgi?id=4654 The SVSM specification documents an alternative method of discovery for the SVSM using a reserved CPUID bit and a reserved MSR. For the CPUID support, the #VC handler of an SEV-SNP guest should modify the returned value in the EAX register for the 0x8000001f CPUID function by setting bit 28 when an SVSM is present. For the MSR support, new reserved MSR 0xc001f000 has been defined. A #VC should be generated when accessing this MSR. The #VC handler is expected to ignore writes to this MSR and return the physical calling area address (CAA) on reads of this MSR. Cc: Ard Biesheuvel <ardb+tianocore@kernel.org> Cc: Erdem Aktas <erdemaktas@google.com> Cc: Gerd Hoffmann <kraxel@redhat.com> Cc: Jiewen Yao <jiewen.yao@intel.com> Cc: Laszlo Ersek <lersek@redhat.com> Cc: Michael Roth <michael.roth@amd.com> Cc: Min Xu <min.m.xu@intel.com> Acked-by: Gerd Hoffmann <kraxel@redhat.com> Signed-off-by: Tom Lendacky <thomas.lendacky@amd.com>
		
			
				
	
	
		
			51 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			INI
		
	
	
	
	
	
			
		
		
	
	
			51 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			INI
		
	
	
	
	
	
| ## @file
 | |
| #  VMGEXIT Support Library.
 | |
| #
 | |
| #  Copyright (C) 2020 - 2024, Advanced Micro Devices, Inc. All rights reserved.<BR>
 | |
| #  SPDX-License-Identifier: BSD-2-Clause-Patent
 | |
| #
 | |
| ##
 | |
| 
 | |
| [Defines]
 | |
|   INF_VERSION                    = 0x00010005
 | |
|   BASE_NAME                      = SecCcExitLib
 | |
|   FILE_GUID                      = dafff819-f86c-4cff-a70e-83161e5bcf9a
 | |
|   MODULE_TYPE                    = BASE
 | |
|   VERSION_STRING                 = 1.0
 | |
|   LIBRARY_CLASS                  = CcExitLib|SEC
 | |
| 
 | |
| #
 | |
| # The following information is for reference only and not required by the build tools.
 | |
| #
 | |
| #  VALID_ARCHITECTURES           = X64
 | |
| #
 | |
| 
 | |
| [Sources.common]
 | |
|   CcExitLib.c
 | |
|   CcExitVcHandler.c
 | |
|   CcExitVcHandler.h
 | |
|   CcInstruction.c
 | |
|   SecCcExitVcHandler.c
 | |
|   CcExitVeHandler.c
 | |
|   X64/TdVmcallCpuid.nasm
 | |
| 
 | |
| [Packages]
 | |
|   MdePkg/MdePkg.dec
 | |
|   OvmfPkg/OvmfPkg.dec
 | |
|   UefiCpuPkg/UefiCpuPkg.dec
 | |
| 
 | |
| [LibraryClasses]
 | |
|   BaseLib
 | |
|   BaseMemoryLib
 | |
|   DebugLib
 | |
|   LocalApicLib
 | |
|   MemEncryptSevLib
 | |
|   PcdLib
 | |
|   AmdSvsmLib
 | |
| 
 | |
| [FixedPcd]
 | |
|   gUefiOvmfPkgTokenSpaceGuid.PcdOvmfSecGhcbBackupBase
 | |
|   gUefiOvmfPkgTokenSpaceGuid.PcdOvmfSecGhcbBackupSize
 | |
|   gUefiOvmfPkgTokenSpaceGuid.PcdOvmfCpuidBase
 | |
|   gUefiOvmfPkgTokenSpaceGuid.PcdOvmfCpuidSize
 |