X86: Implement POR, ORPD and ORPS.
authorGabe Black <gblack@eecs.umich.edu>
Tue, 18 Aug 2009 01:23:33 +0000 (18:23 -0700)
committerGabe Black <gblack@eecs.umich.edu>
Tue, 18 Aug 2009 01:23:33 +0000 (18:23 -0700)
src/arch/x86/isa/decoder/two_byte_opcodes.isa
src/arch/x86/isa/insts/simd128/floating_point/logical/orp.py
src/arch/x86/isa/insts/simd128/integer/logical/por.py
src/arch/x86/isa/insts/simd64/integer/logical/por.py

index 8c49f02f55790a191324876e5128071ab87f629a..10b0bb0e3ede44f4552e0e59a85b5f868d1ebce3 100644 (file)
                     0x3: rcpps_Vo_Wo();
                     0x4: andps_Vo_Wo();
                     0x5: andnps_Vo_Wo();
-                    0x6: orps_Vo_Wo();
+                    0x6: Inst::ORPS(Vo,Wo);
                     0x7: Inst::XORPS(Vo,Wo);
                 }
                 // repe (0xF3)
                     0x1: sqrtpd_Vo_Wo();
                     0x4: andpd_Vo_Wo();
                     0x5: andnpd_Vo_Wo();
-                    0x6: orpd_Vo_Wo();
+                    0x6: Inst::ORPD(Vo,Wo);
                     //This really should be type o, but it works on q sized
                     //chunks at a time.
                     0x7: Inst::XORPD(Vq,Wq);
                     0x0: psubsb_Pq_Qq();
                     0x1: psubsw_Pq_Qq();
                     0x2: pminsw_Pq_Qq();
-                    0x3: por_Pq_Qq();
+                    0x3: Inst::POR(Pq,Qq);
                     0x4: paddsb_Pq_Qq();
                     0x5: paddsw_Pq_Qq();
                     0x6: pmaxsw_Pq_Qq();
                     0x0: psubsb_Vo_Wo();
                     0x1: psubsw_Vo_Wo();
                     0x2: pminsw_Vo_Wo();
-                    0x3: por_Vo_Wo();
+                    0x3: Inst::POR(Vo,Wo);
                     0x4: paddsb_Vo_Wo();
                     0x5: paddsw_Vo_Wo();
                     0x6: pmaxsw_Vo_Wo();
index fba71c8996d9bb0b29ca8d0a721e15e7625d528a..c99a713aaf57238a3910be37461a2483e52efb10 100644 (file)
 # Authors: Gabe Black
 
 microcode = '''
-# ORPS
-# ORPD
+def macroop ORPS_XMM_XMM {
+    mor xmml, xmml, xmmlm
+    mor xmmh, xmmh, xmmhm
+};
+
+def macroop ORPS_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
+    mor xmml, xmml, ufp1
+    mor xmmh, xmmh, ufp2
+};
+
+def macroop ORPS_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
+    mor xmml, xmml, ufp1
+    mor xmmh, xmmh, ufp2
+};
+
+def macroop ORPD_XMM_XMM {
+    mor xmml, xmml, xmmlm
+    mor xmmh, xmmh, xmmhm
+};
+
+def macroop ORPD_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
+    mor xmml, xmml, ufp1
+    mor xmmh, xmmh, ufp2
+};
+
+def macroop ORPD_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
+    mor xmml, xmml, ufp1
+    mor xmmh, xmmh, ufp2
+};
 '''
index addb28a602c2cd4230f7c5135ee84738825c0a33..dc0d7575b6b95b868d8d3d478957ad0713202b1c 100644 (file)
 # Authors: Gabe Black
 
 microcode = '''
-# POR
+def macroop POR_XMM_XMM {
+    mor xmml, xmml, xmmlm
+    mor xmmh, xmmh, xmmhm
+};
+
+def macroop POR_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
+    mor xmml, xmml, ufp1
+    mor xmmh, xmmh, ufp2
+};
+
+def macroop POR_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
+    mor xmml, xmml, ufp1
+    mor xmmh, xmmh, ufp2
+};
 '''
index addb28a602c2cd4230f7c5135ee84738825c0a33..701ac95b5d9957ffb9e9e20b7fcf2d1934cb7953 100644 (file)
 # Authors: Gabe Black
 
 microcode = '''
-# POR
+def macroop POR_MMX_MMX {
+    mor mmx, mmx, mmxm
+};
+
+def macroop POR_MMX_M {
+    ldfp ufp1, seg, sib, disp, dataSize=8
+    mor mmx, mmx, ufp1
+};
+
+def macroop POR_MMX_P {
+    rdip t7
+    ldfp ufp1, seg, riprel, disp, dataSize=8
+    mor mmx, mmx, ufp1
+};
 '''