]> git.proxmox.com Git - mirror_edk2.git/blob - MdePkg/Library/BaseMemoryLibMmx/X64/SetMem16.S
add corresponding .S files for BaseMemoryLibXXX X64 arch. Note that we use ".intel_sy...
[mirror_edk2.git] / MdePkg / Library / BaseMemoryLibMmx / X64 / SetMem16.S
1 #
2 # ConvertAsm.py: Automatically generated from SetMem16.asm
3 #
4 #------------------------------------------------------------------------------
5 #
6 # Copyright (c) 2006, Intel Corporation
7 # All rights reserved. This program and the accompanying materials
8 # are licensed and made available under the terms and conditions of the BSD License
9 # which accompanies this distribution. The full text of the license may be found at
10 # http://opensource.org/licenses/bsd-license.php
11 #
12 # THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
13 # WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
14 #
15 # Module Name:
16 #
17 # SetMem16.S
18 #
19 # Abstract:
20 #
21 # SetMem16 function
22 #
23 # Notes:
24 #
25 #------------------------------------------------------------------------------
26
27
28 #------------------------------------------------------------------------------
29 # VOID *
30 # EFIAPI
31 # InternalMemSetMem16 (
32 # IN VOID *Buffer,
33 # IN UINTN Count,
34 # IN UINT16 Value
35 # )
36 #------------------------------------------------------------------------------
37 .intel_syntax noprefix
38 .globl ASM_PFX(InternalMemSetMem16)
39 ASM_PFX(InternalMemSetMem16):
40 push rdi
41 mov rax, r8
42 movq mm0, rax
43 mov r8, rcx
44 mov rdi, r8
45 mov rcx, rdx
46 and edx, 3
47 shr rcx, 2
48 jz L_SetWords
49 pshufw mm0, mm0, 0x0
50 L0:
51 movntq [rdi], mm0
52 add rdi, 8
53 loop L0
54 mfence
55 L_SetWords:
56 mov ecx, edx
57 rep stosw
58 mov rax, r8
59 pop rdi
60 ret
61