mirror of https://github.com/acidanthera/audk.git
Use "movd" instruction to manipulate MMX register to support more GNU assemblers.
git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@9055 6f19259b-4bc3-4df7-8a09-765794883524
This commit is contained in:
parent
23f41e5601
commit
945f5f400b
|
@ -51,7 +51,7 @@ L0:
|
|||
andq $7, %r8
|
||||
shrq $3, %rcx # rcx <- # of Qwords to copy
|
||||
jz L_CopyBytes
|
||||
movq %mm0, %r10 # (Save mm0 in r10) ; Why just save 32 bits?
|
||||
movd %mm0, %r10 # (Save mm0 in r10)
|
||||
L1:
|
||||
movq (%rsi), %mm0
|
||||
movntq %mm0, (%rdi)
|
||||
|
|
|
@ -39,7 +39,7 @@ ASM_PFX(InternalMemSetMem):
|
|||
push %rdi
|
||||
movq %r8, %rax
|
||||
movb %al, %ah
|
||||
movq %rax, %mm0
|
||||
movd %rax, %mm0
|
||||
movq %rcx, %r8
|
||||
movq %r8, %rdi # rdi <- Buffer
|
||||
movq %rdx, %rcx
|
||||
|
|
|
@ -38,7 +38,7 @@ ASM_GLOBAL ASM_PFX(InternalMemSetMem16)
|
|||
ASM_PFX(InternalMemSetMem16):
|
||||
pushq %rdi
|
||||
movq %r8, %rax
|
||||
movq %rax, %mm0
|
||||
movd %rax, %mm0
|
||||
movq %rcx, %r8
|
||||
movq %r8, %rdi
|
||||
movq %rdx, %rcx
|
||||
|
|
|
@ -36,7 +36,7 @@
|
|||
#------------------------------------------------------------------------------
|
||||
ASM_GLOBAL ASM_PFX(InternalMemSetMem32)
|
||||
ASM_PFX(InternalMemSetMem32):
|
||||
movq %r8, %mm0 # mm0 <- Value
|
||||
movd %r8, %mm0 # mm0 <- Value
|
||||
movq %rcx, %rax # rax <- Buffer
|
||||
xchgq %rdx, %rcx # rcx <- Count rdx <- Buffer
|
||||
shrq $1, % rcx # rcx <- # of qwords to set
|
||||
|
|
|
@ -35,7 +35,7 @@
|
|||
#------------------------------------------------------------------------------
|
||||
ASM_GLOBAL ASM_PFX(InternalMemSetMem64)
|
||||
ASM_PFX(InternalMemSetMem64):
|
||||
movq %r8, %mm0 #Value
|
||||
movd %r8, %mm0 #Value
|
||||
movw %rcx, %rax #rax <- Buffer
|
||||
xchg %rdx, %rcx #rcx <- Count
|
||||
L0:
|
||||
|
|
|
@ -38,7 +38,7 @@ ASM_PFX(InternalMemSetMem64):
|
|||
movq %rcx, %rax # rax <- Buffer
|
||||
xchgq %rdx, %rcx # rcx <- Count & rdx <- Buffer
|
||||
testb $8, %dl
|
||||
movq %r8, %xmm0
|
||||
movd %r8, %xmm0
|
||||
jz L0
|
||||
movq %r8, (%rdx)
|
||||
addq $8, %rdx
|
||||
|
|
Loading…
Reference in New Issue