X86: Implement the versions of MOVD that have an MMX destination.
authorGabe Black <gblack@eecs.umich.edu>
Tue, 18 Aug 2009 01:15:24 +0000 (18:15 -0700)
committerGabe Black <gblack@eecs.umich.edu>
Tue, 18 Aug 2009 01:15:24 +0000 (18:15 -0700)
src/arch/x86/isa/decoder/two_byte_opcodes.isa
src/arch/x86/isa/insts/simd128/integer/data_transfer/move.py

index 55056da8192b5ad0e53f61bda8d390e8c1a289d6..9efb96803bd4dd4ed1e52cb9fce625307ff10dad 100644 (file)
                     0x1: punpckhwd_Pq_Qq();
                     0x2: punpckhdq_Pq_Qq();
                     0x3: packssdw_Pq_Qq();
-                    0x6: movd_Pq_Ed();
+                    0x6: Inst::MOVD(Pq,Edp);
                     0x7: movq_Pq_Qq();
                     default: Inst::UD2();
                 }
index 4bee18c19d0e34686ca6baf5018b1f1f006673c7..f6740a0eaf82328caa02100a49ec982ce29e24e4 100644 (file)
 # Authors: Gabe Black
 
 microcode = '''
-# MOVD
+def macroop MOVD_MMX_R {
+    mov2fp mmx, regm, srcSize=dsz, destSize=8
+};
+
+def macroop MOVD_MMX_M {
+    ldfp mmx, seg, sib, disp, dataSize=8
+};
+
+def macroop MOVD_MMX_P {
+    rdip t7
+    ldfp mmx, seg, riprel, disp, dataSize=8
+};
+'''
 # MOVQ
 # MOVDQA
 # MOVDQU
 # MOVDQ2Q
 # MOVQ2DQ
 # LDDQU
-'''