Minor JitCache cleanup.
This commit is contained in:
parent
86f2e1734a
commit
5847e26d34
|
@ -705,18 +705,18 @@ const u8* Jit64::DoJit(u32 em_address, PPCAnalyst::CodeBuffer *code_buf, JitBloc
|
||||||
// Remove the invalid instruction from the icache, forcing a recompile
|
// Remove the invalid instruction from the icache, forcing a recompile
|
||||||
#ifdef _M_IX86
|
#ifdef _M_IX86
|
||||||
if (js.compilerPC & JIT_ICACHE_VMEM_BIT)
|
if (js.compilerPC & JIT_ICACHE_VMEM_BIT)
|
||||||
MOV(32, M((jit->GetBlockCache()->GetICacheVMEM() + (js.compilerPC & JIT_ICACHE_MASK))), Imm32(JIT_ICACHE_INVALID_WORD));
|
MOV(32, M((jit->GetBlockCache()->iCacheVMEM + (js.compilerPC & JIT_ICACHE_MASK))), Imm32(JIT_ICACHE_INVALID_WORD));
|
||||||
else if (js.compilerPC & JIT_ICACHE_EXRAM_BIT)
|
else if (js.compilerPC & JIT_ICACHE_EXRAM_BIT)
|
||||||
MOV(32, M((jit->GetBlockCache()->GetICacheEx() + (js.compilerPC & JIT_ICACHEEX_MASK))), Imm32(JIT_ICACHE_INVALID_WORD));
|
MOV(32, M((jit->GetBlockCache()->iCacheEx + (js.compilerPC & JIT_ICACHEEX_MASK))), Imm32(JIT_ICACHE_INVALID_WORD));
|
||||||
else
|
else
|
||||||
MOV(32, M((jit->GetBlockCache()->GetICache() + (js.compilerPC & JIT_ICACHE_MASK))), Imm32(JIT_ICACHE_INVALID_WORD));
|
MOV(32, M((jit->GetBlockCache()->iCache + (js.compilerPC & JIT_ICACHE_MASK))), Imm32(JIT_ICACHE_INVALID_WORD));
|
||||||
#else
|
#else
|
||||||
if (js.compilerPC & JIT_ICACHE_VMEM_BIT)
|
if (js.compilerPC & JIT_ICACHE_VMEM_BIT)
|
||||||
MOV(64, R(RAX), ImmPtr(jit->GetBlockCache()->GetICacheVMEM() + (js.compilerPC & JIT_ICACHE_MASK)));
|
MOV(64, R(RAX), ImmPtr(jit->GetBlockCache()->iCacheVMEM + (js.compilerPC & JIT_ICACHE_MASK)));
|
||||||
else if (js.compilerPC & JIT_ICACHE_EXRAM_BIT)
|
else if (js.compilerPC & JIT_ICACHE_EXRAM_BIT)
|
||||||
MOV(64, R(RAX), ImmPtr(jit->GetBlockCache()->GetICacheEx() + (js.compilerPC & JIT_ICACHEEX_MASK)));
|
MOV(64, R(RAX), ImmPtr(jit->GetBlockCache()->iCacheEx + (js.compilerPC & JIT_ICACHEEX_MASK)));
|
||||||
else
|
else
|
||||||
MOV(64, R(RAX), ImmPtr(jit->GetBlockCache()->GetICache() + (js.compilerPC & JIT_ICACHE_MASK)));
|
MOV(64, R(RAX), ImmPtr(jit->GetBlockCache()->iCache + (js.compilerPC & JIT_ICACHE_MASK)));
|
||||||
MOV(32,MatR(RAX),Imm32(JIT_ICACHE_INVALID_WORD));
|
MOV(32,MatR(RAX),Imm32(JIT_ICACHE_INVALID_WORD));
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
|
@ -100,9 +100,9 @@ void Jit64AsmRoutineManager::Generate()
|
||||||
}
|
}
|
||||||
AND(32, R(EAX), Imm32(JIT_ICACHE_MASK));
|
AND(32, R(EAX), Imm32(JIT_ICACHE_MASK));
|
||||||
#ifdef _M_IX86
|
#ifdef _M_IX86
|
||||||
MOV(32, R(EAX), MDisp(EAX, (u32)jit->GetBlockCache()->GetICache()));
|
MOV(32, R(EAX), MDisp(EAX, (u32)jit->GetBlockCache()->iCache));
|
||||||
#else
|
#else
|
||||||
MOV(64, R(RSI), Imm64((u64)jit->GetBlockCache()->GetICache()));
|
MOV(64, R(RSI), Imm64((u64)jit->GetBlockCache()->iCache));
|
||||||
MOV(32, R(EAX), MComplex(RSI, EAX, SCALE_1, 0));
|
MOV(32, R(EAX), MComplex(RSI, EAX, SCALE_1, 0));
|
||||||
#endif
|
#endif
|
||||||
if (Core::g_CoreStartupParameter.bWii || Core::g_CoreStartupParameter.bMMU || Core::g_CoreStartupParameter.bTLBHack)
|
if (Core::g_CoreStartupParameter.bWii || Core::g_CoreStartupParameter.bMMU || Core::g_CoreStartupParameter.bTLBHack)
|
||||||
|
@ -116,9 +116,9 @@ void Jit64AsmRoutineManager::Generate()
|
||||||
FixupBranch no_vmem = J_CC(CC_Z);
|
FixupBranch no_vmem = J_CC(CC_Z);
|
||||||
AND(32, R(EAX), Imm32(JIT_ICACHE_MASK));
|
AND(32, R(EAX), Imm32(JIT_ICACHE_MASK));
|
||||||
#ifdef _M_IX86
|
#ifdef _M_IX86
|
||||||
MOV(32, R(EAX), MDisp(EAX, (u32)jit->GetBlockCache()->GetICacheVMEM()));
|
MOV(32, R(EAX), MDisp(EAX, (u32)jit->GetBlockCache()->iCacheVMEM));
|
||||||
#else
|
#else
|
||||||
MOV(64, R(RSI), Imm64((u64)jit->GetBlockCache()->GetICacheVMEM()));
|
MOV(64, R(RSI), Imm64((u64)jit->GetBlockCache()->iCacheVMEM));
|
||||||
MOV(32, R(EAX), MComplex(RSI, EAX, SCALE_1, 0));
|
MOV(32, R(EAX), MComplex(RSI, EAX, SCALE_1, 0));
|
||||||
#endif
|
#endif
|
||||||
if (Core::g_CoreStartupParameter.bWii) exit_vmem = J();
|
if (Core::g_CoreStartupParameter.bWii) exit_vmem = J();
|
||||||
|
@ -130,9 +130,9 @@ void Jit64AsmRoutineManager::Generate()
|
||||||
FixupBranch no_exram = J_CC(CC_Z);
|
FixupBranch no_exram = J_CC(CC_Z);
|
||||||
AND(32, R(EAX), Imm32(JIT_ICACHEEX_MASK));
|
AND(32, R(EAX), Imm32(JIT_ICACHEEX_MASK));
|
||||||
#ifdef _M_IX86
|
#ifdef _M_IX86
|
||||||
MOV(32, R(EAX), MDisp(EAX, (u32)jit->GetBlockCache()->GetICacheEx()));
|
MOV(32, R(EAX), MDisp(EAX, (u32)jit->GetBlockCache()->iCacheEx));
|
||||||
#else
|
#else
|
||||||
MOV(64, R(RSI), Imm64((u64)jit->GetBlockCache()->GetICacheEx()));
|
MOV(64, R(RSI), Imm64((u64)jit->GetBlockCache()->iCacheEx));
|
||||||
MOV(32, R(EAX), MComplex(RSI, EAX, SCALE_1, 0));
|
MOV(32, R(EAX), MComplex(RSI, EAX, SCALE_1, 0));
|
||||||
#endif
|
#endif
|
||||||
SetJumpTarget(no_exram);
|
SetJumpTarget(no_exram);
|
||||||
|
|
|
@ -1765,19 +1765,19 @@ static void DoWriteCode(IRBuilder* ibuild, JitIL* Jit) {
|
||||||
// Remove the invalid instruction from the icache, forcing a recompile
|
// Remove the invalid instruction from the icache, forcing a recompile
|
||||||
#ifdef _M_IX86
|
#ifdef _M_IX86
|
||||||
if (InstLoc & JIT_ICACHE_VMEM_BIT)
|
if (InstLoc & JIT_ICACHE_VMEM_BIT)
|
||||||
Jit->MOV(32, M((jit->GetBlockCache()->GetICacheVMEM() + (InstLoc & JIT_ICACHE_MASK))), Imm32(JIT_ICACHE_INVALID_WORD));
|
Jit->MOV(32, M((jit->GetBlockCache()->iCacheVMEM + (InstLoc & JIT_ICACHE_MASK))), Imm32(JIT_ICACHE_INVALID_WORD));
|
||||||
else if (InstLoc & JIT_ICACHE_EXRAM_BIT)
|
else if (InstLoc & JIT_ICACHE_EXRAM_BIT)
|
||||||
Jit->MOV(32, M((jit->GetBlockCache()->GetICacheEx() + (InstLoc & JIT_ICACHEEX_MASK))), Imm32(JIT_ICACHE_INVALID_WORD));
|
Jit->MOV(32, M((jit->GetBlockCache()->iCacheEx + (InstLoc & JIT_ICACHEEX_MASK))), Imm32(JIT_ICACHE_INVALID_WORD));
|
||||||
else
|
else
|
||||||
Jit->MOV(32, M((jit->GetBlockCache()->GetICache() + (InstLoc & JIT_ICACHE_MASK))), Imm32(JIT_ICACHE_INVALID_WORD));
|
Jit->MOV(32, M((jit->GetBlockCache()->iCache + (InstLoc & JIT_ICACHE_MASK))), Imm32(JIT_ICACHE_INVALID_WORD));
|
||||||
|
|
||||||
#else
|
#else
|
||||||
if (InstLoc & JIT_ICACHE_VMEM_BIT)
|
if (InstLoc & JIT_ICACHE_VMEM_BIT)
|
||||||
Jit->MOV(64, R(RAX), ImmPtr(jit->GetBlockCache()->GetICacheVMEM() + (InstLoc & JIT_ICACHE_MASK)));
|
Jit->MOV(64, R(RAX), ImmPtr(jit->GetBlockCache()->iCacheVMEM + (InstLoc & JIT_ICACHE_MASK)));
|
||||||
else if (InstLoc & JIT_ICACHE_EXRAM_BIT)
|
else if (InstLoc & JIT_ICACHE_EXRAM_BIT)
|
||||||
Jit->MOV(64, R(RAX), ImmPtr(jit->GetBlockCache()->GetICacheEx() + (InstLoc & JIT_ICACHEEX_MASK)));
|
Jit->MOV(64, R(RAX), ImmPtr(jit->GetBlockCache()->iCacheEx + (InstLoc & JIT_ICACHEEX_MASK)));
|
||||||
else
|
else
|
||||||
Jit->MOV(64, R(RAX), ImmPtr(jit->GetBlockCache()->GetICache() + (InstLoc & JIT_ICACHE_MASK)));
|
Jit->MOV(64, R(RAX), ImmPtr(jit->GetBlockCache()->iCache + (InstLoc & JIT_ICACHE_MASK)));
|
||||||
Jit->MOV(32, MatR(RAX), Imm32(JIT_ICACHE_INVALID_WORD));
|
Jit->MOV(32, MatR(RAX), Imm32(JIT_ICACHE_INVALID_WORD));
|
||||||
#endif
|
#endif
|
||||||
Jit->WriteExceptionExit();
|
Jit->WriteExceptionExit();
|
||||||
|
|
|
@ -101,9 +101,9 @@ void JitILAsmRoutineManager::Generate()
|
||||||
}
|
}
|
||||||
AND(32, R(EAX), Imm32(JIT_ICACHE_MASK));
|
AND(32, R(EAX), Imm32(JIT_ICACHE_MASK));
|
||||||
#ifdef _M_IX86
|
#ifdef _M_IX86
|
||||||
MOV(32, R(EAX), MDisp(EAX, (u32)jit->GetBlockCache()->GetICache()));
|
MOV(32, R(EAX), MDisp(EAX, (u32)jit->GetBlockCache()->iCache));
|
||||||
#else
|
#else
|
||||||
MOV(64, R(RSI), Imm64((u64)jit->GetBlockCache()->GetICache()));
|
MOV(64, R(RSI), Imm64((u64)jit->GetBlockCache()->iCache));
|
||||||
MOV(32, R(EAX), MComplex(RSI, EAX, SCALE_1, 0));
|
MOV(32, R(EAX), MComplex(RSI, EAX, SCALE_1, 0));
|
||||||
#endif
|
#endif
|
||||||
if (Core::g_CoreStartupParameter.bWii || Core::g_CoreStartupParameter.bMMU || Core::g_CoreStartupParameter.bTLBHack)
|
if (Core::g_CoreStartupParameter.bWii || Core::g_CoreStartupParameter.bMMU || Core::g_CoreStartupParameter.bTLBHack)
|
||||||
|
@ -117,9 +117,9 @@ void JitILAsmRoutineManager::Generate()
|
||||||
FixupBranch no_vmem = J_CC(CC_Z);
|
FixupBranch no_vmem = J_CC(CC_Z);
|
||||||
AND(32, R(EAX), Imm32(JIT_ICACHE_MASK));
|
AND(32, R(EAX), Imm32(JIT_ICACHE_MASK));
|
||||||
#ifdef _M_IX86
|
#ifdef _M_IX86
|
||||||
MOV(32, R(EAX), MDisp(EAX, (u32)jit->GetBlockCache()->GetICacheVMEM()));
|
MOV(32, R(EAX), MDisp(EAX, (u32)jit->GetBlockCache()->iCacheVMEM));
|
||||||
#else
|
#else
|
||||||
MOV(64, R(RSI), Imm64((u64)jit->GetBlockCache()->GetICacheVMEM()));
|
MOV(64, R(RSI), Imm64((u64)jit->GetBlockCache()->iCacheVMEM));
|
||||||
MOV(32, R(EAX), MComplex(RSI, EAX, SCALE_1, 0));
|
MOV(32, R(EAX), MComplex(RSI, EAX, SCALE_1, 0));
|
||||||
#endif
|
#endif
|
||||||
if (Core::g_CoreStartupParameter.bWii) exit_vmem = J();
|
if (Core::g_CoreStartupParameter.bWii) exit_vmem = J();
|
||||||
|
@ -131,9 +131,9 @@ void JitILAsmRoutineManager::Generate()
|
||||||
FixupBranch no_exram = J_CC(CC_Z);
|
FixupBranch no_exram = J_CC(CC_Z);
|
||||||
AND(32, R(EAX), Imm32(JIT_ICACHEEX_MASK));
|
AND(32, R(EAX), Imm32(JIT_ICACHEEX_MASK));
|
||||||
#ifdef _M_IX86
|
#ifdef _M_IX86
|
||||||
MOV(32, R(EAX), MDisp(EAX, (u32)jit->GetBlockCache()->GetICacheEx()));
|
MOV(32, R(EAX), MDisp(EAX, (u32)jit->GetBlockCache()->iCacheEx));
|
||||||
#else
|
#else
|
||||||
MOV(64, R(RSI), Imm64((u64)jit->GetBlockCache()->GetICacheEx()));
|
MOV(64, R(RSI), Imm64((u64)jit->GetBlockCache()->iCacheEx));
|
||||||
MOV(32, R(EAX), MComplex(RSI, EAX, SCALE_1, 0));
|
MOV(32, R(EAX), MComplex(RSI, EAX, SCALE_1, 0));
|
||||||
#endif
|
#endif
|
||||||
SetJumpTarget(no_exram);
|
SetJumpTarget(no_exram);
|
||||||
|
|
|
@ -131,7 +131,7 @@ void JitArmAsmRoutineManager::Generate()
|
||||||
Operand2 iCacheMask = Operand2(0xE, 2); // JIT_ICACHE_MASK
|
Operand2 iCacheMask = Operand2(0xE, 2); // JIT_ICACHE_MASK
|
||||||
BIC(R12, R12, iCacheMask); // R12 contains PC & JIT_ICACHE_MASK here.
|
BIC(R12, R12, iCacheMask); // R12 contains PC & JIT_ICACHE_MASK here.
|
||||||
|
|
||||||
MOVI2R(R14, (u32)jit->GetBlockCache()->GetICache());
|
MOVI2R(R14, (u32)jit->GetBlockCache()->iCache);
|
||||||
|
|
||||||
LDR(R12, R14, R12); // R12 contains iCache[PC & JIT_ICACHE_MASK] here
|
LDR(R12, R14, R12); // R12 contains iCache[PC & JIT_ICACHE_MASK] here
|
||||||
// R12 Confirmed this is the correct iCache Location loaded.
|
// R12 Confirmed this is the correct iCache Location loaded.
|
||||||
|
|
|
@ -60,8 +60,6 @@ bool JitBlock::ContainsAddress(u32 em_address)
|
||||||
|
|
||||||
void JitBaseBlockCache::Init()
|
void JitBaseBlockCache::Init()
|
||||||
{
|
{
|
||||||
MAX_NUM_BLOCKS = 65536*2;
|
|
||||||
|
|
||||||
#if defined USE_OPROFILE && USE_OPROFILE
|
#if defined USE_OPROFILE && USE_OPROFILE
|
||||||
agent = op_open_agent();
|
agent = op_open_agent();
|
||||||
#endif
|
#endif
|
||||||
|
@ -249,21 +247,6 @@ bool JitBlock::ContainsAddress(u32 em_address)
|
||||||
return blockCodePointers;
|
return blockCodePointers;
|
||||||
}
|
}
|
||||||
|
|
||||||
u8* JitBaseBlockCache::GetICache()
|
|
||||||
{
|
|
||||||
return iCache;
|
|
||||||
}
|
|
||||||
|
|
||||||
u8* JitBaseBlockCache::GetICacheEx()
|
|
||||||
{
|
|
||||||
return iCacheEx;
|
|
||||||
}
|
|
||||||
|
|
||||||
u8* JitBaseBlockCache::GetICacheVMEM()
|
|
||||||
{
|
|
||||||
return iCacheVMEM;
|
|
||||||
}
|
|
||||||
|
|
||||||
int JitBaseBlockCache::GetBlockNumberFromStartAddress(u32 addr)
|
int JitBaseBlockCache::GetBlockNumberFromStartAddress(u32 addr)
|
||||||
{
|
{
|
||||||
if (!blocks)
|
if (!blocks)
|
||||||
|
|
|
@ -73,10 +73,10 @@ class JitBaseBlockCache
|
||||||
std::multimap<u32, int> links_to;
|
std::multimap<u32, int> links_to;
|
||||||
std::map<std::pair<u32,u32>, u32> block_map; // (end_addr, start_addr) -> number
|
std::map<std::pair<u32,u32>, u32> block_map; // (end_addr, start_addr) -> number
|
||||||
std::bitset<0x20000000 / 32> valid_block;
|
std::bitset<0x20000000 / 32> valid_block;
|
||||||
u8 *iCache;
|
enum
|
||||||
u8 *iCacheEx;
|
{
|
||||||
u8 *iCacheVMEM;
|
MAX_NUM_BLOCKS = 65536*2
|
||||||
int MAX_NUM_BLOCKS;
|
};
|
||||||
|
|
||||||
bool RangeIntersect(int s1, int e1, int s2, int e2) const;
|
bool RangeIntersect(int s1, int e1, int s2, int e2) const;
|
||||||
void LinkBlockExits(int i);
|
void LinkBlockExits(int i);
|
||||||
|
@ -90,8 +90,7 @@ class JitBaseBlockCache
|
||||||
public:
|
public:
|
||||||
JitBaseBlockCache() :
|
JitBaseBlockCache() :
|
||||||
blockCodePointers(0), blocks(0), num_blocks(0),
|
blockCodePointers(0), blocks(0), num_blocks(0),
|
||||||
iCache(0), iCacheEx(0), iCacheVMEM(0),
|
iCache(0), iCacheEx(0), iCacheVMEM(0) {}
|
||||||
MAX_NUM_BLOCKS(0) { }
|
|
||||||
int AllocateBlock(u32 em_address);
|
int AllocateBlock(u32 em_address);
|
||||||
void FinalizeBlock(int block_num, bool block_link, const u8 *code_ptr);
|
void FinalizeBlock(int block_num, bool block_link, const u8 *code_ptr);
|
||||||
|
|
||||||
|
@ -107,9 +106,9 @@ public:
|
||||||
JitBlock *GetBlock(int block_num);
|
JitBlock *GetBlock(int block_num);
|
||||||
int GetNumBlocks() const;
|
int GetNumBlocks() const;
|
||||||
const u8 **GetCodePointers();
|
const u8 **GetCodePointers();
|
||||||
u8 *GetICache();
|
u8 *iCache;
|
||||||
u8 *GetICacheEx();
|
u8 *iCacheEx;
|
||||||
u8 *GetICacheVMEM();
|
u8 *iCacheVMEM;
|
||||||
|
|
||||||
// Fast way to get a block. Only works on the first ppc instruction of a block.
|
// Fast way to get a block. Only works on the first ppc instruction of a block.
|
||||||
int GetBlockNumberFromStartAddress(u32 em_address);
|
int GetBlockNumberFromStartAddress(u32 em_address);
|
||||||
|
|
|
@ -217,17 +217,17 @@ namespace JitInterface
|
||||||
u32 addr;
|
u32 addr;
|
||||||
if (_Address & JIT_ICACHE_VMEM_BIT)
|
if (_Address & JIT_ICACHE_VMEM_BIT)
|
||||||
{
|
{
|
||||||
iCache = jit->GetBlockCache()->GetICacheVMEM();
|
iCache = jit->GetBlockCache()->iCacheVMEM;
|
||||||
addr = _Address & JIT_ICACHE_MASK;
|
addr = _Address & JIT_ICACHE_MASK;
|
||||||
}
|
}
|
||||||
else if (_Address & JIT_ICACHE_EXRAM_BIT)
|
else if (_Address & JIT_ICACHE_EXRAM_BIT)
|
||||||
{
|
{
|
||||||
iCache = jit->GetBlockCache()->GetICacheEx();
|
iCache = jit->GetBlockCache()->iCacheEx;
|
||||||
addr = _Address & JIT_ICACHEEX_MASK;
|
addr = _Address & JIT_ICACHEEX_MASK;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
iCache = jit->GetBlockCache()->GetICache();
|
iCache = jit->GetBlockCache()->iCache;
|
||||||
addr = _Address & JIT_ICACHE_MASK;
|
addr = _Address & JIT_ICACHE_MASK;
|
||||||
}
|
}
|
||||||
u32 inst = *(u32*)(iCache + addr);
|
u32 inst = *(u32*)(iCache + addr);
|
||||||
|
@ -283,17 +283,17 @@ namespace JitInterface
|
||||||
u32 addr;
|
u32 addr;
|
||||||
if (_Address & JIT_ICACHE_VMEM_BIT)
|
if (_Address & JIT_ICACHE_VMEM_BIT)
|
||||||
{
|
{
|
||||||
iCache = jit->GetBlockCache()->GetICacheVMEM();
|
iCache = jit->GetBlockCache()->iCacheVMEM;
|
||||||
addr = _Address & JIT_ICACHE_MASK;
|
addr = _Address & JIT_ICACHE_MASK;
|
||||||
}
|
}
|
||||||
else if (_Address & JIT_ICACHE_EXRAM_BIT)
|
else if (_Address & JIT_ICACHE_EXRAM_BIT)
|
||||||
{
|
{
|
||||||
iCache = jit->GetBlockCache()->GetICacheEx();
|
iCache = jit->GetBlockCache()->iCacheEx;
|
||||||
addr = _Address & JIT_ICACHEEX_MASK;
|
addr = _Address & JIT_ICACHEEX_MASK;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
iCache = jit->GetBlockCache()->GetICache();
|
iCache = jit->GetBlockCache()->iCache;
|
||||||
addr = _Address & JIT_ICACHE_MASK;
|
addr = _Address & JIT_ICACHE_MASK;
|
||||||
}
|
}
|
||||||
u32 inst = *(u32*)(iCache + addr);
|
u32 inst = *(u32*)(iCache + addr);
|
||||||
|
@ -314,14 +314,14 @@ namespace JitInterface
|
||||||
{
|
{
|
||||||
if (_Address & JIT_ICACHE_VMEM_BIT)
|
if (_Address & JIT_ICACHE_VMEM_BIT)
|
||||||
{
|
{
|
||||||
*(u32*)(jit->GetBlockCache()->GetICacheVMEM() + (_Address & JIT_ICACHE_MASK)) = Common::swap32(_Value);
|
*(u32*)(jit->GetBlockCache()->iCacheVMEM + (_Address & JIT_ICACHE_MASK)) = Common::swap32(_Value);
|
||||||
}
|
}
|
||||||
else if (_Address & JIT_ICACHE_EXRAM_BIT)
|
else if (_Address & JIT_ICACHE_EXRAM_BIT)
|
||||||
{
|
{
|
||||||
*(u32*)(jit->GetBlockCache()->GetICacheEx() + (_Address & JIT_ICACHEEX_MASK)) = Common::swap32(_Value);
|
*(u32*)(jit->GetBlockCache()->iCacheEx + (_Address & JIT_ICACHEEX_MASK)) = Common::swap32(_Value);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
*(u32*)(jit->GetBlockCache()->GetICache() + (_Address & JIT_ICACHE_MASK)) = Common::swap32(_Value);
|
*(u32*)(jit->GetBlockCache()->iCache + (_Address & JIT_ICACHE_MASK)) = Common::swap32(_Value);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue