/** @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; | |
} |