X86: Implement the instructions that compare fp values and write to rflags.
authorGabe Black <gblack@eecs.umich.edu>
Tue, 18 Aug 2009 03:25:14 +0000 (20:25 -0700)
committerGabe Black <gblack@eecs.umich.edu>
Tue, 18 Aug 2009 03:25:14 +0000 (20:25 -0700)
src/arch/x86/isa/decoder/two_byte_opcodes.isa
src/arch/x86/isa/insts/simd128/floating_point/compare/compare_and_write_rflags.py

index 41cbdd869aa5c80db991e26c93bca2062d576358..b41f2b31dc147b1b5c7530205692ee63a8f96c88 100644 (file)
                     0x3: movntps_Mo_Vo();
                     0x4: cvttps2pi_Pq_Wq();
                     0x5: cvtpS2pi_Pq_Wq();
-                    0x6: ucomiss_Vd_Wd();
-                    0x7: comiss_Vd_Wd();
+                    0x6: Inst::UCOMISS(Vd,Wd);
+                    0x7: Inst::COMISS(Vd,Wd);
                 }
                 // repe (0xF3)
                 0x4: decode OPCODE_OP_BOTTOM3 {
                     0x4: cvttpd2pi_Pq_Wo();
                     0x5: cvtpd2pi_Pq_Wo();
                     0x6: Inst::UCOMISD(Vq,Wq);
-                    0x7: comisd_Vq_Wq();
+                    0x7: Inst::COMISD(Vq,Wq);
                 }
                 // repne (0xF2)
                 0x8: decode OPCODE_OP_BOTTOM3 {
index 2e22f71ebcc74def2a0cdcd4189e8f6e68106669..50afddf7be0b20200136a7db405fefab605c3c6f 100644 (file)
 # Authors: Gabe Black
 
 microcode = '''
-# COMISS
-# COMISD
-# UCOMISS
+def macroop UCOMISS_XMM_XMM {
+    mcmpf2rf xmml, xmmlm, size=4
+};
+
+def macroop UCOMISS_XMM_M {
+    ldfp ufp1, seg, sib, disp, dataSize=8
+    mcmpf2rf xmml, ufp1, size=4
+};
+
+def macroop UCOMISS_XMM_P {
+    rdip t7
+    ldfp ufp1, seg, riprel, disp, dataSize=8
+    mcmpf2rf xmml, ufp1, size=4
+};
 
 def macroop UCOMISD_XMM_XMM {
-    compfp xmml, xmmlm
+    mcmpf2rf xmml, xmmlm, size=8
 };
 
 def macroop UCOMISD_XMM_M {
     ldfp ufp1, seg, sib, disp, dataSize=8
-    compfp xmml, ufp1
+    mcmpf2rf xmml, ufp1, size=8
 };
 
 def macroop UCOMISD_XMM_P {
     rdip t7
     ldfp ufp1, seg, riprel, disp, dataSize=8
-    compfp xmml, ufp1
+    mcmpf2rf xmml, ufp1, size=8
+};
+
+def macroop COMISS_XMM_XMM {
+    mcmpf2rf xmml, xmmlm, size=4
+};
+
+def macroop COMISS_XMM_M {
+    ldfp ufp1, seg, sib, disp, dataSize=8
+    mcmpf2rf xmml, ufp1, size=4
+};
+
+def macroop COMISS_XMM_P {
+    rdip t7
+    ldfp ufp1, seg, riprel, disp, dataSize=8
+    mcmpf2rf xmml, ufp1, size=4
+};
+
+def macroop COMISD_XMM_XMM {
+    mcmpf2rf xmml, xmmlm, size=8
+};
+
+def macroop COMISD_XMM_M {
+    ldfp ufp1, seg, sib, disp, dataSize=8
+    mcmpf2rf xmml, ufp1, size=8
+};
+
+def macroop COMISD_XMM_P {
+    rdip t7
+    ldfp ufp1, seg, riprel, disp, dataSize=8
+    mcmpf2rf xmml, ufp1, size=8
 };
 '''