Interpreter_LoadStore: Generate alignment exceptions if dcbz or dcbz_l are executed with the data cache disabled
This is an exception condition documented within section 4.5.6 in the architecture reference manual for the PPC 750CL, which also applies to the Gekko microprocessor. Also moves dcbz_l's implementation out of Interpreter_Paired and beside dcbz where it belongs.
This commit is contained in:
parent
9be505fde2
commit
980f1641b5
|
@ -421,6 +421,13 @@ void Interpreter::dcbz(UGeckoInstruction inst)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
const u32 dcbz_addr = Helper_Get_EA_X(inst);
|
const u32 dcbz_addr = Helper_Get_EA_X(inst);
|
||||||
|
|
||||||
|
if (!HID0.DCE)
|
||||||
|
{
|
||||||
|
GenerateAlignmentException(dcbz_addr);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
// Hack to stop dcbz/dcbi over low MEM1 trashing memory.
|
// Hack to stop dcbz/dcbi over low MEM1 trashing memory.
|
||||||
if (SConfig::GetInstance().bLowDCBZHack && (dcbz_addr < 0x80008000) && (dcbz_addr >= 0x80000000))
|
if (SConfig::GetInstance().bLowDCBZHack && (dcbz_addr < 0x80008000) && (dcbz_addr >= 0x80000000))
|
||||||
return;
|
return;
|
||||||
|
@ -429,6 +436,20 @@ void Interpreter::dcbz(UGeckoInstruction inst)
|
||||||
PowerPC::ClearCacheLine(dcbz_addr & (~31));
|
PowerPC::ClearCacheLine(dcbz_addr & (~31));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Interpreter::dcbz_l(UGeckoInstruction inst)
|
||||||
|
{
|
||||||
|
const u32 address = Helper_Get_EA_X(inst);
|
||||||
|
|
||||||
|
if (!HID0.DCE)
|
||||||
|
{
|
||||||
|
GenerateAlignmentException(address);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// FAKE: clear memory instead of clearing the cache block
|
||||||
|
PowerPC::ClearCacheLine(address & (~31));
|
||||||
|
}
|
||||||
|
|
||||||
// eciwx/ecowx technically should access the specified device
|
// eciwx/ecowx technically should access the specified device
|
||||||
// We just do it instantly from ppc...and hey, it works! :D
|
// We just do it instantly from ppc...and hey, it works! :D
|
||||||
void Interpreter::eciwx(UGeckoInstruction inst)
|
void Interpreter::eciwx(UGeckoInstruction inst)
|
||||||
|
|
|
@ -331,12 +331,3 @@ void Interpreter::ps_cmpo1(UGeckoInstruction inst)
|
||||||
{
|
{
|
||||||
Helper_FloatCompareOrdered(inst, rPS1(inst.FA), rPS1(inst.FB));
|
Helper_FloatCompareOrdered(inst, rPS1(inst.FA), rPS1(inst.FB));
|
||||||
}
|
}
|
||||||
|
|
||||||
// __________________________________________________________________________________________________
|
|
||||||
// dcbz_l
|
|
||||||
// TODO(ector) check docs
|
|
||||||
void Interpreter::dcbz_l(UGeckoInstruction inst)
|
|
||||||
{
|
|
||||||
// FAKE: clear memory instead of clearing the cache block
|
|
||||||
PowerPC::ClearCacheLine(Helper_Get_EA_X(inst) & (~31));
|
|
||||||
}
|
|
||||||
|
|
Loading…
Reference in New Issue