summaryrefslogtreecommitdiffstats
path: root/MdePkg/Library/BaseMemoryLibSse2/Ia32
diff options
context:
space:
mode:
authorbxing <bxing@6f19259b-4bc3-4df7-8a09-765794883524>2006-07-12 09:23:28 +0000
committerbxing <bxing@6f19259b-4bc3-4df7-8a09-765794883524>2006-07-12 09:23:28 +0000
commitdb8f40e294c3ab4a8079619da71b6e41dea8044a (patch)
tree4a79d8f4d7267c2b3de1a86fec7b5547049203ff /MdePkg/Library/BaseMemoryLibSse2/Ia32
parent7867eb23e85d12ee494bb0a70cfb34fe55a2671c (diff)
downloadedk2-db8f40e294c3ab4a8079619da71b6e41dea8044a.tar.gz
edk2-db8f40e294c3ab4a8079619da71b6e41dea8044a.tar.bz2
edk2-db8f40e294c3ab4a8079619da71b6e41dea8044a.zip
1. Added '#pragma pack' directive in BaseLib.h for the structure IA32_DESCRIPTOR
2. Updated SetMem64.asm's to remove any SSE3 instructions. git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@901 6f19259b-4bc3-4df7-8a09-765794883524
Diffstat (limited to 'MdePkg/Library/BaseMemoryLibSse2/Ia32')
-rw-r--r--MdePkg/Library/BaseMemoryLibSse2/Ia32/SetMem64.asm28
1 files changed, 14 insertions, 14 deletions
diff --git a/MdePkg/Library/BaseMemoryLibSse2/Ia32/SetMem64.asm b/MdePkg/Library/BaseMemoryLibSse2/Ia32/SetMem64.asm
index 1ddc7ea191..c5d75c6f2b 100644
--- a/MdePkg/Library/BaseMemoryLibSse2/Ia32/SetMem64.asm
+++ b/MdePkg/Library/BaseMemoryLibSse2/Ia32/SetMem64.asm
@@ -28,34 +28,34 @@
;------------------------------------------------------------------------------
; VOID *
-; _mem_SetMem64 (
+; InternalMemSetMem64 (
; IN VOID *Buffer,
; IN UINTN Count,
; IN UINT64 Value
; )
;------------------------------------------------------------------------------
-InternalMemSetMem64 PROC USES edi
- mov ecx, [esp + 12]
- mov edi, [esp + 8]
- test edi, 8
- DB 0f2h, 0fh, 12h, 44h, 24h, 16 ; movddup xmm0, [esp + 16]
+InternalMemSetMem64 PROC
+ mov eax, [esp + 4]
+ mov ecx, [esp + 8]
+ test al, 8
+ mov edx, eax
+ movq xmm0, [esp + 12]
jz @F
- movq [edi], xmm0
- add edi, 8
+ movq [edx], xmm0
+ add edx, 8
dec ecx
@@:
- mov edx, ecx
shr ecx, 1
jz @SetQwords
+ movlhps xmm0, xmm0
@@:
- movntdq [edi], xmm0
- add edi, 16
+ movntdq [edx], xmm0
+ lea edx, [edx + 16]
loop @B
mfence
@SetQwords:
- test dl, 1
- jz @F
- movq [edi], xmm0
+ jnc @F
+ movq [edx], xmm0
@@:
ret
InternalMemSetMem64 ENDP