+++ /dev/null
-#\r
-# ConvertAsm.py: Automatically generated from SetMem64.asm\r
-#\r
-#------------------------------------------------------------------------------\r
-#\r
-# Copyright (c) 2006 - 2009, Intel Corporation. All rights reserved.<BR>\r
-# 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
-# SetMem64.S\r
-#\r
-# Abstract:\r
-#\r
-# SetMem64 function\r
-#\r
-# Notes:\r
-#\r
-#------------------------------------------------------------------------------\r
-\r
-\r
-#------------------------------------------------------------------------------\r
-# VOID *\r
-# InternalMemSetMem64 (\r
-# IN VOID *Buffer,\r
-# IN UINTN Count,\r
-# IN UINT64 Value\r
-# )\r
-#------------------------------------------------------------------------------\r
-ASM_GLOBAL ASM_PFX(InternalMemSetMem64)\r
-ASM_PFX(InternalMemSetMem64):\r
- movq %rcx, %rax # rax <- Buffer\r
- xchgq %rdx, %rcx # rcx <- Count & rdx <- Buffer\r
- testb $8, %dl\r
- movd %r8, %xmm0\r
- jz L0\r
- movq %r8, (%rdx)\r
- addq $8, %rdx\r
- decq %rcx\r
-L0:\r
- shrq $1, %rcx\r
- jz L_SetQwords\r
- movlhps %xmm0, %xmm0\r
-L1:\r
- movntdq %xmm0, (%rdx)\r
- leaq 16(%rdx), %rdx\r
- loop L1\r
- mfence\r
-L_SetQwords:\r
- jnc L2\r
- movq %r8, (%rdx)\r
-L2:\r
- ret\r
-\r