https://bugzilla.tianocore.org/show_bug.cgi?id=1373 Replace BSD 2-Clause License with BSD+Patent License. This change is based on the following emails: https://lists.01.org/pipermail/edk2-devel/2019-February/036260.html https://lists.01.org/pipermail/edk2-devel/2018-October/030385.html RFCs with detailed process for the license change: V3: https://lists.01.org/pipermail/edk2-devel/2019-March/038116.html V2: https://lists.01.org/pipermail/edk2-devel/2019-March/037669.html V1: https://lists.01.org/pipermail/edk2-devel/2019-March/037500.html Contributed-under: TianoCore Contribution Agreement 1.1 Signed-off-by: Michael D Kinney <michael.d.kinney@intel.com> Reviewed-by: Laszlo Ersek <lersek@redhat.com>
		
			
				
	
	
		
			49 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			49 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/** @file
 | 
						|
  Define the module hooks used while probing the QEMU flash device.
 | 
						|
 | 
						|
  Copyright (C) 2018, Advanced Micro Devices. All rights reserved.
 | 
						|
 | 
						|
  SPDX-License-Identifier: BSD-2-Clause-Patent
 | 
						|
 | 
						|
**/
 | 
						|
 | 
						|
#include <Library/BaseMemoryLib.h>
 | 
						|
#include <Library/DebugLib.h>
 | 
						|
#include <Library/PcdLib.h>
 | 
						|
#include <Library/MemEncryptSevLib.h>
 | 
						|
 | 
						|
#include "QemuFlash.h"
 | 
						|
 | 
						|
VOID
 | 
						|
QemuFlashBeforeProbe (
 | 
						|
  IN  EFI_PHYSICAL_ADDRESS    BaseAddress,
 | 
						|
  IN  UINTN                   FdBlockSize,
 | 
						|
  IN  UINTN                   FdBlockCount
 | 
						|
  )
 | 
						|
{
 | 
						|
  EFI_STATUS              Status;
 | 
						|
 | 
						|
  ASSERT (FeaturePcdGet (PcdSmmSmramRequire));
 | 
						|
 | 
						|
  if (!MemEncryptSevIsEnabled ()) {
 | 
						|
    return;
 | 
						|
  }
 | 
						|
 | 
						|
  //
 | 
						|
  // When SEV is enabled, AmdSevDxe runs early in DXE phase and clears the
 | 
						|
  // C-bit from the NonExistent entry -- which is later split and accommodate
 | 
						|
  // the flash MMIO but the driver runs in non SMM context hence it cleared the
 | 
						|
  // flash ranges from non SMM page table. When SMM is enabled, the flash
 | 
						|
  // services are accessed from the SMM mode hence we explicitly clear the
 | 
						|
  // C-bit on flash ranges from SMM page table.
 | 
						|
  //
 | 
						|
 | 
						|
  Status = MemEncryptSevClearPageEncMask (
 | 
						|
             0,
 | 
						|
             BaseAddress,
 | 
						|
             EFI_SIZE_TO_PAGES (FdBlockSize * FdBlockCount),
 | 
						|
             FALSE
 | 
						|
             );
 | 
						|
  ASSERT_EFI_ERROR (Status);
 | 
						|
}
 |