]> git.proxmox.com Git - mirror_edk2.git/blame - MdePkg/Library/BaseMemoryLibMmx/Ia32/SetMem.asm
ArmPkg/ArmDisassemblerLib: fix check for MSR instruction
[mirror_edk2.git] / MdePkg / Library / BaseMemoryLibMmx / Ia32 / SetMem.asm
CommitLineData
c5ecf6c1 1;------------------------------------------------------------------------------\r
2;\r
085c3968
HT
3; Copyright (c) 2006, Intel Corporation. All rights reserved.<BR>\r
4; This program and the accompanying materials\r
c5ecf6c1 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
2fc59a00 7; http://opensource.org/licenses/bsd-license.php.\r
c5ecf6c1 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; SetMem function\r
19;\r
20; Notes:\r
21;\r
22;------------------------------------------------------------------------------\r
23\r
24 .686\r
25 .model flat,C\r
26 .mmx\r
27 .code\r
28\r
29;------------------------------------------------------------------------------\r
30; VOID *\r
31; EFIAPI\r
32; InternalMemSetMem (\r
33; IN VOID *Buffer,\r
34; IN UINTN Count,\r
35; IN UINT8 Value\r
36; )\r
37;------------------------------------------------------------------------------\r
38InternalMemSetMem PROC USES edi\r
39 mov al, [esp + 16]\r
40 mov ah, al\r
41 shrd edx, eax, 16\r
42 shld eax, edx, 16\r
43 mov ecx, [esp + 12] ; ecx <- Count\r
44 mov edi, [esp + 8] ; edi <- Buffer\r
45 mov edx, ecx\r
46 and edx, 7\r
47 shr ecx, 3 ; # of Qwords to set\r
48 jz @SetBytes\r
49 add esp, -10h\r
50 movq [esp], mm0 ; save mm0\r
51 movq [esp + 8], mm1 ; save mm1\r
52 movd mm0, eax\r
53 movd mm1, eax\r
54 psllq mm0, 32\r
55 por mm0, mm1 ; fill mm0 with 8 Value's\r
56@@:\r
57 movq [edi], mm0\r
58 add edi, 8\r
59 loop @B\r
60 movq mm0, [esp] ; restore mm0\r
61 movq mm1, [esp + 8] ; restore mm1\r
62 add esp, 10h ; stack cleanup\r
63@SetBytes:\r
64 mov ecx, edx\r
65 rep stosb\r
66 mov eax, [esp + 8] ; eax <- Buffer as return value\r
67 ret\r
68InternalMemSetMem ENDP\r
69\r
70 END\r