summaryrefslogtreecommitdiff
path: root/MdePkg/Library/BaseMemoryLibMmx/ScanMem16Wrapper.c
diff options
context:
space:
mode:
authorArd Biesheuvel <ard.biesheuvel@linaro.org>2016-09-02 08:26:23 +0100
committerArd Biesheuvel <ard.biesheuvel@linaro.org>2016-09-13 16:28:15 +0100
commit01f688be90f59cd1ea92195bd238e8d97295fbf1 (patch)
treecb1975178c707423e817a6b1005b4f0a6ff79ba9 /MdePkg/Library/BaseMemoryLibMmx/ScanMem16Wrapper.c
parent94a3845be698ddeed9d126363c755bd3bb13dd17 (diff)
downloadedk2-platforms-01f688be90f59cd1ea92195bd238e8d97295fbf1.tar.xz
MdePkg/BaseMemoryLib: widen aligned accesses to 32 or 64 bits
Since the default BaseMemoryLib should be callable from any context, including ones where unaligned accesses are not allowed, it implements InternalCopyMem() and InternalSetMem() using byte accesses only. However, especially in a context where the MMU is off, such narrow accesses may be disproportionately costly, and so if the size and alignment of the access allow it, use 32-bit or even 64-bit loads and stores (the latter may be beneficial even on a 32-bit architectures like ARM, which has load pair/store pair instructions) Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Ard Biesheuvel <ard.biesheuvel@linaro.org> Reviewed-by: Liming Gao <liming.gao@intel.com>
Diffstat (limited to 'MdePkg/Library/BaseMemoryLibMmx/ScanMem16Wrapper.c')
0 files changed, 0 insertions, 0 deletions