Fixed DR registers disasm
This commit is contained in:
parent
aa1a61bfde
commit
caee480547
@ -3819,9 +3819,9 @@ static BxDisasmOpcodeTable_t BxDisasmOpcodes64w[256*2] = {
|
|||||||
/* 0F 1E */ { 0, &Ia_Invalid },
|
/* 0F 1E */ { 0, &Ia_Invalid },
|
||||||
/* 0F 1F */ { 0, &Ia_multibyte_nop },
|
/* 0F 1F */ { 0, &Ia_multibyte_nop },
|
||||||
/* 0F 20 */ { 0, &Ia_movq_Rq_Cq },
|
/* 0F 20 */ { 0, &Ia_movq_Rq_Cq },
|
||||||
/* 0F 21 */ { 0, &Ia_movl_Rd_Dd },
|
/* 0F 21 */ { 0, &Ia_movq_Rq_Dq },
|
||||||
/* 0F 22 */ { 0, &Ia_movq_Cq_Rq },
|
/* 0F 22 */ { 0, &Ia_movq_Cq_Rq },
|
||||||
/* 0F 23 */ { 0, &Ia_movl_Dd_Rd },
|
/* 0F 23 */ { 0, &Ia_movq_Dq_Rq },
|
||||||
/* 0F 24 */ { 0, &Ia_Invalid },
|
/* 0F 24 */ { 0, &Ia_Invalid },
|
||||||
/* 0F 25 */ { 0, &Ia_Invalid },
|
/* 0F 25 */ { 0, &Ia_Invalid },
|
||||||
/* 0F 26 */ { 0, &Ia_Invalid },
|
/* 0F 26 */ { 0, &Ia_Invalid },
|
||||||
@ -4337,9 +4337,9 @@ static BxDisasmOpcodeTable_t BxDisasmOpcodes64d[256*2] = {
|
|||||||
/* 0F 1E */ { 0, &Ia_Invalid },
|
/* 0F 1E */ { 0, &Ia_Invalid },
|
||||||
/* 0F 1F */ { 0, &Ia_multibyte_nop },
|
/* 0F 1F */ { 0, &Ia_multibyte_nop },
|
||||||
/* 0F 20 */ { 0, &Ia_movq_Rq_Cq },
|
/* 0F 20 */ { 0, &Ia_movq_Rq_Cq },
|
||||||
/* 0F 21 */ { 0, &Ia_movl_Rd_Dd },
|
/* 0F 21 */ { 0, &Ia_movq_Rq_Dq },
|
||||||
/* 0F 22 */ { 0, &Ia_movq_Cq_Rq },
|
/* 0F 22 */ { 0, &Ia_movq_Cq_Rq },
|
||||||
/* 0F 23 */ { 0, &Ia_movl_Dd_Rd },
|
/* 0F 23 */ { 0, &Ia_movq_Dq_Rq },
|
||||||
/* 0F 24 */ { 0, &Ia_Invalid },
|
/* 0F 24 */ { 0, &Ia_Invalid },
|
||||||
/* 0F 25 */ { 0, &Ia_Invalid },
|
/* 0F 25 */ { 0, &Ia_Invalid },
|
||||||
/* 0F 26 */ { 0, &Ia_Invalid },
|
/* 0F 26 */ { 0, &Ia_Invalid },
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
// $Id: resolve.cc,v 1.11 2006-04-27 15:11:45 sshwarts Exp $
|
// $Id: resolve.cc,v 1.12 2006-06-26 21:06:26 sshwarts Exp $
|
||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
@ -9,6 +9,8 @@ void disassembler::decode_modrm(x86_insn *insn)
|
|||||||
{
|
{
|
||||||
insn->modrm = fetch_byte();
|
insn->modrm = fetch_byte();
|
||||||
BX_DECODE_MODRM(insn->modrm, insn->mod, insn->nnn, insn->rm);
|
BX_DECODE_MODRM(insn->modrm, insn->mod, insn->nnn, insn->rm);
|
||||||
|
// MOVs with CRx and DRx always use register ops and ignore the mod field.
|
||||||
|
if ((insn->b1 & ~3) == 0x120) insn->mod = 3;
|
||||||
insn->nnn |= insn->rex_r;
|
insn->nnn |= insn->rex_r;
|
||||||
|
|
||||||
if (insn->mod == 3) {
|
if (insn->mod == 3) {
|
||||||
|
Loading…
Reference in New Issue
Block a user