summaryrefslogtreecommitdiff
path: root/src/arch/x86/isa/decoder
diff options
context:
space:
mode:
authorNilay Vaish <nilay@cs.wisc.edu>2014-01-27 18:50:52 -0600
committerNilay Vaish <nilay@cs.wisc.edu>2014-01-27 18:50:52 -0600
commit5be0b846b1ca0131fc6c67c1ff7dcf64791ebc73 (patch)
tree237af620be866ac41bc92877057f3731d408c84b /src/arch/x86/isa/decoder
parent4eb3b1ed0b0cb5182d92fd56c21b5ca003c0fda5 (diff)
downloadgem5-5be0b846b1ca0131fc6c67c1ff7dcf64791ebc73.tar.xz
x86: implements fxch instruction.
Diffstat (limited to 'src/arch/x86/isa/decoder')
-rw-r--r--src/arch/x86/isa/decoder/x87.isa12
1 files changed, 9 insertions, 3 deletions
diff --git a/src/arch/x86/isa/decoder/x87.isa b/src/arch/x86/isa/decoder/x87.isa
index ac1306412..61f125e7c 100644
--- a/src/arch/x86/isa/decoder/x87.isa
+++ b/src/arch/x86/isa/decoder/x87.isa
@@ -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();