2007-06-22 05:21:45 +02:00
|
|
|
/** @file
|
|
|
|
Implementation of the EfiSetMem routine. This function is broken
|
|
|
|
out into its own source file so that it can be excluded from a
|
|
|
|
build for a particular platform easily if an optimized version
|
|
|
|
is desired.
|
|
|
|
|
2008-12-29 15:07:07 +01:00
|
|
|
Copyright (c) 2006 - 2008, Intel Corporation<BR>
|
2007-06-22 05:21:45 +02:00
|
|
|
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.
|
|
|
|
|
|
|
|
**/
|
|
|
|
|
2008-09-17 09:46:17 +02:00
|
|
|
|
2007-06-30 01:22:13 +02:00
|
|
|
|
2007-06-22 05:21:45 +02:00
|
|
|
|
|
|
|
#include "MemLibInternals.h"
|
|
|
|
|
|
|
|
/**
|
|
|
|
Set Buffer to Value for Size bytes.
|
|
|
|
|
2008-12-11 05:45:23 +01:00
|
|
|
@param Buffer Memory to set.
|
|
|
|
@param Length Number of bytes to set
|
|
|
|
@param Value Value of the set operation.
|
2007-06-22 05:21:45 +02:00
|
|
|
|
|
|
|
@return Buffer
|
|
|
|
|
|
|
|
**/
|
|
|
|
VOID *
|
|
|
|
EFIAPI
|
|
|
|
InternalMemSetMem (
|
|
|
|
IN VOID *Buffer,
|
2008-10-21 08:55:38 +02:00
|
|
|
IN UINTN Length,
|
2007-06-22 05:21:45 +02:00
|
|
|
IN UINT8 Value
|
|
|
|
)
|
|
|
|
{
|
|
|
|
//
|
|
|
|
// Declare the local variables that actually move the data elements as
|
|
|
|
// volatile to prevent the optimizer from replacing this function with
|
|
|
|
// the intrinsic memset()
|
|
|
|
//
|
|
|
|
volatile UINT8 *Pointer;
|
|
|
|
|
|
|
|
Pointer = (UINT8*)Buffer;
|
2009-01-21 04:17:15 +01:00
|
|
|
while (Length-- > 0) {
|
2007-06-22 05:21:45 +02:00
|
|
|
*(Pointer++) = Value;
|
|
|
|
}
|
|
|
|
return Buffer;
|
|
|
|
}
|