https://bugzilla.tianocore.org/show_bug.cgi?id=1373 Replace BSD 2-Clause License with BSD+Patent License. This change is based on the following emails: https://lists.01.org/pipermail/edk2-devel/2019-February/036260.html https://lists.01.org/pipermail/edk2-devel/2018-October/030385.html RFCs with detailed process for the license change: V3: https://lists.01.org/pipermail/edk2-devel/2019-March/038116.html V2: https://lists.01.org/pipermail/edk2-devel/2019-March/037669.html V1: https://lists.01.org/pipermail/edk2-devel/2019-March/037500.html Contributed-under: TianoCore Contribution Agreement 1.1 Signed-off-by: Michael D Kinney <michael.d.kinney@intel.com> Reviewed-by: Liming Gao <liming.gao@intel.com>
		
			
				
	
	
		
			48 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			NASM
		
	
	
	
	
	
			
		
		
	
	
			48 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			NASM
		
	
	
	
	
	
;------------------------------------------------------------------------------
 | 
						|
;
 | 
						|
; Copyright (c) 2006, 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):
 | 
						|
    DB      0x49, 0xf, 0x6e, 0xc0         ; movd mm0, r8 (Value)
 | 
						|
    mov     rax, rcx                    ; rax <- Buffer
 | 
						|
    xchg    rcx, rdx                    ; rcx <- Count  rdx <- Buffer
 | 
						|
    shr     rcx, 1                      ; rcx <- # of qwords to set
 | 
						|
    jz      @SetDwords
 | 
						|
    DB      0xf, 0x70, 0xC0, 0x44         ; pshufw mm0, mm0, 44h
 | 
						|
.0:
 | 
						|
    DB      0xf, 0xe7, 0x2              ; movntq [rdx], mm0
 | 
						|
    lea     rdx, [rdx + 8]              ; use "lea" to avoid flag changes
 | 
						|
    loop    .0
 | 
						|
    mfence
 | 
						|
@SetDwords:
 | 
						|
    jnc     .1
 | 
						|
    DB      0xf, 0x7e, 0x2               ; movd [rdx], mm0
 | 
						|
.1:
 | 
						|
    ret
 | 
						|
 |