Bugfix and optimize BxResolve calls - bugfix in 64-bit mode

This commit is contained in:
Stanislav Shwartsman 2007-11-13 17:30:54 +00:00
parent 72af550a0f
commit 0fa82afe1f
7 changed files with 302 additions and 944 deletions

View File

@ -1,5 +1,5 @@
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// $Id: cpu.cc,v 1.180 2007-11-12 18:20:05 sshwarts Exp $ // $Id: cpu.cc,v 1.181 2007-11-13 17:30:52 sshwarts Exp $
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// //
// Copyright (C) 2001 MandrakeSoft S.A. // Copyright (C) 2001 MandrakeSoft S.A.
@ -363,6 +363,8 @@ void BX_CPU_C::repeat_ZFL(bxInstruction_c *i, BxExecutePtr_t execute)
return; return;
} }
unsigned rep = i->repUsedValue();
#if BX_SUPPORT_X86_64 #if BX_SUPPORT_X86_64
if (i->as64L()) { if (i->as64L()) {
while(1) { while(1) {
@ -371,8 +373,8 @@ void BX_CPU_C::repeat_ZFL(bxInstruction_c *i, BxExecutePtr_t execute)
BX_INSTR_REPEAT_ITERATION(BX_CPU_ID, i); BX_INSTR_REPEAT_ITERATION(BX_CPU_ID, i);
RCX --; RCX --;
} }
if ((i->repUsedValue()==3) && (get_ZF()==0)) return; if (rep==3 && get_ZF()==0) return;
if ((i->repUsedValue()==2) && (get_ZF()!=0)) return; if (rep==2 && get_ZF()!=0) return;
if (RCX == 0) return; if (RCX == 0) return;
BX_TICK1_IF_SINGLE_PROCESSOR(); BX_TICK1_IF_SINGLE_PROCESSOR();
@ -392,8 +394,8 @@ void BX_CPU_C::repeat_ZFL(bxInstruction_c *i, BxExecutePtr_t execute)
BX_INSTR_REPEAT_ITERATION(BX_CPU_ID, i); BX_INSTR_REPEAT_ITERATION(BX_CPU_ID, i);
RCX = ECX - 1; RCX = ECX - 1;
} }
if ((i->repUsedValue()==3) && (get_ZF()==0)) return; if (rep==3 && get_ZF()==0) return;
if ((i->repUsedValue()==2) && (get_ZF()!=0)) return; if (rep==2 && get_ZF()!=0) return;
if (ECX == 0) return; if (ECX == 0) return;
BX_TICK1_IF_SINGLE_PROCESSOR(); BX_TICK1_IF_SINGLE_PROCESSOR();
@ -412,8 +414,8 @@ void BX_CPU_C::repeat_ZFL(bxInstruction_c *i, BxExecutePtr_t execute)
BX_INSTR_REPEAT_ITERATION(BX_CPU_ID, i); BX_INSTR_REPEAT_ITERATION(BX_CPU_ID, i);
CX --; CX --;
} }
if ((i->repUsedValue()==3) && (get_ZF()==0)) return; if (rep==3 && get_ZF()==0) return;
if ((i->repUsedValue()==2) && (get_ZF()!=0)) return; if (rep==2 && get_ZF()!=0) return;
if (CX == 0) return; if (CX == 0) return;
BX_TICK1_IF_SINGLE_PROCESSOR(); BX_TICK1_IF_SINGLE_PROCESSOR();

View File

@ -1,5 +1,5 @@
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// $Id: cpu.h,v 1.354 2007-11-12 18:20:07 sshwarts Exp $ // $Id: cpu.h,v 1.355 2007-11-13 17:30:52 sshwarts Exp $
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// //
// Copyright (C) 2001 MandrakeSoft S.A. // Copyright (C) 2001 MandrakeSoft S.A.
@ -644,12 +644,12 @@ public:
Bit8u modRMData4; Bit8u modRMData4;
// 23..20 (unused) // 23..20 (unused)
// 19..16 index (sib) // 19..16 base (sib)
Bit8u modRMData3; Bit8u modRMData3;
// 15..14 mod (modrm) // 15..14 mod (modrm)
// 13..12 scale (sib) // 13..12 scale (sib)
// 11...8 base (sib) // 11...8 index (sib)
Bit8u modRMData2; Bit8u modRMData2;
// 7...4 (unused) // 7...4 (unused)
@ -740,10 +740,10 @@ public:
return (modRMForm.modRMData2 >> 4) & 0x3; return (modRMForm.modRMData2 >> 4) & 0x3;
} }
BX_CPP_INLINE unsigned sibIndex() { BX_CPP_INLINE unsigned sibIndex() {
return modRMForm.modRMData3; return (modRMForm.modRMData2) & 0xf;
} }
BX_CPP_INLINE unsigned sibBase() { BX_CPP_INLINE unsigned sibBase() {
return (modRMForm.modRMData2) & 0xf; return modRMForm.modRMData3;
} }
BX_CPP_INLINE Bit32u displ32u() { return modRMForm.displ32u; } BX_CPP_INLINE Bit32u displ32u() { return modRMForm.displ32u; }
BX_CPP_INLINE Bit16u displ16u() { return modRMForm.displ16u; } BX_CPP_INLINE Bit16u displ16u() { return modRMForm.displ16u; }
@ -801,9 +801,6 @@ public:
BX_CPP_INLINE unsigned os64L(void) { BX_CPP_INLINE unsigned os64L(void) {
return metaInfo1 & (1<<5); return metaInfo1 & (1<<5);
} }
BX_CPP_INLINE void setOs64B(unsigned bit) {
metaInfo1 = (metaInfo1 & ~(1<<5)) | (bit<<5);
}
BX_CPP_INLINE void assertOs64(void) { BX_CPP_INLINE void assertOs64(void) {
metaInfo1 |= (1<<5); metaInfo1 |= (1<<5);
} }
@ -2737,124 +2734,49 @@ public: // for now...
BX_SMF void UndefinedOpcode(bxInstruction_c *); BX_SMF void UndefinedOpcode(bxInstruction_c *);
BX_SMF void BxError(bxInstruction_c *i); BX_SMF void BxError(bxInstruction_c *i);
BX_SMF void ResolveDummy(bxInstruction_c *) BX_CPP_AttrRegparmN(1); BX_SMF void BxResolveDummy(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve16Mod0Rm0(bxInstruction_c *) BX_CPP_AttrRegparmN(1); BX_SMF void BxResolve16Mod0Rm0(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve16Mod0Rm1(bxInstruction_c *) BX_CPP_AttrRegparmN(1); BX_SMF void BxResolve16Mod0Rm1(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve16Mod0Rm2(bxInstruction_c *) BX_CPP_AttrRegparmN(1); BX_SMF void BxResolve16Mod0Rm2(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve16Mod0Rm3(bxInstruction_c *) BX_CPP_AttrRegparmN(1); BX_SMF void BxResolve16Mod0Rm3(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve16Mod0Rm4(bxInstruction_c *) BX_CPP_AttrRegparmN(1); BX_SMF void BxResolve16Mod0Rm4(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve16Mod0Rm5(bxInstruction_c *) BX_CPP_AttrRegparmN(1); BX_SMF void BxResolve16Mod0Rm5(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve16Mod0Rm6(bxInstruction_c *) BX_CPP_AttrRegparmN(1); BX_SMF void BxResolve16Mod0Rm6(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve16Mod0Rm7(bxInstruction_c *) BX_CPP_AttrRegparmN(1); BX_SMF void BxResolve16Mod0Rm7(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve16Mod1or2Rm0(bxInstruction_c *) BX_CPP_AttrRegparmN(1); BX_SMF void BxResolve16Mod1or2Rm0(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve16Mod1or2Rm1(bxInstruction_c *) BX_CPP_AttrRegparmN(1); BX_SMF void BxResolve16Mod1or2Rm1(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve16Mod1or2Rm2(bxInstruction_c *) BX_CPP_AttrRegparmN(1); BX_SMF void BxResolve16Mod1or2Rm2(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve16Mod1or2Rm3(bxInstruction_c *) BX_CPP_AttrRegparmN(1); BX_SMF void BxResolve16Mod1or2Rm3(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve16Mod1or2Rm4(bxInstruction_c *) BX_CPP_AttrRegparmN(1); BX_SMF void BxResolve16Mod1or2Rm4(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve16Mod1or2Rm5(bxInstruction_c *) BX_CPP_AttrRegparmN(1); BX_SMF void BxResolve16Mod1or2Rm5(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve16Mod1or2Rm6(bxInstruction_c *) BX_CPP_AttrRegparmN(1); BX_SMF void BxResolve16Mod1or2Rm6(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve16Mod1or2Rm7(bxInstruction_c *) BX_CPP_AttrRegparmN(1); BX_SMF void BxResolve16Mod1or2Rm7(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve32Mod0Rm0(bxInstruction_c *) BX_CPP_AttrRegparmN(1); BX_SMF void BxResolve32Mod0Rm(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve32Mod0Rm1(bxInstruction_c *) BX_CPP_AttrRegparmN(1); BX_SMF void BxResolve32Mod0Base(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve32Mod0Rm2(bxInstruction_c *) BX_CPP_AttrRegparmN(1); BX_SMF void BxResolve32Mod0Disp(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve32Mod0Rm3(bxInstruction_c *) BX_CPP_AttrRegparmN(1); BX_SMF void BxResolve32Mod0BaseIndex(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve32Mod0Rm5(bxInstruction_c *) BX_CPP_AttrRegparmN(1); BX_SMF void BxResolve32Mod0DispIndex(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve32Mod0Rm6(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve32Mod0Rm7(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve32Mod1or2Rm0(bxInstruction_c *) BX_CPP_AttrRegparmN(1); BX_SMF void BxResolve32Mod1or2Rm(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve32Mod1or2Rm1(bxInstruction_c *) BX_CPP_AttrRegparmN(1); BX_SMF void BxResolve32Mod1or2Base(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve32Mod1or2Rm2(bxInstruction_c *) BX_CPP_AttrRegparmN(1); BX_SMF void BxResolve32Mod1or2BaseIndex(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve32Mod1or2Rm3(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve32Mod1or2Rm5(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve32Mod1or2Rm6(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve32Mod1or2Rm7(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve32Mod0Base0(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve32Mod0Base1(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve32Mod0Base2(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve32Mod0Base3(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve32Mod0Base4(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve32Mod0Base5(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve32Mod0Base6(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve32Mod0Base7(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve32Mod1or2Base0(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve32Mod1or2Base1(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve32Mod1or2Base2(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve32Mod1or2Base3(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve32Mod1or2Base4(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve32Mod1or2Base5(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve32Mod1or2Base6(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve32Mod1or2Base7(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
#if BX_SUPPORT_X86_64 #if BX_SUPPORT_X86_64
// 64 bit addressing BX_SMF void BxResolve32Mod0Rip(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod0Rm0(bxInstruction_c *) BX_CPP_AttrRegparmN(1); BX_SMF void BxResolve64Mod0Rip(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod0Rm1(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod0Rm2(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod0Rm3(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod0Rip(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod0Rm6(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod0Rm7(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod0Rm8(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod0Rm9(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod0Rm10(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod0Rm11(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod0Rm14(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod0Rm15(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod1or2Rm0(bxInstruction_c *) BX_CPP_AttrRegparmN(1); BX_SMF void BxResolve64Mod0Rm(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod1or2Rm1(bxInstruction_c *) BX_CPP_AttrRegparmN(1); BX_SMF void BxResolve64Mod0Base(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod1or2Rm2(bxInstruction_c *) BX_CPP_AttrRegparmN(1); BX_SMF void BxResolve64Mod0Disp(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod1or2Rm3(bxInstruction_c *) BX_CPP_AttrRegparmN(1); BX_SMF void BxResolve64Mod0BaseIndex(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod1or2Rm5(bxInstruction_c *) BX_CPP_AttrRegparmN(1); BX_SMF void BxResolve64Mod0DispIndex(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod1or2Rm6(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod1or2Rm7(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod1or2Rm8(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod1or2Rm9(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod1or2Rm10(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod1or2Rm11(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod1or2Rm13(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod1or2Rm14(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod1or2Rm15(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod0Base0(bxInstruction_c *) BX_CPP_AttrRegparmN(1); BX_SMF void BxResolve64Mod1or2Rm(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod0Base1(bxInstruction_c *) BX_CPP_AttrRegparmN(1); BX_SMF void BxResolve64Mod1or2Base(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod0Base2(bxInstruction_c *) BX_CPP_AttrRegparmN(1); BX_SMF void BxResolve64Mod1or2BaseIndex(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod0Base3(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod0Base4(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod0Base5(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod0Base6(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod0Base7(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod0Base8(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod0Base9(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod0Base10(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod0Base11(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod0Base12(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod0Base13(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod0Base14(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod0Base15(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod1or2Base0(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod1or2Base1(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod1or2Base2(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod1or2Base3(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod1or2Base4(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod1or2Base5(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod1or2Base6(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod1or2Base7(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod1or2Base8(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod1or2Base9(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod1or2Base10(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod1or2Base11(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod1or2Base12(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod1or2Base13(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod1or2Base14(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
BX_SMF void Resolve64Mod1or2Base15(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
#endif // #if BX_SUPPORT_X86_64 #endif // #if BX_SUPPORT_X86_64
// <TAG-CLASS-CPU-END> // <TAG-CLASS-CPU-END>

View File

@ -1,5 +1,5 @@
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// $Id: fetchdecode.cc,v 1.117 2007-11-12 18:20:10 sshwarts Exp $ // $Id: fetchdecode.cc,v 1.118 2007-11-13 17:30:52 sshwarts Exp $
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// //
// Copyright (C) 2001 MandrakeSoft S.A. // Copyright (C) 2001 MandrakeSoft S.A.
@ -61,70 +61,59 @@
* presence or absence of the LOCK prefix. * presence or absence of the LOCK prefix.
*/ */
static BxExecutePtr_tR BxResolve16Mod0[8] = { static BxExecutePtr_tR Resolve16Mod0[8] = {
&BX_CPU_C::Resolve16Mod0Rm0, &BX_CPU_C::BxResolve16Mod0Rm0,
&BX_CPU_C::Resolve16Mod0Rm1, &BX_CPU_C::BxResolve16Mod0Rm1,
&BX_CPU_C::Resolve16Mod0Rm2, &BX_CPU_C::BxResolve16Mod0Rm2,
&BX_CPU_C::Resolve16Mod0Rm3, &BX_CPU_C::BxResolve16Mod0Rm3,
&BX_CPU_C::Resolve16Mod0Rm4, &BX_CPU_C::BxResolve16Mod0Rm4,
&BX_CPU_C::Resolve16Mod0Rm5, &BX_CPU_C::BxResolve16Mod0Rm5,
&BX_CPU_C::Resolve16Mod0Rm6, &BX_CPU_C::BxResolve16Mod0Rm6,
&BX_CPU_C::Resolve16Mod0Rm7 &BX_CPU_C::BxResolve16Mod0Rm7
}; };
static BxExecutePtr_tR BxResolve16Mod1or2[8] = { static BxExecutePtr_tR Resolve16Mod1or2[8] = {
&BX_CPU_C::Resolve16Mod1or2Rm0, &BX_CPU_C::BxResolve16Mod1or2Rm0,
&BX_CPU_C::Resolve16Mod1or2Rm1, &BX_CPU_C::BxResolve16Mod1or2Rm1,
&BX_CPU_C::Resolve16Mod1or2Rm2, &BX_CPU_C::BxResolve16Mod1or2Rm2,
&BX_CPU_C::Resolve16Mod1or2Rm3, &BX_CPU_C::BxResolve16Mod1or2Rm3,
&BX_CPU_C::Resolve16Mod1or2Rm4, &BX_CPU_C::BxResolve16Mod1or2Rm4,
&BX_CPU_C::Resolve16Mod1or2Rm5, &BX_CPU_C::BxResolve16Mod1or2Rm5,
&BX_CPU_C::Resolve16Mod1or2Rm6, &BX_CPU_C::BxResolve16Mod1or2Rm6,
&BX_CPU_C::Resolve16Mod1or2Rm7 &BX_CPU_C::BxResolve16Mod1or2Rm7
}; };
static BxExecutePtr_tR BxResolve32Mod0[8] = { static BxExecutePtr_tR Resolve32Mod0[8] = {
&BX_CPU_C::Resolve32Mod0Rm0, &BX_CPU_C::BxResolve32Mod0Rm,
&BX_CPU_C::Resolve32Mod0Rm1, &BX_CPU_C::BxResolve32Mod0Rm,
&BX_CPU_C::Resolve32Mod0Rm2, &BX_CPU_C::BxResolve32Mod0Rm,
&BX_CPU_C::Resolve32Mod0Rm3, &BX_CPU_C::BxResolve32Mod0Rm,
NULL, // escape to 2-byte NULL, // escape to SIB-byte
&BX_CPU_C::Resolve32Mod0Rm5, &BX_CPU_C::BxResolve32Mod0Disp,
&BX_CPU_C::Resolve32Mod0Rm6, &BX_CPU_C::BxResolve32Mod0Rm,
&BX_CPU_C::Resolve32Mod0Rm7 &BX_CPU_C::BxResolve32Mod0Rm
}; };
static BxExecutePtr_tR BxResolve32Mod1or2[8] = { static BxExecutePtr_tR Resolve32Mod0Base[8] = {
&BX_CPU_C::Resolve32Mod1or2Rm0, &BX_CPU_C::BxResolve32Mod0Base,
&BX_CPU_C::Resolve32Mod1or2Rm1, &BX_CPU_C::BxResolve32Mod0Base,
&BX_CPU_C::Resolve32Mod1or2Rm2, &BX_CPU_C::BxResolve32Mod0Base,
&BX_CPU_C::Resolve32Mod1or2Rm3, &BX_CPU_C::BxResolve32Mod0Base,
NULL, // escape to 2-byte &BX_CPU_C::BxResolve32Mod0Base,
&BX_CPU_C::Resolve32Mod1or2Rm5, &BX_CPU_C::BxResolve32Mod0Disp,
&BX_CPU_C::Resolve32Mod1or2Rm6, &BX_CPU_C::BxResolve32Mod0Base,
&BX_CPU_C::Resolve32Mod1or2Rm7 &BX_CPU_C::BxResolve32Mod0Base,
}; };
static BxExecutePtr_tR BxResolve32Mod0Base[8] = { static BxExecutePtr_tR Resolve32Mod0BaseIndex[8] = {
&BX_CPU_C::Resolve32Mod0Base0, &BX_CPU_C::BxResolve32Mod0BaseIndex,
&BX_CPU_C::Resolve32Mod0Base1, &BX_CPU_C::BxResolve32Mod0BaseIndex,
&BX_CPU_C::Resolve32Mod0Base2, &BX_CPU_C::BxResolve32Mod0BaseIndex,
&BX_CPU_C::Resolve32Mod0Base3, &BX_CPU_C::BxResolve32Mod0BaseIndex,
&BX_CPU_C::Resolve32Mod0Base4, &BX_CPU_C::BxResolve32Mod0BaseIndex,
&BX_CPU_C::Resolve32Mod0Base5, &BX_CPU_C::BxResolve32Mod0DispIndex,
&BX_CPU_C::Resolve32Mod0Base6, &BX_CPU_C::BxResolve32Mod0BaseIndex,
&BX_CPU_C::Resolve32Mod0Base7, &BX_CPU_C::BxResolve32Mod0BaseIndex,
};
static BxExecutePtr_tR BxResolve32Mod1or2Base[8] = {
&BX_CPU_C::Resolve32Mod1or2Base0,
&BX_CPU_C::Resolve32Mod1or2Base1,
&BX_CPU_C::Resolve32Mod1or2Base2,
&BX_CPU_C::Resolve32Mod1or2Base3,
&BX_CPU_C::Resolve32Mod1or2Base4,
&BX_CPU_C::Resolve32Mod1or2Base5,
&BX_CPU_C::Resolve32Mod1or2Base6,
&BX_CPU_C::Resolve32Mod1or2Base7,
}; };
@ -1549,7 +1538,7 @@ BX_CPU_C::fetchDecode32(Bit8u *iptr, bxInstruction_c *instruction, unsigned rema
os_32 = is_32 = os_32 = is_32 =
BX_CPU_THIS_PTR sregs[BX_SEG_REG_CS].cache.u.segment.d_b; BX_CPU_THIS_PTR sregs[BX_SEG_REG_CS].cache.u.segment.d_b;
instruction->ResolveModrm = ResolveDummy; instruction->ResolveModrm = BxResolveDummy;
instruction->initMetaInfo(/*os32*/ is_32, /*as32*/ is_32, instruction->initMetaInfo(/*os32*/ is_32, /*as32*/ is_32,
/*os64*/ 0, /*as64*/ 0); /*os64*/ 0, /*as64*/ 0);
@ -1696,7 +1685,7 @@ fetch_b1:
// 32-bit addressing modes; note that mod==11b handled above // 32-bit addressing modes; note that mod==11b handled above
if (rm != 4) { // no s-i-b byte if (rm != 4) { // no s-i-b byte
if (mod == 0x00) { // mod == 00b if (mod == 0x00) { // mod == 00b
instruction->ResolveModrm = BxResolve32Mod0[rm]; instruction->ResolveModrm = Resolve32Mod0[rm];
if (BX_NULL_SEG_REG(instruction->seg())) if (BX_NULL_SEG_REG(instruction->seg()))
instruction->setSeg(BX_SEG_REG_DS); instruction->setSeg(BX_SEG_REG_DS);
if (rm == 5) { if (rm == 5) {
@ -1712,7 +1701,7 @@ fetch_b1:
goto modrm_done; goto modrm_done;
} }
if (mod == 0x40) { // mod == 01b if (mod == 0x40) { // mod == 01b
instruction->ResolveModrm = BxResolve32Mod1or2[rm]; instruction->ResolveModrm = BxResolve32Mod1or2Rm;
if (BX_NULL_SEG_REG(instruction->seg())) if (BX_NULL_SEG_REG(instruction->seg()))
instruction->setSeg(BX_CPU_THIS_PTR sreg_mod01or10_rm32[rm]); instruction->setSeg(BX_CPU_THIS_PTR sreg_mod01or10_rm32[rm]);
get_8bit_displ: get_8bit_displ:
@ -1725,7 +1714,7 @@ get_8bit_displ:
else return(0); else return(0);
} }
// (mod == 0x80) mod == 10b // (mod == 0x80) mod == 10b
instruction->ResolveModrm = BxResolve32Mod1or2[rm]; instruction->ResolveModrm = BxResolve32Mod1or2Rm;
if (BX_NULL_SEG_REG(instruction->seg())) if (BX_NULL_SEG_REG(instruction->seg()))
instruction->setSeg(BX_CPU_THIS_PTR sreg_mod01or10_rm32[rm]); instruction->setSeg(BX_CPU_THIS_PTR sreg_mod01or10_rm32[rm]);
get_32bit_displ: get_32bit_displ:
@ -1749,11 +1738,14 @@ get_32bit_displ:
base = sib & 0x07; sib >>= 3; base = sib & 0x07; sib >>= 3;
index = sib & 0x07; sib >>= 3; index = sib & 0x07; sib >>= 3;
scale = sib; scale = sib;
instruction->modRMForm.modRMData2 |= (base); instruction->modRMForm.modRMData3 |= (base);
instruction->modRMForm.modRMData3 |= (index); instruction->modRMForm.modRMData2 |= (index);
instruction->modRMForm.modRMData2 |= (scale<<4); instruction->modRMForm.modRMData2 |= (scale<<4);
if (mod == 0x00) { // mod==00b, rm==4 if (mod == 0x00) { // mod==00b, rm==4
instruction->ResolveModrm = BxResolve32Mod0Base[base]; if (index == 4)
instruction->ResolveModrm = Resolve32Mod0Base[base];
else
instruction->ResolveModrm = Resolve32Mod0BaseIndex[base];
if (BX_NULL_SEG_REG(instruction->seg())) if (BX_NULL_SEG_REG(instruction->seg()))
instruction->setSeg(BX_CPU_THIS_PTR sreg_mod0_base32[base]); instruction->setSeg(BX_CPU_THIS_PTR sreg_mod0_base32[base]);
if (base == 0x05) if (base == 0x05)
@ -1762,13 +1754,19 @@ get_32bit_displ:
goto modrm_done; goto modrm_done;
} }
if (mod == 0x40) { // mod==01b, rm==4 if (mod == 0x40) { // mod==01b, rm==4
instruction->ResolveModrm = BxResolve32Mod1or2Base[base]; if (index == 4)
instruction->ResolveModrm = BxResolve32Mod1or2Base;
else
instruction->ResolveModrm = BxResolve32Mod1or2BaseIndex;
if (BX_NULL_SEG_REG(instruction->seg())) if (BX_NULL_SEG_REG(instruction->seg()))
instruction->setSeg(BX_CPU_THIS_PTR sreg_mod1or2_base32[base]); instruction->setSeg(BX_CPU_THIS_PTR sreg_mod1or2_base32[base]);
goto get_8bit_displ; goto get_8bit_displ;
} }
// (mod == 0x80), mod==10b, rm==4 // (mod == 0x80), mod==10b, rm==4
instruction->ResolveModrm = BxResolve32Mod1or2Base[base]; if (index == 4)
instruction->ResolveModrm = BxResolve32Mod1or2Base;
else
instruction->ResolveModrm = BxResolve32Mod1or2BaseIndex;
if (BX_NULL_SEG_REG(instruction->seg())) if (BX_NULL_SEG_REG(instruction->seg()))
instruction->setSeg(BX_CPU_THIS_PTR sreg_mod1or2_base32[base]); instruction->setSeg(BX_CPU_THIS_PTR sreg_mod1or2_base32[base]);
goto get_32bit_displ; goto get_32bit_displ;
@ -1777,7 +1775,7 @@ get_32bit_displ:
else { else {
// 16-bit addressing modes, mod==11b handled above // 16-bit addressing modes, mod==11b handled above
if (mod == 0x40) { // mod == 01b if (mod == 0x40) { // mod == 01b
instruction->ResolveModrm = BxResolve16Mod1or2[rm]; instruction->ResolveModrm = Resolve16Mod1or2[rm];
if (BX_NULL_SEG_REG(instruction->seg())) if (BX_NULL_SEG_REG(instruction->seg()))
instruction->setSeg(BX_CPU_THIS_PTR sreg_mod01or10_rm16[rm]); instruction->setSeg(BX_CPU_THIS_PTR sreg_mod01or10_rm16[rm]);
if (ilen < remain) { if (ilen < remain) {
@ -1789,7 +1787,7 @@ get_32bit_displ:
else return(0); else return(0);
} }
if (mod == 0x80) { // mod == 10b if (mod == 0x80) { // mod == 10b
instruction->ResolveModrm = BxResolve16Mod1or2[rm]; instruction->ResolveModrm = Resolve16Mod1or2[rm];
if (BX_NULL_SEG_REG(instruction->seg())) if (BX_NULL_SEG_REG(instruction->seg()))
instruction->setSeg(BX_CPU_THIS_PTR sreg_mod01or10_rm16[rm]); instruction->setSeg(BX_CPU_THIS_PTR sreg_mod01or10_rm16[rm]);
if ((ilen+1) < remain) { if ((ilen+1) < remain) {
@ -1801,7 +1799,7 @@ get_32bit_displ:
else return(0); else return(0);
} }
// mod must be 00b at this point // mod must be 00b at this point
instruction->ResolveModrm = BxResolve16Mod0[rm]; instruction->ResolveModrm = Resolve16Mod0[rm];
if (BX_NULL_SEG_REG(instruction->seg())) if (BX_NULL_SEG_REG(instruction->seg()))
instruction->setSeg(BX_CPU_THIS_PTR sreg_mod00_rm16[rm]); instruction->setSeg(BX_CPU_THIS_PTR sreg_mod00_rm16[rm]);
if (rm == 0x06) { if (rm == 0x06) {

View File

@ -1,5 +1,5 @@
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// $Id: fetchdecode64.cc,v 1.123 2007-11-12 18:20:12 sshwarts Exp $ // $Id: fetchdecode64.cc,v 1.124 2007-11-13 17:30:54 sshwarts Exp $
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// //
// Copyright (C) 2001 MandrakeSoft S.A. // Copyright (C) 2001 MandrakeSoft S.A.
@ -65,127 +65,97 @@
// Segment override prefixes // Segment override prefixes
// ------------------------- // -------------------------
// In 64-bit mode, the CS, DS, ES, and SS segment overrides are ignored. // In 64-bit mode the CS, DS, ES, and SS segment overrides are ignored.
static BxExecutePtr_tR BxResolve32Mod0[8] = { static BxExecutePtr_tR Resolve32Mod0[8] = {
&BX_CPU_C::Resolve32Mod0Rm0, &BX_CPU_C::BxResolve32Mod0Rm,
&BX_CPU_C::Resolve32Mod0Rm1, &BX_CPU_C::BxResolve32Mod0Rm,
&BX_CPU_C::Resolve32Mod0Rm2, &BX_CPU_C::BxResolve32Mod0Rm,
&BX_CPU_C::Resolve32Mod0Rm3, &BX_CPU_C::BxResolve32Mod0Rm,
NULL, // escape to 2-byte NULL, // escape to SIB-byte
&BX_CPU_C::Resolve64Mod0Rip, &BX_CPU_C::BxResolve32Mod0Rip,
&BX_CPU_C::Resolve32Mod0Rm6, &BX_CPU_C::BxResolve32Mod0Rm,
&BX_CPU_C::Resolve32Mod0Rm7 &BX_CPU_C::BxResolve32Mod0Rm
}; };
static BxExecutePtr_tR BxResolve32Mod1or2[8] = { static BxExecutePtr_tR Resolve32Mod0Base[8] = {
&BX_CPU_C::Resolve32Mod1or2Rm0, &BX_CPU_C::BxResolve32Mod0Base,
&BX_CPU_C::Resolve32Mod1or2Rm1, &BX_CPU_C::BxResolve32Mod0Base,
&BX_CPU_C::Resolve32Mod1or2Rm2, &BX_CPU_C::BxResolve32Mod0Base,
&BX_CPU_C::Resolve32Mod1or2Rm3, &BX_CPU_C::BxResolve32Mod0Base,
NULL, // escape to 2-byte &BX_CPU_C::BxResolve32Mod0Base,
&BX_CPU_C::Resolve32Mod1or2Rm5, &BX_CPU_C::BxResolve32Mod0Disp,
&BX_CPU_C::Resolve32Mod1or2Rm6, &BX_CPU_C::BxResolve32Mod0Base,
&BX_CPU_C::Resolve32Mod1or2Rm7 &BX_CPU_C::BxResolve32Mod0Base,
}; };
static BxExecutePtr_tR BxResolve32Mod0Base[8] = { static BxExecutePtr_tR Resolve32Mod0BaseIndex[8] = {
&BX_CPU_C::Resolve32Mod0Base0, &BX_CPU_C::BxResolve32Mod0BaseIndex,
&BX_CPU_C::Resolve32Mod0Base1, &BX_CPU_C::BxResolve32Mod0BaseIndex,
&BX_CPU_C::Resolve32Mod0Base2, &BX_CPU_C::BxResolve32Mod0BaseIndex,
&BX_CPU_C::Resolve32Mod0Base3, &BX_CPU_C::BxResolve32Mod0BaseIndex,
&BX_CPU_C::Resolve32Mod0Base4, &BX_CPU_C::BxResolve32Mod0BaseIndex,
&BX_CPU_C::Resolve32Mod0Base5, &BX_CPU_C::BxResolve32Mod0DispIndex,
&BX_CPU_C::Resolve32Mod0Base6, &BX_CPU_C::BxResolve32Mod0BaseIndex,
&BX_CPU_C::Resolve32Mod0Base7, &BX_CPU_C::BxResolve32Mod0BaseIndex,
}; };
static BxExecutePtr_tR BxResolve32Mod1or2Base[8] = { static BxExecutePtr_tR Resolve64Mod0[16] = {
&BX_CPU_C::Resolve32Mod1or2Base0, &BX_CPU_C::BxResolve64Mod0Rm,
&BX_CPU_C::Resolve32Mod1or2Base1, &BX_CPU_C::BxResolve64Mod0Rm,
&BX_CPU_C::Resolve32Mod1or2Base2, &BX_CPU_C::BxResolve64Mod0Rm,
&BX_CPU_C::Resolve32Mod1or2Base3, &BX_CPU_C::BxResolve64Mod0Rm,
&BX_CPU_C::Resolve32Mod1or2Base4, NULL, // escape to SIB-byte
&BX_CPU_C::Resolve32Mod1or2Base5, &BX_CPU_C::BxResolve64Mod0Rip,
&BX_CPU_C::Resolve32Mod1or2Base6, &BX_CPU_C::BxResolve64Mod0Rm,
&BX_CPU_C::Resolve32Mod1or2Base7, &BX_CPU_C::BxResolve64Mod0Rm,
&BX_CPU_C::BxResolve64Mod0Rm,
&BX_CPU_C::BxResolve64Mod0Rm,
&BX_CPU_C::BxResolve64Mod0Rm,
&BX_CPU_C::BxResolve64Mod0Rm,
NULL, // escape to SIB-byte
&BX_CPU_C::BxResolve64Mod0Rip,
&BX_CPU_C::BxResolve64Mod0Rm,
&BX_CPU_C::BxResolve64Mod0Rm
}; };
static BxExecutePtr_tR BxResolve64Mod0[16] = { static BxExecutePtr_tR Resolve64Mod0Base[16] = {
&BX_CPU_C::Resolve64Mod0Rm0, &BX_CPU_C::BxResolve64Mod0Base,
&BX_CPU_C::Resolve64Mod0Rm1, &BX_CPU_C::BxResolve64Mod0Base,
&BX_CPU_C::Resolve64Mod0Rm2, &BX_CPU_C::BxResolve64Mod0Base,
&BX_CPU_C::Resolve64Mod0Rm3, &BX_CPU_C::BxResolve64Mod0Base,
NULL, // escape to 2-byte &BX_CPU_C::BxResolve64Mod0Base,
&BX_CPU_C::Resolve64Mod0Rip, &BX_CPU_C::BxResolve64Mod0Disp,
&BX_CPU_C::Resolve64Mod0Rm6, &BX_CPU_C::BxResolve64Mod0Base,
&BX_CPU_C::Resolve64Mod0Rm7, &BX_CPU_C::BxResolve64Mod0Base,
&BX_CPU_C::Resolve64Mod0Rm8, &BX_CPU_C::BxResolve64Mod0Base,
&BX_CPU_C::Resolve64Mod0Rm9, &BX_CPU_C::BxResolve64Mod0Base,
&BX_CPU_C::Resolve64Mod0Rm10, &BX_CPU_C::BxResolve64Mod0Base,
&BX_CPU_C::Resolve64Mod0Rm11, &BX_CPU_C::BxResolve64Mod0Base,
NULL, // escape to 2-byte &BX_CPU_C::BxResolve64Mod0Base,
&BX_CPU_C::Resolve64Mod0Rip, &BX_CPU_C::BxResolve64Mod0Disp,
&BX_CPU_C::Resolve64Mod0Rm14, &BX_CPU_C::BxResolve64Mod0Base,
&BX_CPU_C::Resolve64Mod0Rm15 &BX_CPU_C::BxResolve64Mod0Base,
}; };
static BxExecutePtr_tR BxResolve64Mod1or2[16] = { static BxExecutePtr_tR Resolve64Mod0BaseIndex[16] = {
&BX_CPU_C::Resolve64Mod1or2Rm0, &BX_CPU_C::BxResolve64Mod0BaseIndex,
&BX_CPU_C::Resolve64Mod1or2Rm1, &BX_CPU_C::BxResolve64Mod0BaseIndex,
&BX_CPU_C::Resolve64Mod1or2Rm2, &BX_CPU_C::BxResolve64Mod0BaseIndex,
&BX_CPU_C::Resolve64Mod1or2Rm3, &BX_CPU_C::BxResolve64Mod0BaseIndex,
NULL, // escape to 2-byte &BX_CPU_C::BxResolve64Mod0BaseIndex,
&BX_CPU_C::Resolve64Mod1or2Rm5, &BX_CPU_C::BxResolve64Mod0DispIndex,
&BX_CPU_C::Resolve64Mod1or2Rm6, &BX_CPU_C::BxResolve64Mod0BaseIndex,
&BX_CPU_C::Resolve64Mod1or2Rm7, &BX_CPU_C::BxResolve64Mod0BaseIndex,
&BX_CPU_C::Resolve64Mod1or2Rm8, &BX_CPU_C::BxResolve64Mod0BaseIndex,
&BX_CPU_C::Resolve64Mod1or2Rm9, &BX_CPU_C::BxResolve64Mod0BaseIndex,
&BX_CPU_C::Resolve64Mod1or2Rm10, &BX_CPU_C::BxResolve64Mod0BaseIndex,
&BX_CPU_C::Resolve64Mod1or2Rm11, &BX_CPU_C::BxResolve64Mod0BaseIndex,
NULL, // escape to 2-byte &BX_CPU_C::BxResolve64Mod0BaseIndex,
&BX_CPU_C::Resolve64Mod1or2Rm13, &BX_CPU_C::BxResolve64Mod0DispIndex,
&BX_CPU_C::Resolve64Mod1or2Rm14, &BX_CPU_C::BxResolve64Mod0BaseIndex,
&BX_CPU_C::Resolve64Mod1or2Rm15 &BX_CPU_C::BxResolve64Mod0BaseIndex,
};
static BxExecutePtr_tR BxResolve64Mod0Base[16] = {
&BX_CPU_C::Resolve64Mod0Base0,
&BX_CPU_C::Resolve64Mod0Base1,
&BX_CPU_C::Resolve64Mod0Base2,
&BX_CPU_C::Resolve64Mod0Base3,
&BX_CPU_C::Resolve64Mod0Base4,
&BX_CPU_C::Resolve64Mod0Base5,
&BX_CPU_C::Resolve64Mod0Base6,
&BX_CPU_C::Resolve64Mod0Base7,
&BX_CPU_C::Resolve64Mod0Base8,
&BX_CPU_C::Resolve64Mod0Base9,
&BX_CPU_C::Resolve64Mod0Base10,
&BX_CPU_C::Resolve64Mod0Base11,
&BX_CPU_C::Resolve64Mod0Base12,
&BX_CPU_C::Resolve64Mod0Base13,
&BX_CPU_C::Resolve64Mod0Base14,
&BX_CPU_C::Resolve64Mod0Base15,
};
static BxExecutePtr_tR BxResolve64Mod1or2Base[16] = {
&BX_CPU_C::Resolve64Mod1or2Base0,
&BX_CPU_C::Resolve64Mod1or2Base1,
&BX_CPU_C::Resolve64Mod1or2Base2,
&BX_CPU_C::Resolve64Mod1or2Base3,
&BX_CPU_C::Resolve64Mod1or2Base4,
&BX_CPU_C::Resolve64Mod1or2Base5,
&BX_CPU_C::Resolve64Mod1or2Base6,
&BX_CPU_C::Resolve64Mod1or2Base7,
&BX_CPU_C::Resolve64Mod1or2Base8,
&BX_CPU_C::Resolve64Mod1or2Base9,
&BX_CPU_C::Resolve64Mod1or2Base10,
&BX_CPU_C::Resolve64Mod1or2Base11,
&BX_CPU_C::Resolve64Mod1or2Base12,
&BX_CPU_C::Resolve64Mod1or2Base13,
&BX_CPU_C::Resolve64Mod1or2Base14,
&BX_CPU_C::Resolve64Mod1or2Base15,
}; };
@ -2163,7 +2133,7 @@ BX_CPU_C::fetchDecode64(Bit8u *iptr, bxInstruction_c *instruction, unsigned rema
offset = 512*1; offset = 512*1;
instruction->ResolveModrm = ResolveDummy; instruction->ResolveModrm = BxResolveDummy;
instruction->initMetaInfo(/*os32*/ 1, // operand size 32 override defaults to 1 instruction->initMetaInfo(/*os32*/ 1, // operand size 32 override defaults to 1
/*as32*/ 1, // address size 32 override defaults to 1 /*as32*/ 1, // address size 32 override defaults to 1
/*os64*/ 0, // operand size 64 override defaults to 0 /*os64*/ 0, // operand size 64 override defaults to 0
@ -2310,31 +2280,27 @@ fetch_b1:
// Parse mod-nnn-rm and related bytes // Parse mod-nnn-rm and related bytes
mod = b2 & 0xc0; mod = b2 & 0xc0;
nnn = ((b2 >> 3) & 0x07) | rex_r; nnn = ((b2 >> 3) & 0x07) | rex_r;
rm = b2 & 0x07; rm = (b2 & 0x07) | rex_b;
// MOVs with CRx and DRx always use register ops and ignore the mod field. // MOVs with CRx and DRx always use register ops and ignore the mod field.
if ((b1 & ~3) == 0x120) if ((b1 & ~3) == 0x120)
mod = 0xc0; mod = 0xc0;
instruction->modRMForm.modRMData1 = 0; instruction->modRMForm.modRMData1 = rm;
instruction->modRMForm.modRMData2 = mod; instruction->modRMForm.modRMData2 = mod;
instruction->modRMForm.modRMData3 = 0; instruction->modRMForm.modRMData3 = 0;
instruction->modRMForm.modRMData4 = nnn; instruction->modRMForm.modRMData4 = nnn;
if (mod == 0xc0) { // mod == 11b if (mod == 0xc0) { // mod == 11b
rm |= rex_b;
instruction->modRMForm.modRMData1 |= rm;
instruction->assertModC0(); instruction->assertModC0();
goto modrm_done; goto modrm_done;
} }
if (rm != 4) rm |= rex_b;
instruction->modRMForm.modRMData1 |= rm;
if (instruction->as64L()) { if (instruction->as64L()) {
// 64-bit addressing modes; note that mod==11b handled above // 64-bit addressing modes; note that mod==11b handled above
if ((rm & 0x7) != 4) { // no s-i-b byte if ((rm & 0x7) != 4) { // no s-i-b byte
if (mod == 0x00) { // mod == 00b if (mod == 0x00) { // mod == 00b
instruction->ResolveModrm = BxResolve64Mod0[rm]; instruction->ResolveModrm = Resolve64Mod0[rm];
if (BX_NULL_SEG_REG(instruction->seg())) if (BX_NULL_SEG_REG(instruction->seg()))
instruction->setSeg(BX_SEG_REG_DS); instruction->setSeg(BX_SEG_REG_DS);
if ((rm & 0x7) == 5) { if ((rm & 0x7) == 5) {
@ -2350,7 +2316,7 @@ fetch_b1:
goto modrm_done; goto modrm_done;
} }
if (mod == 0x40) { // mod == 01b if (mod == 0x40) { // mod == 01b
instruction->ResolveModrm = BxResolve64Mod1or2[rm]; instruction->ResolveModrm = BxResolve64Mod1or2Rm;
if (BX_NULL_SEG_REG(instruction->seg())) if (BX_NULL_SEG_REG(instruction->seg()))
instruction->setSeg(BX_CPU_THIS_PTR sreg_mod01or10_rm32[rm]); instruction->setSeg(BX_CPU_THIS_PTR sreg_mod01or10_rm32[rm]);
if (ilen < remain) { if (ilen < remain) {
@ -2362,7 +2328,7 @@ fetch_b1:
else return(0); else return(0);
} }
// (mod == 0x80) mod == 10b // (mod == 0x80) mod == 10b
instruction->ResolveModrm = BxResolve64Mod1or2[rm]; instruction->ResolveModrm = BxResolve64Mod1or2Rm;
if (BX_NULL_SEG_REG(instruction->seg())) if (BX_NULL_SEG_REG(instruction->seg()))
instruction->setSeg(BX_CPU_THIS_PTR sreg_mod01or10_rm32[rm]); instruction->setSeg(BX_CPU_THIS_PTR sreg_mod01or10_rm32[rm]);
if ((ilen+3) < remain) { if ((ilen+3) < remain) {
@ -2384,12 +2350,15 @@ fetch_b1:
} }
base = (sib & 0x07) | rex_b; sib >>= 3; base = (sib & 0x07) | rex_b; sib >>= 3;
index = (sib & 0x07) | rex_x; sib >>= 3; index = (sib & 0x07) | rex_x; sib >>= 3;
scale = sib; scale = sib;
instruction->modRMForm.modRMData2 |= (base); instruction->modRMForm.modRMData3 |= (base);
instruction->modRMForm.modRMData3 |= (index); instruction->modRMForm.modRMData2 |= (index);
instruction->modRMForm.modRMData2 |= (scale<<4); instruction->modRMForm.modRMData2 |= (scale<<4);
if (mod == 0x00) { // mod==00b, rm==4 if (mod == 0x00) { // mod==00b, rm==4
instruction->ResolveModrm = BxResolve64Mod0Base[base]; if (index == 4)
instruction->ResolveModrm = Resolve64Mod0Base[base];
else
instruction->ResolveModrm = Resolve64Mod0BaseIndex[base];
if (BX_NULL_SEG_REG(instruction->seg())) if (BX_NULL_SEG_REG(instruction->seg()))
instruction->setSeg(BX_CPU_THIS_PTR sreg_mod0_base32[base]); instruction->setSeg(BX_CPU_THIS_PTR sreg_mod0_base32[base]);
if ((base & 0x7) == 5) if ((base & 0x7) == 5)
@ -2398,13 +2367,19 @@ fetch_b1:
goto modrm_done; goto modrm_done;
} }
if (mod == 0x40) { // mod==01b, rm==4 if (mod == 0x40) { // mod==01b, rm==4
instruction->ResolveModrm = BxResolve64Mod1or2Base[base]; if (index == 4)
instruction->ResolveModrm = BxResolve64Mod1or2Base;
else
instruction->ResolveModrm = BxResolve64Mod1or2BaseIndex;
if (BX_NULL_SEG_REG(instruction->seg())) if (BX_NULL_SEG_REG(instruction->seg()))
instruction->setSeg(BX_CPU_THIS_PTR sreg_mod1or2_base32[base]); instruction->setSeg(BX_CPU_THIS_PTR sreg_mod1or2_base32[base]);
goto get_8bit_displ; goto get_8bit_displ;
} }
// (mod == 0x80), mod==10b, rm==4 // (mod == 0x80), mod==10b, rm==4
instruction->ResolveModrm = BxResolve64Mod1or2Base[base]; if (index == 4)
instruction->ResolveModrm = BxResolve64Mod1or2Base;
else
instruction->ResolveModrm = BxResolve64Mod1or2BaseIndex;
if (BX_NULL_SEG_REG(instruction->seg())) if (BX_NULL_SEG_REG(instruction->seg()))
instruction->setSeg(BX_CPU_THIS_PTR sreg_mod1or2_base32[base]); instruction->setSeg(BX_CPU_THIS_PTR sreg_mod1or2_base32[base]);
goto get_32bit_displ; goto get_32bit_displ;
@ -2414,7 +2389,7 @@ fetch_b1:
// 32-bit addressing modes; note that mod==11b handled above // 32-bit addressing modes; note that mod==11b handled above
if ((rm & 0x7) != 4) { // no s-i-b byte if ((rm & 0x7) != 4) { // no s-i-b byte
if (mod == 0x00) { // mod == 00b if (mod == 0x00) { // mod == 00b
instruction->ResolveModrm = BxResolve32Mod0[rm]; instruction->ResolveModrm = Resolve32Mod0[rm];
if (BX_NULL_SEG_REG(instruction->seg())) if (BX_NULL_SEG_REG(instruction->seg()))
instruction->setSeg(BX_SEG_REG_DS); instruction->setSeg(BX_SEG_REG_DS);
if ((rm & 0x7) == 5) { if ((rm & 0x7) == 5) {
@ -2430,7 +2405,7 @@ fetch_b1:
goto modrm_done; goto modrm_done;
} }
if (mod == 0x40) { // mod == 01b if (mod == 0x40) { // mod == 01b
instruction->ResolveModrm = BxResolve32Mod1or2[rm]; instruction->ResolveModrm = BxResolve32Mod1or2Rm;
if (BX_NULL_SEG_REG(instruction->seg())) if (BX_NULL_SEG_REG(instruction->seg()))
instruction->setSeg(BX_CPU_THIS_PTR sreg_mod01or10_rm32[rm]); instruction->setSeg(BX_CPU_THIS_PTR sreg_mod01or10_rm32[rm]);
get_8bit_displ: get_8bit_displ:
@ -2443,7 +2418,7 @@ get_8bit_displ:
else return(0); else return(0);
} }
// (mod == 0x80) mod == 10b // (mod == 0x80) mod == 10b
instruction->ResolveModrm = BxResolve32Mod1or2[rm]; instruction->ResolveModrm = BxResolve32Mod1or2Rm;
if (BX_NULL_SEG_REG(instruction->seg())) if (BX_NULL_SEG_REG(instruction->seg()))
instruction->setSeg(BX_CPU_THIS_PTR sreg_mod01or10_rm32[rm]); instruction->setSeg(BX_CPU_THIS_PTR sreg_mod01or10_rm32[rm]);
get_32bit_displ: get_32bit_displ:
@ -2466,12 +2441,15 @@ get_32bit_displ:
} }
base = (sib & 0x07) | rex_b; sib >>= 3; base = (sib & 0x07) | rex_b; sib >>= 3;
index = (sib & 0x07) | rex_x; sib >>= 3; index = (sib & 0x07) | rex_x; sib >>= 3;
scale = sib; scale = sib;
instruction->modRMForm.modRMData2 |= (base); instruction->modRMForm.modRMData3 |= (base);
instruction->modRMForm.modRMData3 |= (index); instruction->modRMForm.modRMData2 |= (index);
instruction->modRMForm.modRMData2 |= (scale<<4); instruction->modRMForm.modRMData2 |= (scale<<4);
if (mod == 0x00) { // mod==00b, rm==4 if (mod == 0x00) { // mod==00b, rm==4
instruction->ResolveModrm = BxResolve32Mod0Base[base]; if (index == 4)
instruction->ResolveModrm = Resolve32Mod0Base[base];
else
instruction->ResolveModrm = Resolve32Mod0BaseIndex[base];
if (BX_NULL_SEG_REG(instruction->seg())) if (BX_NULL_SEG_REG(instruction->seg()))
instruction->setSeg(BX_CPU_THIS_PTR sreg_mod0_base32[base]); instruction->setSeg(BX_CPU_THIS_PTR sreg_mod0_base32[base]);
if ((base & 0x7) == 5) if ((base & 0x7) == 5)
@ -2480,13 +2458,19 @@ get_32bit_displ:
goto modrm_done; goto modrm_done;
} }
if (mod == 0x40) { // mod==01b, rm==4 if (mod == 0x40) { // mod==01b, rm==4
instruction->ResolveModrm = BxResolve32Mod1or2Base[base]; if (index == 4)
instruction->ResolveModrm = BxResolve32Mod1or2Base;
else
instruction->ResolveModrm = BxResolve32Mod1or2BaseIndex;
if (BX_NULL_SEG_REG(instruction->seg())) if (BX_NULL_SEG_REG(instruction->seg()))
instruction->setSeg(BX_CPU_THIS_PTR sreg_mod1or2_base32[base]); instruction->setSeg(BX_CPU_THIS_PTR sreg_mod1or2_base32[base]);
goto get_8bit_displ; goto get_8bit_displ;
} }
// (mod == 0x80), mod==10b, rm==4 // (mod == 0x80), mod==10b, rm==4
instruction->ResolveModrm = BxResolve32Mod1or2Base[base]; if (index == 4)
instruction->ResolveModrm = BxResolve32Mod1or2Base;
else
instruction->ResolveModrm = BxResolve32Mod1or2BaseIndex;
if (BX_NULL_SEG_REG(instruction->seg())) if (BX_NULL_SEG_REG(instruction->seg()))
instruction->setSeg(BX_CPU_THIS_PTR sreg_mod1or2_base32[base]); instruction->setSeg(BX_CPU_THIS_PTR sreg_mod1or2_base32[base]);
goto get_32bit_displ; goto get_32bit_displ;

View File

@ -1,5 +1,5 @@
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// $Id: resolve16.cc,v 1.11 2007-11-12 18:20:15 sshwarts Exp $ // $Id: resolve16.cc,v 1.12 2007-11-13 17:30:54 sshwarts Exp $
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// //
// Copyright (C) 2001 MandrakeSoft S.A. // Copyright (C) 2001 MandrakeSoft S.A.
@ -31,89 +31,89 @@
#define LOG_THIS BX_CPU_THIS_PTR #define LOG_THIS BX_CPU_THIS_PTR
void BX_CPP_AttrRegparmN(1) void BX_CPP_AttrRegparmN(1)
BX_CPU_C::ResolveDummy(bxInstruction_c *i) BX_CPU_C::BxResolveDummy(bxInstruction_c *)
{ {
return; // used when no memory access is needed return; // used when no memory access is needed
} }
void BX_CPP_AttrRegparmN(1) void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve16Mod0Rm0(bxInstruction_c *i) BX_CPU_C::BxResolve16Mod0Rm0(bxInstruction_c *i)
{ {
RMAddr(i) = (Bit16u) (BX + SI); RMAddr(i) = (Bit16u) (BX + SI);
} }
void BX_CPP_AttrRegparmN(1) void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve16Mod0Rm1(bxInstruction_c *i) BX_CPU_C::BxResolve16Mod0Rm1(bxInstruction_c *i)
{ {
RMAddr(i) = (Bit16u) (BX + DI); RMAddr(i) = (Bit16u) (BX + DI);
} }
void BX_CPP_AttrRegparmN(1) void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve16Mod0Rm2(bxInstruction_c *i) BX_CPU_C::BxResolve16Mod0Rm2(bxInstruction_c *i)
{ {
RMAddr(i) = (Bit16u) (BP + SI); RMAddr(i) = (Bit16u) (BP + SI);
} }
void BX_CPP_AttrRegparmN(1) void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve16Mod0Rm3(bxInstruction_c *i) BX_CPU_C::BxResolve16Mod0Rm3(bxInstruction_c *i)
{ {
RMAddr(i) = (Bit16u) (BP + DI); RMAddr(i) = (Bit16u) (BP + DI);
} }
void BX_CPP_AttrRegparmN(1) void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve16Mod0Rm4(bxInstruction_c *i) BX_CPU_C::BxResolve16Mod0Rm4(bxInstruction_c *i)
{ {
RMAddr(i) = (Bit16u) SI; RMAddr(i) = (Bit16u) SI;
} }
void BX_CPP_AttrRegparmN(1) void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve16Mod0Rm5(bxInstruction_c *i) BX_CPU_C::BxResolve16Mod0Rm5(bxInstruction_c *i)
{ {
RMAddr(i) = (Bit16u) DI; RMAddr(i) = (Bit16u) DI;
} }
void BX_CPP_AttrRegparmN(1) void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve16Mod0Rm6(bxInstruction_c *i) BX_CPU_C::BxResolve16Mod0Rm6(bxInstruction_c *i)
{ {
RMAddr(i) = i->displ16u(); RMAddr(i) = i->displ16u();
} }
void BX_CPP_AttrRegparmN(1) void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve16Mod0Rm7(bxInstruction_c *i) BX_CPU_C::BxResolve16Mod0Rm7(bxInstruction_c *i)
{ {
RMAddr(i) = (Bit16u) BX; RMAddr(i) = (Bit16u) BX;
} }
void BX_CPP_AttrRegparmN(1) void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve16Mod1or2Rm0(bxInstruction_c *i) BX_CPU_C::BxResolve16Mod1or2Rm0(bxInstruction_c *i)
{ {
RMAddr(i) = (Bit16u) (BX + SI + (Bit16s) i->displ16u()); RMAddr(i) = (Bit16u) (BX + SI + (Bit16s) i->displ16u());
} }
void BX_CPP_AttrRegparmN(1) void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve16Mod1or2Rm1(bxInstruction_c *i) BX_CPU_C::BxResolve16Mod1or2Rm1(bxInstruction_c *i)
{ {
RMAddr(i) = (Bit16u) (BX + DI + (Bit16s) i->displ16u()); RMAddr(i) = (Bit16u) (BX + DI + (Bit16s) i->displ16u());
} }
void BX_CPP_AttrRegparmN(1) void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve16Mod1or2Rm2(bxInstruction_c *i) BX_CPU_C::BxResolve16Mod1or2Rm2(bxInstruction_c *i)
{ {
RMAddr(i) = (Bit16u) (BP + SI + (Bit16s) i->displ16u()); RMAddr(i) = (Bit16u) (BP + SI + (Bit16s) i->displ16u());
} }
void BX_CPP_AttrRegparmN(1) void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve16Mod1or2Rm3(bxInstruction_c *i) BX_CPU_C::BxResolve16Mod1or2Rm3(bxInstruction_c *i)
{ {
RMAddr(i) = (Bit16u) (BP + DI + (Bit16s) i->displ16u()); RMAddr(i) = (Bit16u) (BP + DI + (Bit16s) i->displ16u());
} }
void BX_CPP_AttrRegparmN(1) void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve16Mod1or2Rm4(bxInstruction_c *i) BX_CPU_C::BxResolve16Mod1or2Rm4(bxInstruction_c *i)
{ {
RMAddr(i) = (Bit16u) (SI + (Bit16s) i->displ16u()); RMAddr(i) = (Bit16u) (SI + (Bit16s) i->displ16u());
} }
void BX_CPP_AttrRegparmN(1) void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve16Mod1or2Rm5(bxInstruction_c *i) BX_CPU_C::BxResolve16Mod1or2Rm5(bxInstruction_c *i)
{ {
RMAddr(i) = (Bit16u) (DI + (Bit16s) i->displ16u()); RMAddr(i) = (Bit16u) (DI + (Bit16s) i->displ16u());
} }
void BX_CPP_AttrRegparmN(1) void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve16Mod1or2Rm6(bxInstruction_c *i) BX_CPU_C::BxResolve16Mod1or2Rm6(bxInstruction_c *i)
{ {
RMAddr(i) = (Bit16u) (BP + (Bit16s) i->displ16u()); RMAddr(i) = (Bit16u) (BP + (Bit16s) i->displ16u());
} }
void BX_CPP_AttrRegparmN(1) void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve16Mod1or2Rm7(bxInstruction_c *i) BX_CPU_C::BxResolve16Mod1or2Rm7(bxInstruction_c *i)
{ {
RMAddr(i) = (Bit16u) (BX + (Bit16s) i->displ16u()); RMAddr(i) = (Bit16u) (BX + (Bit16s) i->displ16u());
} }

View File

@ -1,5 +1,5 @@
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// $Id: resolve32.cc,v 1.11 2006-03-06 22:03:02 sshwarts Exp $ // $Id: resolve32.cc,v 1.12 2007-11-13 17:30:54 sshwarts Exp $
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// //
// Copyright (C) 2001 MandrakeSoft S.A. // Copyright (C) 2001 MandrakeSoft S.A.
@ -32,256 +32,47 @@
void BX_CPP_AttrRegparmN(1) void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve32Mod0Rm0(bxInstruction_c *i) BX_CPU_C::BxResolve32Mod0Rm(bxInstruction_c *i)
{ {
RMAddr(i) = EAX; RMAddr(i) = BX_READ_32BIT_REG(i->rm());
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::BxResolve32Mod0Base(bxInstruction_c *i)
{
RMAddr(i) = BX_READ_32BIT_REG(i->sibBase());
} }
void BX_CPP_AttrRegparmN(1) void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve32Mod0Rm1(bxInstruction_c *i) BX_CPU_C::BxResolve32Mod0Disp(bxInstruction_c *i)
{
RMAddr(i) = ECX;
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve32Mod0Rm2(bxInstruction_c *i)
{
RMAddr(i) = EDX;
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve32Mod0Rm3(bxInstruction_c *i)
{
RMAddr(i) = EBX;
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve32Mod0Rm5(bxInstruction_c *i)
{ {
RMAddr(i) = i->displ32u(); RMAddr(i) = i->displ32u();
} }
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve32Mod0Rm6(bxInstruction_c *i)
{
RMAddr(i) = ESI;
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve32Mod0Rm7(bxInstruction_c *i)
{
RMAddr(i) = EDI;
}
void BX_CPP_AttrRegparmN(1) void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve32Mod1or2Rm0(bxInstruction_c *i) BX_CPU_C::BxResolve32Mod0BaseIndex(bxInstruction_c *i)
{ {
RMAddr(i) = EAX + i->displ32u(); RMAddr(i) = BX_READ_32BIT_REG(i->sibBase()) + (BX_READ_32BIT_REG(i->sibIndex()) << i->sibScale());
} }
void BX_CPP_AttrRegparmN(1) void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve32Mod1or2Rm1(bxInstruction_c *i) BX_CPU_C::BxResolve32Mod0DispIndex(bxInstruction_c *i)
{ {
RMAddr(i) = ECX + i->displ32u(); RMAddr(i) = i->displ32u() + (BX_READ_32BIT_REG(i->sibIndex()) << i->sibScale());
} }
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve32Mod1or2Rm2(bxInstruction_c *i)
{
RMAddr(i) = EDX + i->displ32u();
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve32Mod1or2Rm3(bxInstruction_c *i)
{
RMAddr(i) = EBX + i->displ32u();
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve32Mod1or2Rm5(bxInstruction_c *i)
{
RMAddr(i) = EBP + i->displ32u();
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve32Mod1or2Rm6(bxInstruction_c *i)
{
RMAddr(i) = ESI + i->displ32u();
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve32Mod1or2Rm7(bxInstruction_c *i)
{
RMAddr(i) = EDI + i->displ32u();
}
void BX_CPP_AttrRegparmN(1) void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve32Mod0Base0(bxInstruction_c *i) BX_CPU_C::BxResolve32Mod1or2Rm(bxInstruction_c *i)
{ {
Bit32u scaled_index; RMAddr(i) = BX_READ_32BIT_REG(i->rm()) + i->displ32u();
if (i->sibIndex() != 4)
scaled_index = BX_READ_32BIT_REG(i->sibIndex()) << i->sibScale();
else
scaled_index = 0;
RMAddr(i) = EAX + scaled_index;
} }
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve32Mod0Base1(bxInstruction_c *i)
{
Bit32u scaled_index;
if (i->sibIndex() != 4)
scaled_index = BX_READ_32BIT_REG(i->sibIndex()) << i->sibScale();
else
scaled_index = 0;
RMAddr(i) = ECX + scaled_index;
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve32Mod0Base2(bxInstruction_c *i)
{
Bit32u scaled_index;
if (i->sibIndex() != 4)
scaled_index = BX_READ_32BIT_REG(i->sibIndex()) << i->sibScale();
else
scaled_index = 0;
RMAddr(i) = EDX + scaled_index;
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve32Mod0Base3(bxInstruction_c *i)
{
Bit32u scaled_index;
if (i->sibIndex() != 4)
scaled_index = BX_READ_32BIT_REG(i->sibIndex()) << i->sibScale();
else
scaled_index = 0;
RMAddr(i) = EBX + scaled_index;
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve32Mod0Base4(bxInstruction_c *i)
{
Bit32u scaled_index;
if (i->sibIndex() != 4)
scaled_index = BX_READ_32BIT_REG(i->sibIndex()) << i->sibScale();
else
scaled_index = 0;
RMAddr(i) = ESP + scaled_index;
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve32Mod0Base5(bxInstruction_c *i)
{
Bit32u scaled_index;
if (i->sibIndex() != 4)
scaled_index = BX_READ_32BIT_REG(i->sibIndex()) << i->sibScale();
else
scaled_index = 0;
RMAddr(i) = i->displ32u() + scaled_index;
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve32Mod0Base6(bxInstruction_c *i)
{
Bit32u scaled_index;
if (i->sibIndex() != 4)
scaled_index = BX_READ_32BIT_REG(i->sibIndex()) << i->sibScale();
else
scaled_index = 0;
RMAddr(i) = ESI + scaled_index;
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve32Mod0Base7(bxInstruction_c *i)
{
Bit32u scaled_index;
if (i->sibIndex() != 4)
scaled_index = BX_READ_32BIT_REG(i->sibIndex()) << i->sibScale();
else
scaled_index = 0;
RMAddr(i) = EDI + scaled_index;
}
void BX_CPP_AttrRegparmN(1) void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve32Mod1or2Base0(bxInstruction_c *i) BX_CPU_C::BxResolve32Mod1or2Base(bxInstruction_c *i)
{ {
Bit32u scaled_index; RMAddr(i) = BX_READ_32BIT_REG(i->sibBase()) + i->displ32u();
if (i->sibIndex() != 4)
scaled_index = BX_READ_32BIT_REG(i->sibIndex()) << i->sibScale();
else
scaled_index = 0;
RMAddr(i) = EAX + scaled_index + i->displ32u();
} }
void BX_CPP_AttrRegparmN(1) void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve32Mod1or2Base1(bxInstruction_c *i) BX_CPU_C::BxResolve32Mod1or2BaseIndex(bxInstruction_c *i)
{ {
Bit32u scaled_index; RMAddr(i) = BX_READ_32BIT_REG(i->sibBase()) + (BX_READ_32BIT_REG(i->sibIndex()) << i->sibScale()) + i->displ32u();
if (i->sibIndex() != 4)
scaled_index = BX_READ_32BIT_REG(i->sibIndex()) << i->sibScale();
else
scaled_index = 0;
RMAddr(i) = ECX + scaled_index + i->displ32u();
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve32Mod1or2Base2(bxInstruction_c *i)
{
Bit32u scaled_index;
if (i->sibIndex() != 4)
scaled_index = BX_READ_32BIT_REG(i->sibIndex()) << i->sibScale();
else
scaled_index = 0;
RMAddr(i) = EDX + scaled_index + i->displ32u();
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve32Mod1or2Base3(bxInstruction_c *i)
{
Bit32u scaled_index;
if (i->sibIndex() != 4)
scaled_index = BX_READ_32BIT_REG(i->sibIndex()) << i->sibScale();
else
scaled_index = 0;
RMAddr(i) = EBX + scaled_index + i->displ32u();
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve32Mod1or2Base4(bxInstruction_c *i)
{
Bit32u scaled_index;
if (i->sibIndex() != 4)
scaled_index = BX_READ_32BIT_REG(i->sibIndex()) << i->sibScale();
else
scaled_index = 0;
RMAddr(i) = ESP + scaled_index + i->displ32u();
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve32Mod1or2Base5(bxInstruction_c *i)
{
Bit32u scaled_index;
if (i->sibIndex() != 4)
scaled_index = BX_READ_32BIT_REG(i->sibIndex()) << i->sibScale();
else
scaled_index = 0;
RMAddr(i) = EBP + scaled_index + i->displ32u();
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve32Mod1or2Base6(bxInstruction_c *i)
{
Bit32u scaled_index;
if (i->sibIndex() != 4)
scaled_index = BX_READ_32BIT_REG(i->sibIndex()) << i->sibScale();
else
scaled_index = 0;
RMAddr(i) = ESI + scaled_index + i->displ32u();
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve32Mod1or2Base7(bxInstruction_c *i)
{
Bit32u scaled_index;
if (i->sibIndex() != 4)
scaled_index = BX_READ_32BIT_REG(i->sibIndex()) << i->sibScale();
else
scaled_index = 0;
RMAddr(i) = EDI + scaled_index + i->displ32u();
} }

View File

@ -1,5 +1,5 @@
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// $Id: resolve64.cc,v 1.10 2007-04-09 21:15:00 sshwarts Exp $ // $Id: resolve64.cc,v 1.11 2007-11-13 17:30:54 sshwarts Exp $
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// //
// Copyright (C) 2001 MandrakeSoft S.A. // Copyright (C) 2001 MandrakeSoft S.A.
@ -34,401 +34,62 @@
#if BX_SUPPORT_X86_64 #if BX_SUPPORT_X86_64
void BX_CPP_AttrRegparmN(1) void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod0Rm0(bxInstruction_c *i) BX_CPU_C::BxResolve32Mod0Rip(bxInstruction_c *i)
{ {
RMAddr(i) = RAX; // RIP hasn't been bumped yet when this is called. must choose the saved value.
RMAddr(i) = (Bit32u) (BX_CPU_THIS_PTR prev_eip + i->ilen() + (Bit32s)i->displ32u());
} }
void BX_CPP_AttrRegparmN(1) void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod0Rm1(bxInstruction_c *i) BX_CPU_C::BxResolve64Mod0Rip(bxInstruction_c *i)
{
RMAddr(i) = RCX;
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod0Rm2(bxInstruction_c *i)
{
RMAddr(i) = RDX;
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod0Rm3(bxInstruction_c *i)
{
RMAddr(i) = RBX;
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod0Rip(bxInstruction_c *i)
{ {
// RIP hasn't been bumped yet when this is called. must choose the saved value. // RIP hasn't been bumped yet when this is called. must choose the saved value.
RMAddr(i) = BX_CPU_THIS_PTR prev_eip + i->ilen() + (Bit32s)i->displ32u(); RMAddr(i) = BX_CPU_THIS_PTR prev_eip + i->ilen() + (Bit32s)i->displ32u();
} }
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod0Rm6(bxInstruction_c *i)
{
RMAddr(i) = RSI;
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod0Rm7(bxInstruction_c *i)
{
RMAddr(i) = RDI;
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod0Rm8(bxInstruction_c *i)
{
RMAddr(i) = R8;
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod0Rm9(bxInstruction_c *i)
{
RMAddr(i) = R9;
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod0Rm10(bxInstruction_c *i)
{
RMAddr(i) = R10;
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod0Rm11(bxInstruction_c *i)
{
RMAddr(i) = R11;
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod0Rm14(bxInstruction_c *i)
{
RMAddr(i) = R14;
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod0Rm15(bxInstruction_c *i)
{
RMAddr(i) = R15;
}
void BX_CPP_AttrRegparmN(1) void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod1or2Rm0(bxInstruction_c *i) BX_CPU_C::BxResolve64Mod0Rm(bxInstruction_c *i)
{ {
RMAddr(i) = RAX + (Bit32s) i->displ32u(); RMAddr(i) = BX_READ_64BIT_REG(i->rm());
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod1or2Rm1(bxInstruction_c *i)
{
RMAddr(i) = RCX + (Bit32s) i->displ32u();
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod1or2Rm2(bxInstruction_c *i)
{
RMAddr(i) = RDX + (Bit32s) i->displ32u();
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod1or2Rm3(bxInstruction_c *i)
{
RMAddr(i) = RBX + (Bit32s) i->displ32u();
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod1or2Rm5(bxInstruction_c *i)
{
RMAddr(i) = RBP + (Bit32s) i->displ32u();
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod1or2Rm6(bxInstruction_c *i)
{
RMAddr(i) = RSI + (Bit32s) i->displ32u();
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod1or2Rm7(bxInstruction_c *i)
{
RMAddr(i) = RDI + (Bit32s) i->displ32u();
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod1or2Rm8(bxInstruction_c *i)
{
RMAddr(i) = R8 + (Bit32s) i->displ32u();
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod1or2Rm9(bxInstruction_c *i)
{
RMAddr(i) = R9 + (Bit32s) i->displ32u();
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod1or2Rm10(bxInstruction_c *i)
{
RMAddr(i) = R10 + (Bit32s) i->displ32u();
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod1or2Rm11(bxInstruction_c *i)
{
RMAddr(i) = R11 + (Bit32s) i->displ32u();
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod1or2Rm13(bxInstruction_c *i)
{
RMAddr(i) = R13 + (Bit32s) i->displ32u();
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod1or2Rm14(bxInstruction_c *i)
{
RMAddr(i) = R14 + (Bit32s) i->displ32u();
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod1or2Rm15(bxInstruction_c *i)
{
RMAddr(i) = R15 + (Bit32s) i->displ32u();
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod0Base0(bxInstruction_c *i)
{
if (i->sibIndex() != 4)
RMAddr(i) = RAX + (BX_READ_64BIT_REG(i->sibIndex()) << i->sibScale());
else
RMAddr(i) = RAX;
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod0Base1(bxInstruction_c *i)
{
if (i->sibIndex() != 4)
RMAddr(i) = RCX + (BX_READ_64BIT_REG(i->sibIndex()) << i->sibScale());
else
RMAddr(i) = RCX;
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod0Base2(bxInstruction_c *i)
{
if (i->sibIndex() != 4)
RMAddr(i) = RDX + (BX_READ_64BIT_REG(i->sibIndex()) << i->sibScale());
else
RMAddr(i) = RDX;
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod0Base3(bxInstruction_c *i)
{
if (i->sibIndex() != 4)
RMAddr(i) = RBX + (BX_READ_64BIT_REG(i->sibIndex()) << i->sibScale());
else
RMAddr(i) = RBX;
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod0Base4(bxInstruction_c *i)
{
if (i->sibIndex() != 4)
RMAddr(i) = RSP + (BX_READ_64BIT_REG(i->sibIndex()) << i->sibScale());
else
RMAddr(i) = RSP;
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod0Base5(bxInstruction_c *i)
{
if (i->sibIndex() != 4)
RMAddr(i) = (BX_READ_64BIT_REG(i->sibIndex()) << i->sibScale()) + (Bit32s) i->displ32u();
else
RMAddr(i) = (Bit32s) i->displ32u();
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod0Base6(bxInstruction_c *i)
{
if (i->sibIndex() != 4)
RMAddr(i) = RSI + (BX_READ_64BIT_REG(i->sibIndex()) << i->sibScale());
else
RMAddr(i) = RSI;
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod0Base7(bxInstruction_c *i)
{
if (i->sibIndex() != 4)
RMAddr(i) = RDI + (BX_READ_64BIT_REG(i->sibIndex()) << i->sibScale());
else
RMAddr(i) = RDI;
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod0Base8(bxInstruction_c *i)
{
if (i->sibIndex() != 4)
RMAddr(i) = R8 + (BX_READ_64BIT_REG(i->sibIndex()) << i->sibScale());
else
RMAddr(i) = R8;
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod0Base9(bxInstruction_c *i)
{
if (i->sibIndex() != 4)
RMAddr(i) = R9 + (BX_READ_64BIT_REG(i->sibIndex()) << i->sibScale());
else
RMAddr(i) = R9;
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod0Base10(bxInstruction_c *i)
{
if (i->sibIndex() != 4)
RMAddr(i) = R10 + (BX_READ_64BIT_REG(i->sibIndex()) << i->sibScale());
else
RMAddr(i) = R10;
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod0Base11(bxInstruction_c *i)
{
if (i->sibIndex() != 4)
RMAddr(i) = R11 + (BX_READ_64BIT_REG(i->sibIndex()) << i->sibScale());
else
RMAddr(i) = R11;
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod0Base12(bxInstruction_c *i)
{
if (i->sibIndex() != 4)
RMAddr(i) = R12 + (BX_READ_64BIT_REG(i->sibIndex()) << i->sibScale());
else
RMAddr(i) = R12;
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod0Base13(bxInstruction_c *i)
{
if (i->sibIndex() != 4)
RMAddr(i) = R13 + (BX_READ_64BIT_REG(i->sibIndex()) << i->sibScale());
else
RMAddr(i) = R13;
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod0Base14(bxInstruction_c *i)
{
if (i->sibIndex() != 4)
RMAddr(i) = R14 + (BX_READ_64BIT_REG(i->sibIndex()) << i->sibScale());
else
RMAddr(i) = R14;
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod0Base15(bxInstruction_c *i)
{
if (i->sibIndex() != 4)
RMAddr(i) = R15 + (BX_READ_64BIT_REG(i->sibIndex()) << i->sibScale());
else
RMAddr(i) = R15;
} }
void BX_CPP_AttrRegparmN(1) void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod1or2Base0(bxInstruction_c *i) BX_CPU_C::BxResolve64Mod0Base(bxInstruction_c *i)
{ {
if (i->sibIndex() != 4) RMAddr(i) = BX_READ_64BIT_REG(i->sibBase());
RMAddr(i) = RAX + (BX_READ_64BIT_REG(i->sibIndex()) << i->sibScale()) + (Bit32s) i->displ32u();
else
RMAddr(i) = RAX + (Bit32s) i->displ32u();
} }
void BX_CPP_AttrRegparmN(1) void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod1or2Base1(bxInstruction_c *i) BX_CPU_C::BxResolve64Mod0Disp(bxInstruction_c *i)
{ {
if (i->sibIndex() != 4) RMAddr(i) = (Bit32s) i->displ32u();
RMAddr(i) = RCX + (BX_READ_64BIT_REG(i->sibIndex()) << i->sibScale()) + (Bit32s) i->displ32u(); }
else
RMAddr(i) = RCX + (Bit32s) i->displ32u(); void BX_CPP_AttrRegparmN(1)
BX_CPU_C::BxResolve64Mod0BaseIndex(bxInstruction_c *i)
{
RMAddr(i) = BX_READ_64BIT_REG(i->sibBase()) + (BX_READ_64BIT_REG(i->sibIndex()) << i->sibScale());
} }
void BX_CPP_AttrRegparmN(1) void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod1or2Base2(bxInstruction_c *i) BX_CPU_C::BxResolve64Mod0DispIndex(bxInstruction_c *i)
{ {
if (i->sibIndex() != 4) RMAddr(i) = (BX_READ_64BIT_REG(i->sibIndex()) << i->sibScale()) + (Bit32s) i->displ32u();
RMAddr(i) = RDX + (BX_READ_64BIT_REG(i->sibIndex()) << i->sibScale()) + (Bit32s) i->displ32u();
else
RMAddr(i) = RDX + (Bit32s) i->displ32u();
} }
void BX_CPP_AttrRegparmN(1) void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod1or2Base3(bxInstruction_c *i) BX_CPU_C::BxResolve64Mod1or2Rm(bxInstruction_c *i)
{ {
if (i->sibIndex() != 4) RMAddr(i) = BX_READ_64BIT_REG(i->rm()) + (Bit32s) i->displ32u();
RMAddr(i) = RBX + (BX_READ_64BIT_REG(i->sibIndex()) << i->sibScale()) + (Bit32s) i->displ32u();
else
RMAddr(i) = RBX + (Bit32s) i->displ32u();
} }
void BX_CPP_AttrRegparmN(1) void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod1or2Base4(bxInstruction_c *i) BX_CPU_C::BxResolve64Mod1or2Base(bxInstruction_c *i)
{ {
if (i->sibIndex() != 4) RMAddr(i) = BX_READ_64BIT_REG(i->sibBase()) + (Bit32s) i->displ32u();
RMAddr(i) = RSP + (BX_READ_64BIT_REG(i->sibIndex()) << i->sibScale()) + (Bit32s) i->displ32u();
else
RMAddr(i) = RSP + (Bit32s) i->displ32u();
} }
void BX_CPP_AttrRegparmN(1) void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod1or2Base5(bxInstruction_c *i) BX_CPU_C::BxResolve64Mod1or2BaseIndex(bxInstruction_c *i)
{ {
if (i->sibIndex() != 4) RMAddr(i) = BX_READ_64BIT_REG(i->sibBase()) + (BX_READ_64BIT_REG(i->sibIndex()) << i->sibScale()) + (Bit32s) i->displ32u();
RMAddr(i) = RBP + (BX_READ_64BIT_REG(i->sibIndex()) << i->sibScale()) + (Bit32s) i->displ32u();
else
RMAddr(i) = RBP + (Bit32s) i->displ32u();
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod1or2Base6(bxInstruction_c *i)
{
if (i->sibIndex() != 4)
RMAddr(i) = RSI + (BX_READ_64BIT_REG(i->sibIndex()) << i->sibScale()) + (Bit32s) i->displ32u();
else
RMAddr(i) = RSI + (Bit32s) i->displ32u();
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod1or2Base7(bxInstruction_c *i)
{
if (i->sibIndex() != 4)
RMAddr(i) = RDI + (BX_READ_64BIT_REG(i->sibIndex()) << i->sibScale()) + (Bit32s) i->displ32u();
else
RMAddr(i) = RDI + (Bit32s) i->displ32u();
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod1or2Base8(bxInstruction_c *i)
{
if (i->sibIndex() != 4)
RMAddr(i) = R8 + (BX_READ_64BIT_REG(i->sibIndex()) << i->sibScale()) + (Bit32s) i->displ32u();
else
RMAddr(i) = R8 + (Bit32s) i->displ32u();
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod1or2Base9(bxInstruction_c *i)
{
if (i->sibIndex() != 4)
RMAddr(i) = R9 + (BX_READ_64BIT_REG(i->sibIndex()) << i->sibScale()) + (Bit32s) i->displ32u();
else
RMAddr(i) = R9 + (Bit32s) i->displ32u();
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod1or2Base10(bxInstruction_c *i)
{
if (i->sibIndex() != 4)
RMAddr(i) = R10 + (BX_READ_64BIT_REG(i->sibIndex()) << i->sibScale()) + (Bit32s) i->displ32u();
else
RMAddr(i) = R10 + (Bit32s) i->displ32u();
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod1or2Base11(bxInstruction_c *i)
{
if (i->sibIndex() != 4)
RMAddr(i) = R11 + (BX_READ_64BIT_REG(i->sibIndex()) << i->sibScale()) + (Bit32s) i->displ32u();
else
RMAddr(i) = R11 + (Bit32s) i->displ32u();
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod1or2Base12(bxInstruction_c *i)
{
if (i->sibIndex() != 4)
RMAddr(i) = R12 + (BX_READ_64BIT_REG(i->sibIndex()) << i->sibScale()) + (Bit32s) i->displ32u();
else
RMAddr(i) = R12 + (Bit32s) i->displ32u();
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod1or2Base13(bxInstruction_c *i)
{
if (i->sibIndex() != 4)
RMAddr(i) = R13 + (BX_READ_64BIT_REG(i->sibIndex()) << i->sibScale()) + (Bit32s) i->displ32u();
else
RMAddr(i) = R13 + (Bit32s) i->displ32u();
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod1or2Base14(bxInstruction_c *i)
{
if (i->sibIndex() != 4)
RMAddr(i) = R14 + (BX_READ_64BIT_REG(i->sibIndex()) << i->sibScale()) + (Bit32s) i->displ32u();
else
RMAddr(i) = R14 + (Bit32s) i->displ32u();
}
void BX_CPP_AttrRegparmN(1)
BX_CPU_C::Resolve64Mod1or2Base15(bxInstruction_c *i)
{
if (i->sibIndex() != 4)
RMAddr(i) = R15 + (BX_READ_64BIT_REG(i->sibIndex()) << i->sibScale()) + (Bit32s) i->displ32u();
else
RMAddr(i) = R15 + (Bit32s) i->displ32u();
} }
#endif /* if BX_SUPPORT_X86_64 */ #endif /* if BX_SUPPORT_X86_64 */