| /** @file | |
| Base Memory Library functions implementation bases on Uefi Boot Service. | |
| Copyright (c) 2006 - 2008, Intel Corporation<BR> | |
| All rights reserved. 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. | |
| **/ | |
| #include "MemLibInternals.h" | |
| /** | |
| Copies a source buffer to a destination buffer, and returns the destination buffer. | |
| This function wraps the gBS->CopyMem(). | |
| @param DestinationBuffer Pointer to the destination buffer of the memory copy. | |
| @param SourceBuffer Pointer to the source buffer of the memory copy. | |
| @param Length Number of bytes to copy from SourceBuffer to DestinationBuffer. | |
| @return DestinationBuffer. | |
| **/ | |
| VOID * | |
| EFIAPI | |
| InternalMemCopyMem ( | |
| OUT VOID *Destination, | |
| IN CONST VOID *Source, | |
| IN UINTN Length | |
| ) | |
| { | |
| gBS->CopyMem (Destination, (VOID*)Source, Length); | |
| return Destination; | |
| } | |
| /** | |
| Fills a target buffer with a byte value, and returns the target buffer. | |
| This function wraps the gBS->SetMem(). | |
| @param Buffer Memory to set. | |
| @param Size Number of bytes to set. | |
| @param Value Value of the set operation. | |
| @return Buffer. | |
| **/ | |
| VOID * | |
| EFIAPI | |
| InternalMemSetMem ( | |
| OUT VOID *Buffer, | |
| IN UINTN Size, | |
| IN UINT8 Value | |
| ) | |
| { | |
| gBS->SetMem (Buffer, Size, Value); | |
| return Buffer; | |
| } |