]> git.proxmox.com Git - mirror_edk2.git/blob - CryptoPkg/Library/IntrinsicLib/MemoryIntrinsics.c
1. Add new API supports for PEM & X509 key retrieving & verification;
[mirror_edk2.git] / CryptoPkg / Library / IntrinsicLib / MemoryIntrinsics.c
1 /** @file
2 Intrinsic Memory Routines Wrapper Implementation for OpenSSL-based
3 Cryptographic Library.
4
5 Copyright (c) 2010, Intel Corporation. All rights reserved.<BR>
6 This program and the accompanying materials
7 are licensed and made available under the terms and conditions of the BSD License
8 which accompanies this distribution. The full text of the license may be found at
9 http://opensource.org/licenses/bsd-license.php
10
11 THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
12 WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
13
14 **/
15
16 #include <Base.h>
17 #include <Library/BaseMemoryLib.h>
18
19 /* OpenSSL will use floating point support, and C compiler produces the _fltused
20 symbol by default. Simply define this symbol here to satisfy the linker. */
21 int _fltused = 1;
22
23 /* Sets buffers to a specified character */
24 void * memset (void *dest, char ch, unsigned int count)
25 {
26 //
27 // Declare the local variables that actually move the data elements as
28 // volatile to prevent the optimizer from replacing this function with
29 // the intrinsic memset()
30 //
31 volatile UINT8 *Pointer;
32
33 Pointer = (UINT8 *)dest;
34 while (count-- != 0) {
35 *(Pointer++) = ch;
36 }
37
38 return dest;
39 }