X86: Implement PANDN, ANDNPS, and ANDNPD.
authorGabe Black <gblack@eecs.umich.edu>
Tue, 18 Aug 2009 01:25:00 +0000 (18:25 -0700)
committerGabe Black <gblack@eecs.umich.edu>
Tue, 18 Aug 2009 01:25:00 +0000 (18:25 -0700)
src/arch/x86/isa/decoder/two_byte_opcodes.isa
src/arch/x86/isa/insts/simd128/floating_point/logical/andp.py
src/arch/x86/isa/insts/simd128/integer/logical/pand.py
src/arch/x86/isa/insts/simd64/integer/logical/pand.py

index 4fd1fa4fc185cebbb476179318dc3a5404675c1d..5a6a17b17daa0c0f93003123c83601fd82f888d1 100644 (file)
                     0x2: rqsrtps_Vo_Wo();
                     0x3: rcpps_Vo_Wo();
                     0x4: Inst::ANDPS(Vo,Wo);
-                    0x5: andnps_Vo_Wo();
+                    0x5: Inst::ANDNPS(Vo,Wo);
                     0x6: Inst::ORPS(Vo,Wo);
                     0x7: Inst::XORPS(Vo,Wo);
                 }
                     0x0: movmskpd_Gd_VRo();
                     0x1: sqrtpd_Vo_Wo();
                     0x4: Inst::ANDPD(Vo,Wo);
-                    0x5: andnpd_Vo_Wo();
+                    0x5: Inst::ANDNPD(Vo,Wo);
                     0x6: Inst::ORPD(Vo,Wo);
                     //This really should be type o, but it works on q sized
                     //chunks at a time.
                     0x4: paddusb_Pq_Qq();
                     0x5: paddusw_Pq_Qq();
                     0x6: pmaxub_Pq_Qq();
-                    0x7: pandn_Pq_Qq();
+                    0x7: Inst::PANDN(Pq,Qq);
                 }
                 // operand size (0x66)
                 0x1: decode OPCODE_OP_BOTTOM3 {
                     0x4: paddusb_Vo_Wo();
                     0x5: paddusw_Vo_Wo();
                     0x6: pmaxub_Vo_Wo();
-                    0x7: pandn_Vo_Wo();
+                    0x7: Inst::PANDN(Vo,Wo);
                 }
                 default: Inst::UD2();
             }
index 104af8fa39d88def5c1d0348107fe11c670ef0b7..e3eaf16a06fbd7dff6ed284ad36b37b08c0519dd 100644 (file)
@@ -97,6 +97,48 @@ def macroop ANDPD_XMM_P {
     mand xmml, xmml, ufp1
     mand xmmh, xmmh, ufp2
 };
+
+def macroop ANDNPS_XMM_XMM {
+    mandn xmml, xmml, xmmlm
+    mandn xmmh, xmmh, xmmhm
+};
+
+def macroop ANDNPS_XMM_M {
+    lea t1, seg, sib, disp, dataSize=asz
+    ldfp ufp1, seg, [1, t0, t1], dataSize=8
+    ldfp ufp2, seg, [1, t0, t1], 8, dataSize=8
+    mandn xmml, xmml, ufp1
+    mandn xmmh, xmmh, ufp2
+};
+
+def macroop ANDNPS_XMM_P {
+    rdip t7
+    lea t1, seg, riprel, disp, dataSize=asz
+    ldfp ufp1, seg, [1, t0, t1], dataSize=8
+    ldfp ufp2, seg, [1, t0, t1], 8, dataSize=8
+    mandn xmml, xmml, ufp1
+    mandn xmmh, xmmh, ufp2
+};
+
+def macroop ANDNPD_XMM_XMM {
+    mandn xmml, xmml, xmmlm
+    mandn xmmh, xmmh, xmmhm
+};
+
+def macroop ANDNPD_XMM_M {
+    lea t1, seg, sib, disp, dataSize=asz
+    ldfp ufp1, seg, [1, t0, t1], dataSize=8
+    ldfp ufp2, seg, [1, t0, t1], 8, dataSize=8
+    mandn xmml, xmml, ufp1
+    mandn xmmh, xmmh, ufp2
+};
+
+def macroop ANDNPD_XMM_P {
+    rdip t7
+    lea t1, seg, riprel, disp, dataSize=asz
+    ldfp ufp1, seg, [1, t0, t1], dataSize=8
+    ldfp ufp2, seg, [1, t0, t1], 8, dataSize=8
+    mandn xmml, xmml, ufp1
+    mandn xmmh, xmmh, ufp2
+};
 '''
-# ANDNPS
-# ANDNPD
index aae80c8b5410e5c8b27b5bcc157fa0384ec75c9c..69699454d6930ed4eb575511d7d82376b59351e5 100644 (file)
@@ -75,5 +75,26 @@ def macroop PAND_XMM_P {
     mand xmml, xmml, ufp1
     mand xmmh, xmmh, ufp2
 };
+
+def macroop PANDN_XMM_XMM {
+    mandn xmml, xmml, xmmlm
+    mandn xmmh, xmmh, xmmhm
+};
+
+def macroop PANDN_XMM_M {
+    lea t1, seg, sib, disp, dataSize=asz
+    ldfp ufp1, seg, [1, t0, t1], dataSize=8
+    ldfp ufp2, seg, [1, t0, t1], 8, dataSize=8
+    mandn xmml, xmml, ufp1
+    mandn xmmh, xmmh, ufp2
+};
+
+def macroop PANDN_XMM_P {
+    rdip t7
+    lea t1, seg, riprel, disp, dataSize=asz
+    ldfp ufp1, seg, [1, t0, t1], dataSize=8
+    ldfp ufp2, seg, [1, t0, t1], 8, dataSize=8
+    mandn xmml, xmml, ufp1
+    mandn xmmh, xmmh, ufp2
+};
 '''
-# PANDN
index 15513ef9892f176899283330a379209deb010737..181c26a6222637cdb6736b8aa86abc8a5384e28c 100644 (file)
@@ -68,5 +68,19 @@ def macroop PAND_MMX_P {
     ldfp ufp1, seg, riprel, disp, dataSize=8
     mand mmx, mmx, ufp1
 };
+
+def macroop PANDN_MMX_MMX {
+    mandn mmx, mmx, mmxm
+};
+
+def macroop PANDN_MMX_M {
+    ldfp ufp1, seg, sib, disp, dataSize=8
+    mandn mmx, mmx, ufp1
+};
+
+def macroop PANDN_MMX_P {
+    rdip t7
+    ldfp ufp1, seg, riprel, disp, dataSize=8
+    mandn mmx, mmx, ufp1
+};
 '''
-# PANDN