2006-04-22 00:54:32 +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.
|
|
|
|
|
|
|
|
Copyright (c) 2006, 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.
|
|
|
|
|
2006-06-26 12:18:28 +02:00
|
|
|
Module Name: SetMem.c
|
2006-04-22 00:54:32 +02:00
|
|
|
|
|
|
|
**/
|
|
|
|
|
2007-01-25 07:05:36 +01:00
|
|
|
#include "MemLibInternals.h"
|
2006-04-22 00:54:32 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
Set Buffer to Value for Size bytes.
|
|
|
|
|
|
|
|
@param Buffer Memory to set.
|
|
|
|
@param Size Number of bytes to set
|
|
|
|
@param Value Value of the set operation.
|
|
|
|
|
|
|
|
@return Buffer
|
|
|
|
|
|
|
|
**/
|
|
|
|
VOID *
|
|
|
|
EFIAPI
|
|
|
|
InternalMemSetMem (
|
|
|
|
IN VOID *Buffer,
|
|
|
|
IN UINTN Size,
|
|
|
|
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;
|
|
|
|
while (Size-- != 0) {
|
|
|
|
*(Pointer++) = Value;
|
|
|
|
}
|
|
|
|
return Buffer;
|
|
|
|
}
|