]> git.proxmox.com Git - mirror_edk2.git/blame_incremental - ArmPkg/Library/BaseMemoryLibStm/Arm/SetMem.S
BeagleBoardPkg: remove dependency on ArmPkg/BaseMemoryLibStm
[mirror_edk2.git] / ArmPkg / Library / BaseMemoryLibStm / Arm / SetMem.S
... / ...
CommitLineData
1#------------------------------------------------------------------------------\r
2#\r
3# SemMem() worker for ARM\r
4#\r
5# This file started out as C code that did 64 bit moves if the buffer was\r
6# 32-bit aligned, else it does a byte copy. It also does a byte copy for\r
7# any trailing bytes. It was updated to do 32-byte at a time.\r
8#\r
9# Copyright (c) 2008 - 2010, Apple Inc. All rights reserved.<BR>\r
10# This program and the accompanying materials\r
11# are licensed and made available under the terms and conditions of the BSD License\r
12# which accompanies this distribution. The full text of the license may be found at\r
13# http://opensource.org/licenses/bsd-license.php\r
14#\r
15# THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
16# WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
17#\r
18#------------------------------------------------------------------------------\r
19\r
20#include <AsmMacroIoLib.h>\r
21\r
22/**\r
23 Set Buffer to Value for Size bytes.\r
24\r
25 @param Buffer Memory to set.\r
26 @param Length Number of bytes to set\r
27 @param Value Value of the set operation.\r
28\r
29 @return Buffer\r
30\r
31VOID *\r
32EFIAPI\r
33InternalMemSetMem (\r
34 OUT VOID *Buffer,\r
35 IN UINTN Length,\r
36 IN UINT8 Value\r
37 )\r
38**/\r
39\r
40.syntax unified\r
41\r
42ASM_FUNC(InternalMemSetMem)\r
43 stmfd sp!, {r4-r11, lr}\r
44 tst r0, #3\r
45 movne r3, #0\r
46 moveq r3, #1\r
47 cmp r1, #31\r
48 movls lr, #0\r
49 andhi lr, r3, #1\r
50 cmp lr, #0\r
51 mov r12, r0\r
52 bne L31\r
53L32:\r
54 mov r3, #0\r
55 b L43\r
56L31:\r
57 and r4, r2, #0xff\r
58 orr r4, r4, r4, LSL #8\r
59 orr r4, r4, r4, LSL #16\r
60 mov r5, r4\r
61 mov r6, r4\r
62 mov r7, r4\r
63 mov r8, r4\r
64 mov r9, r4\r
65 mov r10, r4\r
66 mov r11, r4\r
67 b L32\r
68L34:\r
69 cmp lr, #0\r
70 strbeq r2, [r12], #1\r
71 subeq r1, r1, #1\r
72 beq L43\r
73 sub r1, r1, #32\r
74 cmp r1, #31\r
75 movls lr, r3\r
76 stmia r12!, {r4-r11}\r
77L43:\r
78 cmp r1, #0\r
79 bne L34\r
80 ldmfd sp!, {r4-r11, pc}\r
81\r