]> git.proxmox.com Git - mirror_edk2.git/blame - ArmPkg/Library/BaseMemoryLibVstm/Arm/SetMem.S
Add the missing up/down arrow in UNI string.
[mirror_edk2.git] / ArmPkg / Library / BaseMemoryLibVstm / Arm / SetMem.S
CommitLineData
d39eb83c 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. Update to use VSTM/VLDM to do 128 byte writes.\r
8#\r
d6ebcab7
HT
9# Copyright (c) 2008 - 2010, Apple Inc. All rights reserved.<BR>\r
10# This program and the accompanying materials\r
d39eb83c 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/**\r
21 Set Buffer to Value for Size bytes.\r
22\r
23 @param Buffer Memory to set.\r
24 @param Length Number of bytes to set\r
25 @param Value Value of the set operation.\r
26\r
27 @return Buffer\r
28\r
29VOID *\r
30EFIAPI\r
31InternalMemSetMem (\r
32 OUT VOID *Buffer,\r
33 IN UINTN Length,\r
34 IN UINT8 Value\r
35 )\r
36**/\r
37 \r
38.text\r
39.align 2\r
40.globl ASM_PFX(InternalMemSetMem)\r
63ca7402 41INTERWORK_FUNC(InternalMemSetMem)\r
d39eb83c 42\r
43ASM_PFX(InternalMemSetMem):\r
44 stmfd sp!, {r4-r7, lr}\r
45 tst r0, #3\r
46 movne r3, #0\r
47 moveq r3, #1\r
48 cmp r1, #127\r
49 movls lr, #0\r
50 andhi lr, r3, #1\r
51 cmp lr, #0\r
52 mov r12, r0\r
53 bne L31\r
54L32:\r
55 mov r3, #0\r
56 b L43\r
57L31:\r
58 vdup.8 q0,r2\r
59 vmov q1,q0\r
60 vmov q2,q0\r
61 vmov q3,q0\r
62 vmov q4,q0\r
63 vmov q5,q0\r
64 vmov q6,q0\r
65 vmov q7,q0\r
66 b L32\r
67L34:\r
68 cmp lr, #0\r
69 streqb r2, [r12], #1\r
70 subeq r1, r1, #1\r
71 beq L43\r
72 sub r1, r1, #128\r
73 cmp r1, #127\r
74 cmp r1, #31\r
75 movls lr, r3\r
76 vstm r12!, {d0-d15}\r
77L43:\r
78 cmp r1, #0\r
79 bne L34\r
80 ldmfd sp!, {pc}\r
81