]> git.proxmox.com Git - mirror_edk2.git/blobdiff - MdePkg/Library/BaseMemoryLibSse2/X64/SetMem.S
Update to use DOS format
[mirror_edk2.git] / MdePkg / Library / BaseMemoryLibSse2 / X64 / SetMem.S
index 5d915d4a08a738126726f3c26daed6863c13f568..44100820781e97b3b2d057cd9380040bb21273ab 100644 (file)
@@ -1,73 +1,73 @@
-#
-# ConvertAsm.py: Automatically generated from SetMem.asm
-#
-#------------------------------------------------------------------------------
-#
-# Copyright (c) 2006, Intel Corporation
-# All rights reserved. This program and the accompanying materials
-# are licensed and made available under the terms and conditions of the BSD License
-# which accompanies this distribution.  The full text of the license may be found at
-# http://opensource.org/licenses/bsd-license.php
-#
-# THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
-# WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
-#
-# Module Name:
-#
-#   SetMem.S
-#
-# Abstract:
-#
-#   SetMem function
-#
-# Notes:
-#
-#------------------------------------------------------------------------------
-
-
-#------------------------------------------------------------------------------
-#  VOID *
-#  EFIAPI
-#  InternalMemSetMem (
-#    IN VOID   *Buffer,
-#    IN UINTN  Count,
-#    IN UINT8  Value
-#    )
-#------------------------------------------------------------------------------
-.intel_syntax noprefix
-.globl ASM_PFX(InternalMemSetMem)
-ASM_PFX(InternalMemSetMem):
-    push    rdi
-    mov     rdi, rcx                    # rdi <- Buffer
-    mov     al, r8b                     # al <- Value
-    mov     r9, rdi                     # r9 <- Buffer as return value
-    xor     rcx, rcx
-    sub     rcx, rdi
-    and     rcx, 15                     # rcx + rdi aligns on 16-byte boundary
-    jz      L0
-    cmp     rcx, rdx
-    cmova   rcx, rdx
-    sub     rdx, rcx
-    rep     stosb
-L0:
-    mov     rcx, rdx
-    and     rdx, 15
-    shr     rcx, 4
-    jz      L_SetBytes
-    mov     ah, al                      # ax <- Value repeats twice
-    movdqa  [rsp + 0x10], xmm0          # save xmm0
-    movd    xmm0, eax                   # xmm0[0..16] <- Value repeats twice
-    pshuflw xmm0, xmm0, 0               # xmm0[0..63] <- Value repeats 8 times
-    movlhps xmm0, xmm0                  # xmm0 <- Value repeats 16 times
-L1:
-    movntdq [rdi], xmm0                 # rdi should be 16-byte aligned
-    add     rdi, 16
-    loop    L1
-    mfence
-    movdqa  xmm0, [rsp + 0x10]          # restore xmm0
-L_SetBytes:
-    mov     ecx, edx                    # high 32 bits of rcx are always zero
-    rep     stosb
-    mov     rax, r9                     # rax <- Return value
-    pop     rdi
-    ret
+#\r
+# ConvertAsm.py: Automatically generated from SetMem.asm\r
+#\r
+#------------------------------------------------------------------------------\r
+#\r
+# Copyright (c) 2006, Intel Corporation\r
+# All rights reserved. This program and the accompanying materials\r
+# are licensed and made available under the terms and conditions of the BSD License\r
+# which accompanies this distribution.  The full text of the license may be found at\r
+# http://opensource.org/licenses/bsd-license.php\r
+#\r
+# THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
+# WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
+#\r
+# Module Name:\r
+#\r
+#   SetMem.S\r
+#\r
+# Abstract:\r
+#\r
+#   SetMem function\r
+#\r
+# Notes:\r
+#\r
+#------------------------------------------------------------------------------\r
+\r
+\r
+#------------------------------------------------------------------------------\r
+#  VOID *\r
+#  EFIAPI\r
+#  InternalMemSetMem (\r
+#    IN VOID   *Buffer,\r
+#    IN UINTN  Count,\r
+#    IN UINT8  Value\r
+#    )\r
+#------------------------------------------------------------------------------\r
+.intel_syntax noprefix\r
+.globl ASM_PFX(InternalMemSetMem)\r
+ASM_PFX(InternalMemSetMem):\r
+    push    rdi\r
+    mov     rdi, rcx                    # rdi <- Buffer\r
+    mov     al, r8b                     # al <- Value\r
+    mov     r9, rdi                     # r9 <- Buffer as return value\r
+    xor     rcx, rcx\r
+    sub     rcx, rdi\r
+    and     rcx, 15                     # rcx + rdi aligns on 16-byte boundary\r
+    jz      L0\r
+    cmp     rcx, rdx\r
+    cmova   rcx, rdx\r
+    sub     rdx, rcx\r
+    rep     stosb\r
+L0:\r
+    mov     rcx, rdx\r
+    and     rdx, 15\r
+    shr     rcx, 4\r
+    jz      L_SetBytes\r
+    mov     ah, al                      # ax <- Value repeats twice\r
+    movdqa  [rsp + 0x10], xmm0          # save xmm0\r
+    movd    xmm0, eax                   # xmm0[0..16] <- Value repeats twice\r
+    pshuflw xmm0, xmm0, 0               # xmm0[0..63] <- Value repeats 8 times\r
+    movlhps xmm0, xmm0                  # xmm0 <- Value repeats 16 times\r
+L1:\r
+    movntdq [rdi], xmm0                 # rdi should be 16-byte aligned\r
+    add     rdi, 16\r
+    loop    L1\r
+    mfence\r
+    movdqa  xmm0, [rsp + 0x10]          # restore xmm0\r
+L_SetBytes:\r
+    mov     ecx, edx                    # high 32 bits of rcx are always zero\r
+    rep     stosb\r
+    mov     rax, r9                     # rax <- Return value\r
+    pop     rdi\r
+    ret\r