arch-x86: fix CondInst decoding for MOV to Control Registers
authorBjoern A. Zeeb <baz21@cam.ac.uk>
Tue, 26 Sep 2017 16:36:05 +0000 (16:36 +0000)
committerB.A. Zeeb <baz21@cam.ac.uk>
Wed, 27 Sep 2017 22:13:22 +0000 (22:13 +0000)
commit0b77e05cb21ad946f12b67cf3336ba92b2a1a522
tree9c6902ae90ad6a4c8ae0c03168f5709dc4d85180
parent9eac6c5ce50930d9c92bdf7f9a5f875c3cfd16f8
arch-x86: fix CondInst decoding for MOV to Control Registers

MOV Rd,Cd is MR encoded but the control register is operand 2
not operand 1 hence this needs to be MODRM_REG not MODRM_RM.
While MOV Cd,Rd is RM encoded registers are also swapped, so
it also needs to be MODRM_REG as well (as it already correctly is).

This fixes incorrect UD2 reportings leading to invalid traps
reported in O3 on X86 FS introduced with 4e939a7 .

Change-Id: Ib33c8ba87b00e0264d33da44fff64ed9e4d2d9d8
Reviewed-on: https://gem5-review.googlesource.com/4861
Reviewed-by: Jason Lowe-Power <jason@lowepower.com>
Reviewed-by: Gabe Black <gabeblack@google.com>
Maintainer: Jason Lowe-Power <jason@lowepower.com>
src/arch/x86/isa/decoder/two_byte_opcodes.isa