REF: https://bugzilla.tianocore.org/show_bug.cgi?id=3790 Replace Opcode with the corresponding instructions. The code changes have been verified with CompareBuild.py tool, which can be used to compare the results of two different EDK II builds to determine if they generate the same binaries. (tool link: https://github.com/mdkinney/edk2/tree/sandbox/CompareBuild) Signed-off-by: Jason Lou <yun.lou@intel.com> Cc: Michael D Kinney <michael.d.kinney@intel.com> Reviewed-by: Liming Gao <gaoliming@byosoft.com.cn> Cc: Zhiguang Liu <zhiguang.liu@intel.com>
		
			
				
	
	
		
			48 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			NASM
		
	
	
	
	
	
			
		
		
	
	
			48 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			NASM
		
	
	
	
	
	
| ;------------------------------------------------------------------------------
 | |
| ;
 | |
| ; Copyright (c) 2006 - 2022, Intel Corporation. All rights reserved.<BR>
 | |
| ; SPDX-License-Identifier: BSD-2-Clause-Patent
 | |
| ;
 | |
| ; Module Name:
 | |
| ;
 | |
| ;   SetMem32.nasm
 | |
| ;
 | |
| ; Abstract:
 | |
| ;
 | |
| ;   SetMem32 function
 | |
| ;
 | |
| ; Notes:
 | |
| ;
 | |
| ;------------------------------------------------------------------------------
 | |
| 
 | |
|     DEFAULT REL
 | |
|     SECTION .text
 | |
| 
 | |
| ;------------------------------------------------------------------------------
 | |
| ;  VOID *
 | |
| ;  InternalMemSetMem32 (
 | |
| ;    IN VOID   *Buffer,
 | |
| ;    IN UINTN  Count,
 | |
| ;    IN UINT32 Value
 | |
| ;    )
 | |
| ;------------------------------------------------------------------------------
 | |
| global ASM_PFX(InternalMemSetMem32)
 | |
| ASM_PFX(InternalMemSetMem32):
 | |
|     movq    mm0, r8
 | |
|     mov     rax, rcx                    ; rax <- Buffer
 | |
|     xchg    rcx, rdx                    ; rcx <- Count  rdx <- Buffer
 | |
|     shr     rcx, 1                      ; rcx <- # of qwords to set
 | |
|     jz      @SetDwords
 | |
|     pshufw  mm0, mm0, 44h
 | |
| .0:
 | |
|     movntq  [rdx], mm0
 | |
|     lea     rdx, [rdx + 8]              ; use "lea" to avoid flag changes
 | |
|     loop    .0
 | |
|     mfence
 | |
| @SetDwords:
 | |
|     jnc     .1
 | |
|     movd    [rdx], mm0
 | |
| .1:
 | |
|     ret
 | |
| 
 |