Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: "Yao, Jiewen" <jiewen.yao@intel.com> Reviewed-by: "Gao, Liming" <liming.gao@intel.com> Reviewed-by: "Fan, Jeff" <jeff.fan@intel.com> git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@16693 6f19259b-4bc3-4df7-8a09-765794883524
		
			
				
	
	
		
			138 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			138 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/** @file
 | 
						|
  Provides services for SMM Memory Operation.
 | 
						|
 | 
						|
  The SMM Mem Library provides function for checking if buffer is outside SMRAM and valid.
 | 
						|
  It also provides functions for copy data from SMRAM to non-SMRAM, from non-SMRAM to SMRAM,
 | 
						|
  from non-SMRAM to non-SMRAM, or set data in non-SMRAM.
 | 
						|
  
 | 
						|
  Copyright (c) 2015, Intel Corporation. All rights reserved.<BR>
 | 
						|
  This program and the accompanying materials
 | 
						|
  are licensed and made available under the terms and conditions of the BSD License
 | 
						|
  which accompanies this distribution.  The full text of the license may be found at
 | 
						|
  http://opensource.org/licenses/bsd-license.php
 | 
						|
 | 
						|
  THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
 | 
						|
  WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
 | 
						|
 | 
						|
**/
 | 
						|
 | 
						|
#ifndef _SMM_MEM_LIB_H_
 | 
						|
#define _SMM_MEM_LIB_H_
 | 
						|
 | 
						|
/**
 | 
						|
  This function check if the buffer is valid per processor architecture and not overlap with SMRAM.
 | 
						|
 | 
						|
  @param Buffer  The buffer start address to be checked.
 | 
						|
  @param Length  The buffer length to be checked.
 | 
						|
 | 
						|
  @retval TRUE  This buffer is valid per processor architecture and not overlap with SMRAM.
 | 
						|
  @retval FALSE This buffer is not valid per processor architecture or overlap with SMRAM.
 | 
						|
**/
 | 
						|
BOOLEAN
 | 
						|
EFIAPI
 | 
						|
SmmIsBufferOutsideSmmValid (
 | 
						|
  IN EFI_PHYSICAL_ADDRESS  Buffer,
 | 
						|
  IN UINT64                Length
 | 
						|
  );
 | 
						|
 | 
						|
/**
 | 
						|
  Copies a source buffer (non-SMRAM) to a destination buffer (SMRAM).
 | 
						|
 | 
						|
  This function copies a source buffer (non-SMRAM) to a destination buffer (SMRAM).
 | 
						|
  It checks if source buffer is valid per processor architecture and not overlap with SMRAM.
 | 
						|
  If the check passes, it copies memory and returns EFI_SUCCESS.
 | 
						|
  If the check fails, it return EFI_SECURITY_VIOLATION.
 | 
						|
  The implementation must be reentrant.
 | 
						|
 | 
						|
  @param  DestinationBuffer   The pointer to the destination buffer of the memory copy.
 | 
						|
  @param  SourceBuffer        The pointer to the source buffer of the memory copy.
 | 
						|
  @param  Length              The number of bytes to copy from SourceBuffer to DestinationBuffer.
 | 
						|
 | 
						|
  @retval EFI_SECURITY_VIOLATION The SourceBuffer is invalid per processor architecture or overlap with SMRAM.
 | 
						|
  @retval EFI_SUCCESS            Memory is copied.
 | 
						|
 | 
						|
**/
 | 
						|
EFI_STATUS
 | 
						|
EFIAPI
 | 
						|
SmmCopyMemToSmram (
 | 
						|
  OUT VOID       *DestinationBuffer,
 | 
						|
  IN CONST VOID  *SourceBuffer,
 | 
						|
  IN UINTN       Length
 | 
						|
  );
 | 
						|
 | 
						|
/**
 | 
						|
  Copies a source buffer (SMRAM) to a destination buffer (NON-SMRAM).
 | 
						|
 | 
						|
  This function copies a source buffer (non-SMRAM) to a destination buffer (SMRAM).
 | 
						|
  It checks if destination buffer is valid per processor architecture and not overlap with SMRAM.
 | 
						|
  If the check passes, it copies memory and returns EFI_SUCCESS.
 | 
						|
  If the check fails, it returns EFI_SECURITY_VIOLATION.
 | 
						|
  The implementation must be reentrant.
 | 
						|
  
 | 
						|
  @param  DestinationBuffer   The pointer to the destination buffer of the memory copy.
 | 
						|
  @param  SourceBuffer        The pointer to the source buffer of the memory copy.
 | 
						|
  @param  Length              The number of bytes to copy from SourceBuffer to DestinationBuffer.
 | 
						|
 | 
						|
  @retval EFI_SECURITY_VIOLATION The DesinationBuffer is invalid per processor architecture or overlap with SMRAM.
 | 
						|
  @retval EFI_SUCCESS            Memory is copied.
 | 
						|
 | 
						|
**/
 | 
						|
EFI_STATUS
 | 
						|
EFIAPI
 | 
						|
SmmCopyMemFromSmram (
 | 
						|
  OUT VOID       *DestinationBuffer,
 | 
						|
  IN CONST VOID  *SourceBuffer,
 | 
						|
  IN UINTN       Length
 | 
						|
  );
 | 
						|
 | 
						|
/**
 | 
						|
  Copies a source buffer (NON-SMRAM) to a destination buffer (NON-SMRAM).
 | 
						|
 | 
						|
  This function copies a source buffer (non-SMRAM) to a destination buffer (SMRAM).
 | 
						|
  It checks if source buffer and destination buffer are valid per processor architecture and not overlap with SMRAM.
 | 
						|
  If the check passes, it copies memory and returns EFI_SUCCESS.
 | 
						|
  If the check fails, it returns EFI_SECURITY_VIOLATION.
 | 
						|
  The implementation must be reentrant, and it must handle the case where source buffer overlaps destination buffer.
 | 
						|
  
 | 
						|
  @param  DestinationBuffer   The pointer to the destination buffer of the memory copy.
 | 
						|
  @param  SourceBuffer        The pointer to the source buffer of the memory copy.
 | 
						|
  @param  Length              The number of bytes to copy from SourceBuffer to DestinationBuffer.
 | 
						|
 | 
						|
  @retval EFI_SECURITY_VIOLATION The DesinationBuffer is invalid per processor architecture or overlap with SMRAM.
 | 
						|
  @retval EFI_SECURITY_VIOLATION The SourceBuffer is invalid per processor architecture or overlap with SMRAM.
 | 
						|
  @retval EFI_SUCCESS            Memory is copied.
 | 
						|
 | 
						|
**/
 | 
						|
EFI_STATUS
 | 
						|
EFIAPI
 | 
						|
SmmCopyMem (
 | 
						|
  OUT VOID       *DestinationBuffer,
 | 
						|
  IN CONST VOID  *SourceBuffer,
 | 
						|
  IN UINTN       Length
 | 
						|
  );
 | 
						|
 | 
						|
/**
 | 
						|
  Fills a target buffer (NON-SMRAM) with a byte value.
 | 
						|
 | 
						|
  This function fills a target buffer (non-SMRAM) with a byte value.
 | 
						|
  It checks if target buffer is valid per processor architecture and not overlap with SMRAM.
 | 
						|
  If the check passes, it fills memory and returns EFI_SUCCESS.
 | 
						|
  If the check fails, it returns EFI_SECURITY_VIOLATION.
 | 
						|
  
 | 
						|
  @param  Buffer    The memory to set.
 | 
						|
  @param  Length    The number of bytes to set.
 | 
						|
  @param  Value     The value with which to fill Length bytes of Buffer.
 | 
						|
  
 | 
						|
  @retval EFI_SECURITY_VIOLATION The Buffer is invalid per processor architecture or overlap with SMRAM.
 | 
						|
  @retval EFI_SUCCESS            Memory is set.
 | 
						|
 | 
						|
**/
 | 
						|
EFI_STATUS
 | 
						|
EFIAPI
 | 
						|
SmmSetMem (
 | 
						|
  OUT VOID  *Buffer,
 | 
						|
  IN UINTN  Length,
 | 
						|
  IN UINT8  Value
 | 
						|
  );
 | 
						|
 | 
						|
#endif |