# 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 - 2014, Intel Corporation. All rights reserved.<BR>\r
+# Copyright (c) 2007 - 2016, Intel Corporation. All rights reserved.<BR>\r
#\r
# This program and the accompanying materials\r
# are licensed and made available under the terms and conditions of the BSD License\r
\r
\r
#\r
-# VALID_ARCHITECTURES = IA32 X64\r
+# VALID_ARCHITECTURES = IA32 X64 ARM AARCH64\r
#\r
\r
[Sources]\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