X86: Implement the insert/extract instructions.
authorGabe Black <gblack@eecs.umich.edu>
Tue, 18 Aug 2009 03:22:56 +0000 (20:22 -0700)
committerGabe Black <gblack@eecs.umich.edu>
Tue, 18 Aug 2009 03:22:56 +0000 (20:22 -0700)
src/arch/x86/isa/decoder/two_byte_opcodes.isa
src/arch/x86/isa/insts/simd128/integer/data_reordering/extract_and_insert.py
src/arch/x86/isa/insts/simd64/integer/data_reordering/extract_and_insert.py

index 023a440d175519ba62b6ca9df8d0ec2ab414dbbb..adc14b2bddbf9fe6812156fa793bd7ce5004f0c0 100644 (file)
                         0x0: decode OPCODE_OP_BOTTOM3 {
                             0x2: WarnUnimpl::cmpccps_Vo_Wo_Ib();
                             0x3: WarnUnimpl::movnti_Mdq_Gdq();
-                            0x4: WarnUnimpl::pinsrw_Pq_Ew_Ib();
-                            0x5: WarnUnimpl::pextrw_Gd_PRq_Ib();
+                            0x4: PINSRW(Pq,Ew,Ib);
+                            0x5: PEXTRW(Gd,PRq,Ib);
                             0x6: WarnUnimpl::shufps_Vps_Wps_Ib();
                         }
                         // repe (0xF3)
                         // operand size (0x66)
                         0x1: decode OPCODE_OP_BOTTOM3 {
                             0x2: WarnUnimpl::cmpccpd_Vo_Wo_Ib();
-                            0x4: WarnUnimpl::pinsrw_Vdw_Ew_Ib();
-                            0x5: WarnUnimpl::pextrw_Gd_VRdq_Ib();
+                            0x4: PINSRW(Vdw,Ew,Ib);
+                            0x5: PEXTRW(Gd,VRdq,Ib);
                             0x6: WarnUnimpl::shufpd_Vpd_Wpd_Ib();
                             default: UD2();
                         }
index 80f7a3e71f71210ed798dc5881b43f7ecdfe4fdf..f4f06ca67293d9bd0a220e6772f6f341744eaa07 100644 (file)
 # Authors: Gabe Black
 
 microcode = '''
-# PEXTRW
-# PINSRW
+def macroop PEXTRW_R_XMM_I {
+    mov2int reg, xmmlm, "IMMEDIATE & mask(3)", size=2, ext=1
+    mov2int reg, xmmhm, "IMMEDIATE & mask(3)", size=2, ext=1
+};
+
+def macroop PINSRW_XMM_R_I {
+    mov2fp xmml, regm, "IMMEDIATE & mask(3)", size=2, ext=1
+    mov2fp xmmh, regm, "IMMEDIATE & mask(3)", size=2, ext=1
+};
+
+def macroop PINSRW_XMM_M_I {
+    ld t1, seg, sib, disp, dataSize=2
+    mov2fp xmml, t1, "IMMEDIATE & mask(3)", size=2, ext=1
+    mov2fp xmmh, t1, "IMMEDIATE & mask(3)", size=2, ext=1
+};
+
+def macroop PINSRW_XMM_P_I {
+    rdip t7
+    ld t1, seg, riprel, disp, dataSize=2
+    mov2fp xmml, t1, "IMMEDIATE & mask(3)", size=2, ext=1
+    mov2fp xmmh, t1, "IMMEDIATE & mask(3)", size=2, ext=1
+};
 '''
index 80f7a3e71f71210ed798dc5881b43f7ecdfe4fdf..c9ebbcf1406ea6d45240c90fbcc6cbc25f45ad4b 100644 (file)
 # Authors: Gabe Black
 
 microcode = '''
-# PEXTRW
-# PINSRW
+def macroop PEXTRW_R_MMX_I {
+    mov2int reg, mmxm, "IMMEDIATE & mask(2)", size=2, ext=0
+};
+
+def macroop PINSRW_MMX_R_I {
+    mov2fp mmx, regm, "IMMEDIATE & mask(2)", size=2, ext=0
+};
+
+def macroop PINSRW_MMX_M_I {
+    ld t1, seg, sib, disp, dataSize=2
+    mov2fp mmx, t1, "IMMEDIATE & mask(2)", size=2, ext=0
+};
+
+def macroop PINSRW_MMX_P_I {
+    rdip t7
+    ld t1, seg, riprel, disp, dataSize=2
+    mov2fp mmx, t1, "IMMEDIATE & mask(2)", size=2, ext=0
+};
 '''