summaryrefslogtreecommitdiff
path: root/src/arch/x86/isa/decoder/one_byte_opcodes.isa
diff options
context:
space:
mode:
Diffstat (limited to 'src/arch/x86/isa/decoder/one_byte_opcodes.isa')
-rw-r--r--src/arch/x86/isa/decoder/one_byte_opcodes.isa20
1 files changed, 8 insertions, 12 deletions
diff --git a/src/arch/x86/isa/decoder/one_byte_opcodes.isa b/src/arch/x86/isa/decoder/one_byte_opcodes.isa
index 71d161231..4a5cf32d0 100644
--- a/src/arch/x86/isa/decoder/one_byte_opcodes.isa
+++ b/src/arch/x86/isa/decoder/one_byte_opcodes.isa
@@ -394,19 +394,15 @@
default: Inst::RET_FAR();
}
0x4: int3();
-#if FULL_SYSTEM
- 0x5: int_Ib();
-#else
- // Really only the LSB matters, but the predecoder will sign
- // extend it, and there's no easy way to specify only checking
- // the first byte.
- 0x5: decode IMMEDIATE {
- -0x80:
- SyscallInst::int80('xc->syscall(Rax)',
- IsSyscall, IsNonSpeculative, IsSerializeAfter);
- default: int_Ib();
+ 0x5: decode FULL_SYSTEM default int_Ib() {
+ 0: decode IMMEDIATE {
+ // Really only the LSB matters, but the predecoder
+ // will sign extend it, and there's no easy way to
+ // specify only checking the first byte.
+ -0x80: SyscallInst::int80('xc->syscall(Rax)',
+ IsSyscall, IsNonSpeculative, IsSerializeAfter);
+ }
}
-#endif
0x6: decode MODE_SUBMODE {
0x0: Inst::UD2();
default: into();