ArmPkg: only attempt buildin MmCommunicationDxe for AArch64
[mirror_edk2.git] / CryptoPkg / Library / IntrinsicLib / MemoryIntrinsics.c
1 /** @file\r
2   Intrinsic Memory Routines Wrapper Implementation for OpenSSL-based\r
3   Cryptographic Library.\r
4 \r
5 Copyright (c) 2010 - 2019, Intel Corporation. All rights reserved.<BR>\r
6 SPDX-License-Identifier: BSD-2-Clause-Patent\r
7 \r
8 **/\r
9 \r
10 #include <Base.h>\r
11 #include <Library/BaseMemoryLib.h>\r
12 #include <Library/BaseLib.h>\r
13 \r
14 typedef UINTN  size_t;\r
15 \r
16 #if defined(__GNUC__) || defined(__clang__)\r
17   #define GLOBAL_USED __attribute__((used))\r
18 #else\r
19   #define GLOBAL_USED\r
20 #endif\r
21 \r
22 /* OpenSSL will use floating point support, and C compiler produces the _fltused\r
23    symbol by default. Simply define this symbol here to satisfy the linker. */\r
24 int  GLOBAL_USED _fltused = 1;\r
25 \r
26 /* Sets buffers to a specified character */\r
27 void * memset (void *dest, int ch, size_t count)\r
28 {\r
29   //\r
30   // NOTE: Here we use one base implementation for memset, instead of the direct\r
31   //       optimized SetMem() wrapper. Because the IntrinsicLib has to be built\r
32   //       without whole program optimization option, and there will be some\r
33   //       potential register usage errors when calling other optimized codes.\r
34   //\r
35 \r
36   //\r
37   // Declare the local variables that actually move the data elements as\r
38   // volatile to prevent the optimizer from replacing this function with\r
39   // the intrinsic memset()\r
40   //\r
41   volatile UINT8  *Pointer;\r
42 \r
43   Pointer = (UINT8 *)dest;\r
44   while (count-- != 0) {\r
45     *(Pointer++) = (UINT8)ch;\r
46   }\r
47 \r
48   return dest;\r
49 }\r
50 \r
51 /* Compare bytes in two buffers. */\r
52 int memcmp (const void *buf1, const void *buf2, size_t count)\r
53 {\r
54   return (int)CompareMem(buf1, buf2, count);\r
55 }\r
56 \r
57 int strcmp (const char *s1, const char *s2)\r
58 {\r
59   return (int)AsciiStrCmp(s1, s2);\r
60 }\r