x86: implements fxch instruction.
authorNilay Vaish <nilay@cs.wisc.edu>
Tue, 28 Jan 2014 00:50:52 +0000 (18:50 -0600)
committerNilay Vaish <nilay@cs.wisc.edu>
Tue, 28 Jan 2014 00:50:52 +0000 (18:50 -0600)
src/arch/x86/isa/decoder/x87.isa
src/arch/x86/isa/insts/x87/data_transfer_and_conversion/exchange.py

index ac1306412ac873e802e9d74d23a72439ed5fee23..61f125e7c701ac19cb1ad47f461e0768ba88c3c7 100644 (file)
@@ -59,7 +59,7 @@ format WarnUnimpl {
                 default: Inst::FLD(Md);
             }
             0x1: decode MODRM_MOD {
-                0x3: fxch();
+                0x3: Inst::FXCH(Eq);
                 default: Inst::UD2();
             }
             0x2: decode MODRM_MOD {
@@ -240,8 +240,14 @@ format WarnUnimpl {
                 0x3: Inst::UD2();
                 default: fisttp();
             }
-            0x2: Inst::FST(Eq);
-            0x3: Inst::FSTP(Eq);
+            0x2: decode MODRM_MOD {
+                0x3: Inst::FST(Eq);
+                default: Inst::FST(Mq);
+            }
+            0x3: decode MODRM_MOD {
+                0x3: Inst::FSTP(Eq);
+                default: Inst::FSTP(Mq);
+            }
             0x4: decode MODRM_MOD {
                 0x3: fucom();
                 default: frstor();
index 982ac8e559e9eef04d0ad0ee8d8d031c6bc61b6c..b6fbb01cccd1f320f2e74632851dc80254ed7117 100644 (file)
 # Authors: Gabe Black
 
 microcode = '''
-# FXCH
+def macroop FXCH_R
+{
+    movfp ufp1, sti
+    movfp sti, st(0)
+    movfp st(0), ufp1
+};
+
+def macroop FXCH_M
+{
+    fault "new UnimpInstFault"
+};
+
+def macroop FXCH_P
+{
+   fault "new UnimpInstFault"
+};
 '''