changeset 301f2c0b3423 in /z/repo/gem5
details: http://repo.gem5.org/gem5?cmd=changeset;node=301f2c0b3423
description:
x86: implements fxch instruction.
diffstat:
src/arch/x86/isa/decoder/x87.isa | 12
+++++-
src/arch/x86/isa/insts/x87/data_transfer_and_conversion/exchange.py | 17
+++++++++-
2 files changed, 25 insertions(+), 4 deletions(-)
diffs (54 lines):
diff -r d4405a6bcc5a -r 301f2c0b3423 src/arch/x86/isa/decoder/x87.isa
--- a/src/arch/x86/isa/decoder/x87.isa Mon Jan 27 18:50:51 2014 -0600
+++ b/src/arch/x86/isa/decoder/x87.isa Mon Jan 27 18:50:52 2014 -0600
@@ -59,7 +59,7 @@
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 @@
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();
diff -r d4405a6bcc5a -r 301f2c0b3423
src/arch/x86/isa/insts/x87/data_transfer_and_conversion/exchange.py
--- a/src/arch/x86/isa/insts/x87/data_transfer_and_conversion/exchange.py
Mon Jan 27 18:50:51 2014 -0600
+++ b/src/arch/x86/isa/insts/x87/data_transfer_and_conversion/exchange.py
Mon Jan 27 18:50:52 2014 -0600
@@ -36,5 +36,20 @@
# 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"
+};
'''
_______________________________________________
gem5-dev mailing list
[email protected]
http://m5sim.org/mailman/listinfo/gem5-dev