-#/** @file\r
+## @file\r
# Instance of Base Memory Library optimized for use in DXE phase.\r
#\r
# Base Memory Library that is optimized for use in DXE phase. \r
# Uses REP, MMX, XMM registers as required for best performance.\r
#\r
-# Copyright (c) 2007 - 2008, Intel Corporation.\r
+# Copyright (c) 2007 - 2016, Intel Corporation. All rights reserved.<BR>\r
#\r
-# All rights reserved. This program and the accompanying materials\r
+# This program and the accompanying materials\r
# are licensed and made available under the terms and conditions of the BSD License\r
# which accompanies this distribution. The full text of the license may be found at\r
-# http://opensource.org/licenses/bsd-license.php\r
+# http://opensource.org/licenses/bsd-license.php.\r
# THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
# WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
#\r
#\r
-#**/\r
+##\r
\r
[Defines]\r
INF_VERSION = 0x00010005\r
BASE_NAME = BaseMemoryLibOptDxe\r
+ MODULE_UNI_FILE = BaseMemoryLibOptDxe.uni\r
FILE_GUID = 02BD55C2-AB1D-4b75-B0FD-9A63AE09B31D\r
MODULE_TYPE = BASE\r
VERSION_STRING = 1.0\r
\r
\r
#\r
-# VALID_ARCHITECTURES = IA32 X64\r
+# VALID_ARCHITECTURES = IA32 X64 ARM AARCH64\r
#\r
\r
-[Sources.common]\r
+[Sources]\r
MemLibInternals.h\r
\r
[Sources.Ia32]\r
+ Ia32/ScanMem64.nasm\r
Ia32/ScanMem64.S\r
+ Ia32/ScanMem32.nasm\r
Ia32/ScanMem32.S\r
+ Ia32/ScanMem16.nasm\r
Ia32/ScanMem16.S\r
+ Ia32/ScanMem8.nasm\r
Ia32/ScanMem8.S\r
+ Ia32/CompareMem.nasm\r
Ia32/CompareMem.S\r
+ Ia32/ZeroMem.nasm\r
Ia32/ZeroMem.S\r
+ Ia32/SetMem64.nasm\r
Ia32/SetMem64.S\r
+ Ia32/SetMem32.nasm\r
Ia32/SetMem32.S\r
+ Ia32/SetMem16.nasm\r
Ia32/SetMem16.S\r
+ Ia32/SetMem.nasm\r
Ia32/SetMem.S\r
+ Ia32/CopyMem.nasm\r
Ia32/CopyMem.S\r
+ Ia32/ScanMem64.nasm\r
Ia32/ScanMem64.asm\r
+ Ia32/ScanMem32.nasm\r
Ia32/ScanMem32.asm\r
+ Ia32/ScanMem16.nasm\r
Ia32/ScanMem16.asm\r
+ Ia32/ScanMem8.nasm\r
Ia32/ScanMem8.asm\r
+ Ia32/CompareMem.nasm\r
Ia32/CompareMem.asm\r
+ Ia32/ZeroMem.nasm\r
Ia32/ZeroMem.asm\r
+ Ia32/SetMem64.nasm\r
Ia32/SetMem64.asm\r
+ Ia32/SetMem32.nasm\r
Ia32/SetMem32.asm\r
+ Ia32/SetMem16.nasm\r
Ia32/SetMem16.asm\r
+ Ia32/SetMem.nasm\r
Ia32/SetMem.asm\r
+ Ia32/CopyMem.nasm\r
Ia32/CopyMem.asm\r
- ScanMem64Wrapper.c\r
- ScanMem32Wrapper.c\r
- ScanMem16Wrapper.c\r
- ScanMem8Wrapper.c\r
- ZeroMemWrapper.c\r
- CompareMemWrapper.c\r
- SetMem64Wrapper.c\r
- SetMem32Wrapper.c\r
- SetMem16Wrapper.c\r
- SetMemWrapper.c\r
- CopyMemWrapper.c\r
+ Ia32/IsZeroBuffer.nasm\r
MemLibGuid.c\r
\r
[Sources.X64]\r
+ X64/ScanMem64.nasm\r
X64/ScanMem64.asm\r
X64/ScanMem64.S\r
+ X64/ScanMem32.nasm\r
X64/ScanMem32.asm\r
X64/ScanMem32.S\r
+ X64/ScanMem16.nasm\r
X64/ScanMem16.asm\r
X64/ScanMem16.S\r
+ X64/ScanMem8.nasm\r
X64/ScanMem8.asm\r
X64/ScanMem8.S\r
+ X64/CompareMem.nasm\r
X64/CompareMem.asm\r
X64/CompareMem.S\r
+ X64/ZeroMem.nasm\r
X64/ZeroMem.asm\r
X64/ZeroMem.S\r
+ X64/SetMem64.nasm\r
X64/SetMem64.asm\r
X64/SetMem64.S\r
+ X64/SetMem32.nasm\r
X64/SetMem32.asm\r
X64/SetMem32.S\r
+ X64/SetMem16.nasm\r
X64/SetMem16.asm\r
X64/SetMem16.S\r
+ X64/SetMem.nasm\r
X64/SetMem.asm\r
X64/SetMem.S\r
+ X64/CopyMem.nasm\r
X64/CopyMem.asm\r
X64/CopyMem.S\r
+ X64/IsZeroBuffer.nasm\r
+ MemLibGuid.c\r
+\r
+[Defines.ARM, Defines.AARCH64]\r
+ #\r
+ # The ARM implementations of this library may perform unaligned accesses, and\r
+ # may use DC ZVA instructions that are only allowed when the MMU and D-cache\r
+ # are on. Since SEC, PEI_CORE and PEIM modules may execute with the MMU off,\r
+ # omit them from the supported module types list for this library.\r
+ #\r
+ LIBRARY_CLASS = BaseMemoryLib|DXE_CORE DXE_DRIVER DXE_RUNTIME_DRIVER UEFI_DRIVER UEFI_APPLICATION\r
+\r
+[Sources.ARM]\r
+ Arm/ScanMem.S |GCC\r
+ Arm/SetMem.S |GCC\r
+ Arm/CopyMem.S |GCC\r
+ Arm/CompareMem.S |GCC\r
+ Arm/CompareGuid.S |GCC\r
+\r
+ Arm/ScanMem.asm |RVCT\r
+ Arm/SetMem.asm |RVCT\r
+ Arm/CopyMem.asm |RVCT\r
+ Arm/CompareMem.asm |RVCT\r
+ Arm/CompareGuid.asm |RVCT\r
+\r
+[Sources.AARCH64]\r
+ AArch64/ScanMem.S\r
+ AArch64/SetMem.S\r
+ AArch64/CopyMem.S\r
+ AArch64/CompareMem.S\r
+ AArch64/CompareGuid.S\r
+\r
+[Sources.ARM, Sources.AARCH64]\r
+ Arm/ScanMemGeneric.c\r
+ Arm/MemLibGuid.c\r
+\r
+[Sources]\r
ScanMem64Wrapper.c\r
ScanMem32Wrapper.c\r
ScanMem16Wrapper.c\r
SetMem16Wrapper.c\r
SetMemWrapper.c\r
CopyMemWrapper.c\r
- MemLibGuid.c\r
+ IsZeroBufferWrapper.c\r
\r
[Packages]\r
MdePkg/MdePkg.dec\r