| /** @file | |
| Provides services for MM Memory Operation. | |
| The MM Mem Library provides function for checking if buffer is outside MMRAM and valid. | |
| It also provides functions for copy data from MMRAM to non-MMRAM, from non-MMRAM to MMRAM, | |
| from non-MMRAM to non-MMRAM, or set data in non-MMRAM. | |
| Copyright (c) 2015, Intel Corporation. All rights reserved.<BR> | |
| Copyright (c) 2016 - 2021, Arm Limited. All rights reserved.<BR> | |
| SPDX-License-Identifier: BSD-2-Clause-Patent | |
| **/ | |
| #ifndef _MM_MEM_LIB_H_ | |
| #define _MM_MEM_LIB_H_ | |
| /** | |
| This function check if the buffer is valid per processor architecture and not overlap with MMRAM. | |
| @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 MMRAM. | |
| @retval FALSE This buffer is not valid per processor architecture or overlap with MMRAM. | |
| **/ | |
| BOOLEAN | |
| EFIAPI | |
| MmIsBufferOutsideMmValid ( | |
| IN EFI_PHYSICAL_ADDRESS Buffer, | |
| IN UINT64 Length | |
| ); | |
| /** | |
| Copies a source buffer (non-MMRAM) to a destination buffer (MMRAM). | |
| This function copies a source buffer (non-MMRAM) to a destination buffer (MMRAM). | |
| It checks if source buffer is valid per processor architecture and not overlap with MMRAM. | |
| 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 MMRAM. | |
| @retval EFI_SUCCESS Memory is copied. | |
| **/ | |
| EFI_STATUS | |
| EFIAPI | |
| MmCopyMemToMmram ( | |
| OUT VOID *DestinationBuffer, | |
| IN CONST VOID *SourceBuffer, | |
| IN UINTN Length | |
| ); | |
| /** | |
| Copies a source buffer (MMRAM) to a destination buffer (NON-MMRAM). | |
| This function copies a source buffer (non-MMRAM) to a destination buffer (MMRAM). | |
| It checks if destination buffer is valid per processor architecture and not overlap with MMRAM. | |
| 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 DestinationBuffer is invalid per processor architecture or overlap with MMRAM. | |
| @retval EFI_SUCCESS Memory is copied. | |
| **/ | |
| EFI_STATUS | |
| EFIAPI | |
| MmCopyMemFromMmram ( | |
| OUT VOID *DestinationBuffer, | |
| IN CONST VOID *SourceBuffer, | |
| IN UINTN Length | |
| ); | |
| /** | |
| Copies a source buffer (NON-MMRAM) to a destination buffer (NON-MMRAM). | |
| This function copies a source buffer (non-MMRAM) to a destination buffer (MMRAM). | |
| It checks if source buffer and destination buffer are valid per processor architecture and not overlap with MMRAM. | |
| 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 DestinationBuffer is invalid per processor architecture or overlap with MMRAM. | |
| @retval EFI_SECURITY_VIOLATION The SourceBuffer is invalid per processor architecture or overlap with MMRAM. | |
| @retval EFI_SUCCESS Memory is copied. | |
| **/ | |
| EFI_STATUS | |
| EFIAPI | |
| MmCopyMem ( | |
| OUT VOID *DestinationBuffer, | |
| IN CONST VOID *SourceBuffer, | |
| IN UINTN Length | |
| ); | |
| /** | |
| Fills a target buffer (NON-MMRAM) with a byte value. | |
| This function fills a target buffer (non-MMRAM) with a byte value. | |
| It checks if target buffer is valid per processor architecture and not overlap with MMRAM. | |
| 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 MMRAM. | |
| @retval EFI_SUCCESS Memory is set. | |
| **/ | |
| EFI_STATUS | |
| EFIAPI | |
| MmSetMem ( | |
| OUT VOID *Buffer, | |
| IN UINTN Length, | |
| IN UINT8 Value | |
| ); | |
| #endif |