opps, forget a file
This commit is contained in:
parent
243cadb4cd
commit
7a28e26a98
|
@ -2444,11 +2444,58 @@ static int OP_CLZ(const u32 i)
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// MCR / MRC
|
// MCR / MRC
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
#define maskPrecalc \
|
|
||||||
{ \
|
// precalculate region masks/sets from cp15 register ----- JIT
|
||||||
X86CompilerFuncCall* ctxM = c.call((void*)maskPrecalc); \
|
// TODO: rewrite to asm
|
||||||
ctxM->setPrototype(ASMJIT_CALL_CONV, FuncBuilder0<Void>()); \
|
static void maskPrecalc(u32 _num)
|
||||||
|
{
|
||||||
|
#define precalc(num) { \
|
||||||
|
u32 mask = 0, set = 0xFFFFFFFF ; /* (x & 0) == 0xFF..FF is allways false (disabled) */ \
|
||||||
|
if (BIT_N(cp15.protectBaseSize[num],0)) /* if region is enabled */ \
|
||||||
|
{ /* reason for this define: naming includes var */ \
|
||||||
|
mask = CP15_MASKFROMREG(cp15.protectBaseSize[num]) ; \
|
||||||
|
set = CP15_SETFROMREG(cp15.protectBaseSize[num]) ; \
|
||||||
|
if (CP15_SIZEIDENTIFIER(cp15.protectBaseSize[num])==0x1F) \
|
||||||
|
{ /* for the 4GB region, u32 suffers wraparound */ \
|
||||||
|
mask = 0 ; set = 0 ; /* (x & 0) == 0 is allways true (enabled) */ \
|
||||||
|
} \
|
||||||
|
} \
|
||||||
|
cp15.setSingleRegionAccess(num, mask, set) ; \
|
||||||
}
|
}
|
||||||
|
switch(_num)
|
||||||
|
{
|
||||||
|
case 0: precalc(0); break;
|
||||||
|
case 1: precalc(1); break;
|
||||||
|
case 2: precalc(2); break;
|
||||||
|
case 3: precalc(3); break;
|
||||||
|
case 4: precalc(4); break;
|
||||||
|
case 5: precalc(5); break;
|
||||||
|
case 6: precalc(6); break;
|
||||||
|
case 7: precalc(7); break;
|
||||||
|
|
||||||
|
case 0xFF:
|
||||||
|
precalc(0);
|
||||||
|
precalc(1);
|
||||||
|
precalc(2);
|
||||||
|
precalc(3);
|
||||||
|
precalc(4);
|
||||||
|
precalc(5);
|
||||||
|
precalc(6);
|
||||||
|
precalc(7);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
#undef precalc
|
||||||
|
}
|
||||||
|
|
||||||
|
#define _maskPrecalc(num) \
|
||||||
|
{ \
|
||||||
|
GpVar _num = c.newGpVar(kX86VarTypeGpd); \
|
||||||
|
X86CompilerFuncCall* ctxM = c.call((uintptr_t)maskPrecalc); \
|
||||||
|
c.mov(_num, num); \
|
||||||
|
ctxM->setPrototype(ASMJIT_CALL_CONV, FuncBuilder1<Void, u32>()); \
|
||||||
|
ctxM->setArgument(0, _num); \
|
||||||
|
}
|
||||||
|
|
||||||
static int OP_MCR(const u32 i)
|
static int OP_MCR(const u32 i)
|
||||||
{
|
{
|
||||||
if (PROCNUM == ARMCPU_ARM7) return 0;
|
if (PROCNUM == ARMCPU_ARM7) return 0;
|
||||||
|
@ -2548,12 +2595,12 @@ static int OP_MCR(const u32 i)
|
||||||
case 2:
|
case 2:
|
||||||
//DaccessPerm = val;
|
//DaccessPerm = val;
|
||||||
c.mov(cp15_ptr(DaccessPerm), data);
|
c.mov(cp15_ptr(DaccessPerm), data);
|
||||||
maskPrecalc;
|
_maskPrecalc(0xFF);
|
||||||
break;
|
break;
|
||||||
case 3:
|
case 3:
|
||||||
//IaccessPerm = val;
|
//IaccessPerm = val;
|
||||||
c.mov(cp15_ptr(IaccessPerm), data);
|
c.mov(cp15_ptr(IaccessPerm), data);
|
||||||
maskPrecalc;
|
_maskPrecalc(0xFF);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
bUnknown = true;
|
bUnknown = true;
|
||||||
|
@ -2565,50 +2612,11 @@ static int OP_MCR(const u32 i)
|
||||||
case 6:
|
case 6:
|
||||||
if((opcode1==0) && (opcode2==0))
|
if((opcode1==0) && (opcode2==0))
|
||||||
{
|
{
|
||||||
switch(CRm)
|
if (CRm < 8)
|
||||||
{
|
{
|
||||||
case 0:
|
//protectBaseSize[CRm] = val;
|
||||||
//protectBaseSize0 = val;
|
c.mov(cp15_ptr(protectBaseSize[CRm]), data);
|
||||||
c.mov(cp15_ptr(protectBaseSize0), data);
|
_maskPrecalc(CRm);
|
||||||
maskPrecalc;
|
|
||||||
break;
|
|
||||||
case 1:
|
|
||||||
//protectBaseSize1 = val;
|
|
||||||
c.mov(cp15_ptr(protectBaseSize1), data);
|
|
||||||
maskPrecalc;
|
|
||||||
break;
|
|
||||||
case 2:
|
|
||||||
//protectBaseSize2 = val;
|
|
||||||
c.mov(cp15_ptr(protectBaseSize2), data);
|
|
||||||
maskPrecalc;
|
|
||||||
break;
|
|
||||||
case 3:
|
|
||||||
//protectBaseSize3 = val;
|
|
||||||
c.mov(cp15_ptr(protectBaseSize3), data);
|
|
||||||
maskPrecalc;
|
|
||||||
break;
|
|
||||||
case 4:
|
|
||||||
//protectBaseSize4 = val;
|
|
||||||
c.mov(cp15_ptr(protectBaseSize4), data);
|
|
||||||
maskPrecalc;
|
|
||||||
break;
|
|
||||||
case 5:
|
|
||||||
//protectBaseSize5 = val;
|
|
||||||
c.mov(cp15_ptr(protectBaseSize5), data);
|
|
||||||
maskPrecalc;
|
|
||||||
break;
|
|
||||||
case 6:
|
|
||||||
//protectBaseSize6 = val;
|
|
||||||
c.mov(cp15_ptr(protectBaseSize6), data);
|
|
||||||
maskPrecalc;
|
|
||||||
break;
|
|
||||||
case 7:
|
|
||||||
//protectBaseSize7 = val;
|
|
||||||
c.mov(cp15_ptr(protectBaseSize7), data);
|
|
||||||
maskPrecalc;
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
bUnknown = true;
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2810,45 +2818,12 @@ static int OP_MRC(const u32 i)
|
||||||
case 6:
|
case 6:
|
||||||
if((opcode1==0) && (opcode2==0))
|
if((opcode1==0) && (opcode2==0))
|
||||||
{
|
{
|
||||||
switch(CRm)
|
if (CRm < 8)
|
||||||
{
|
{
|
||||||
case 0:
|
// *R = protectBaseSize[CRm];
|
||||||
// *R = protectBaseSize0;
|
c.mov(data, cp15_ptr(protectBaseSize[CRm]));
|
||||||
c.mov(data, cp15_ptr(protectBaseSize0));
|
|
||||||
break;
|
|
||||||
case 1:
|
|
||||||
// *R = protectBaseSize1;
|
|
||||||
c.mov(data, cp15_ptr(protectBaseSize1));
|
|
||||||
break;
|
|
||||||
case 2:
|
|
||||||
// *R = protectBaseSize2;
|
|
||||||
c.mov(data, cp15_ptr(protectBaseSize2));
|
|
||||||
break;
|
|
||||||
case 3:
|
|
||||||
// *R = protectBaseSize3;
|
|
||||||
c.mov(data, cp15_ptr(protectBaseSize3));
|
|
||||||
break;
|
|
||||||
case 4:
|
|
||||||
// *R = protectBaseSize4;
|
|
||||||
c.mov(data, cp15_ptr(protectBaseSize4));
|
|
||||||
break;
|
|
||||||
case 5:
|
|
||||||
// *R = protectBaseSize5;
|
|
||||||
c.mov(data, cp15_ptr(protectBaseSize5));
|
|
||||||
break;
|
|
||||||
case 6:
|
|
||||||
// *R = protectBaseSize6;
|
|
||||||
c.mov(data, cp15_ptr(protectBaseSize6));
|
|
||||||
break;
|
|
||||||
case 7:
|
|
||||||
// *R = protectBaseSize7;
|
|
||||||
c.mov(data, cp15_ptr(protectBaseSize7));
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
bUnknown = true;
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
bUnknown = true;
|
bUnknown = true;
|
||||||
break;
|
break;
|
||||||
|
|
Loading…
Reference in New Issue