]> git.proxmox.com Git - mirror_edk2.git/blame - EdkCompatibilityPkg/Foundation/Library/CompilerStub/Ia32/memsetSSE2.asm
Add in the 1st version of ECP.
[mirror_edk2.git] / EdkCompatibilityPkg / Foundation / Library / CompilerStub / Ia32 / memsetSSE2.asm
CommitLineData
3eb9473e 1;------------------------------------------------------------------------------\r
2;\r
3; Copyright (c) 2007, Intel Corporation\r
4; All rights reserved. This program and the accompanying materials\r
5; are licensed and made available under the terms and conditions of the BSD License\r
6; which accompanies this distribution. The full text of the license may be found at\r
7; http://opensource.org/licenses/bsd-license.php\r
8;\r
9; THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
10; WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
11;\r
12; Module Name:\r
13;\r
14; SetMem.asm\r
15;\r
16; Abstract:\r
17;\r
18; memset function\r
19;\r
20; Notes:\r
21;\r
22;------------------------------------------------------------------------------\r
23\r
24 .686\r
25 .model flat,C\r
26 .xmm\r
27 .code\r
28\r
29;------------------------------------------------------------------------------\r
30; VOID *\r
31; memset (\r
32; OUT VOID *Buffer,\r
33; IN UINT8 Value,\r
34; IN UINTN Count\r
35; )\r
36;------------------------------------------------------------------------------\r
37memset PROC USES edi\r
38 mov edx, [esp + 16] ; edx <- Count\r
39 cmp edx, 0 ; if Count == 0, do nothing\r
40 je @SetDone \r
41 mov edi, [esp + 8] ; edi <- Buffer\r
42 mov al, [esp + 12] ; al <- Value\r
43 xor ecx, ecx\r
44 sub ecx, edi\r
45 and ecx, 15 ; ecx + edi aligns on 16-byte boundary\r
46 jz @F\r
47 cmp ecx, edx\r
48 cmova ecx, edx\r
49 sub edx, ecx\r
50 rep stosb\r
51@@:\r
52 mov ecx, edx\r
53 and edx, 15\r
54 shr ecx, 4 ; ecx <- # of DQwords to set\r
55 jz @SetBytes\r
56 mov ah, al ; ax <- Value | (Value << 8)\r
57 add esp, -16\r
58 movd xmm0, eax\r
59 pshuflw xmm0, xmm0, 0 ; xmm0[0..63] <- Value repeats 8 times\r
60 movlhps xmm0, xmm0 ; xmm0 <- Value repeats 16 times\r
61@@:\r
62 movdqa [edi], xmm0 ; edi should be 16-byte aligned\r
63 add edi, 16\r
64 loop @B\r
65 add esp, 16 ; stack cleanup\r
66@SetBytes:\r
67 mov ecx, edx\r
68 rep stosb\r
69@SetDone: \r
70 mov eax, [esp + 8] ; eax <- Buffer as return value\r
71 ret\r
72memset ENDP\r
73\r
74 END\r