Merge pull request #3535 from RisingFog/cya_savestate_memleak
Properly clear JIT cache on save states
This commit is contained in:
commit
e455ca4d58
|
@ -607,7 +607,11 @@ void Wiimote::DoState(PointerWrap& p)
|
||||||
{
|
{
|
||||||
//clear
|
//clear
|
||||||
while (!m_read_requests.empty())
|
while (!m_read_requests.empty())
|
||||||
|
{
|
||||||
|
delete[] m_read_requests.front().data;
|
||||||
m_read_requests.pop();
|
m_read_requests.pop();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
p.Do(size);
|
p.Do(size);
|
||||||
while (size--)
|
while (size--)
|
||||||
|
|
|
@ -210,6 +210,7 @@ void Jit64::Init()
|
||||||
// important: do this *after* generating the global asm routines, because we can't use farcode in them.
|
// important: do this *after* generating the global asm routines, because we can't use farcode in them.
|
||||||
// it'll crash because the farcode functions get cleared on JIT clears.
|
// it'll crash because the farcode functions get cleared on JIT clears.
|
||||||
farcode.Init(jo.memcheck ? FARCODE_SIZE_MMU : FARCODE_SIZE);
|
farcode.Init(jo.memcheck ? FARCODE_SIZE_MMU : FARCODE_SIZE);
|
||||||
|
Clear();
|
||||||
|
|
||||||
code_block.m_stats = &js.st;
|
code_block.m_stats = &js.st;
|
||||||
code_block.m_gpa = &js.gpa;
|
code_block.m_gpa = &js.gpa;
|
||||||
|
@ -223,6 +224,7 @@ void Jit64::ClearCache()
|
||||||
trampolines.ClearCodeSpace();
|
trampolines.ClearCodeSpace();
|
||||||
farcode.ClearCodeSpace();
|
farcode.ClearCodeSpace();
|
||||||
ClearCodeSpace();
|
ClearCodeSpace();
|
||||||
|
Clear();
|
||||||
UpdateMemoryOptions();
|
UpdateMemoryOptions();
|
||||||
m_clear_cache_asap = false;
|
m_clear_cache_asap = false;
|
||||||
}
|
}
|
||||||
|
|
|
@ -258,6 +258,7 @@ void JitIL::Init()
|
||||||
asm_routines.Init(nullptr);
|
asm_routines.Init(nullptr);
|
||||||
|
|
||||||
farcode.Init(jo.memcheck ? FARCODE_SIZE_MMU : FARCODE_SIZE);
|
farcode.Init(jo.memcheck ? FARCODE_SIZE_MMU : FARCODE_SIZE);
|
||||||
|
Clear();
|
||||||
|
|
||||||
code_block.m_stats = &js.st;
|
code_block.m_stats = &js.st;
|
||||||
code_block.m_gpa = &js.gpa;
|
code_block.m_gpa = &js.gpa;
|
||||||
|
@ -273,7 +274,9 @@ void JitIL::ClearCache()
|
||||||
{
|
{
|
||||||
blocks.Clear();
|
blocks.Clear();
|
||||||
trampolines.ClearCodeSpace();
|
trampolines.ClearCodeSpace();
|
||||||
|
farcode.ClearCodeSpace();
|
||||||
ClearCodeSpace();
|
ClearCodeSpace();
|
||||||
|
Clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
void JitIL::Shutdown()
|
void JitIL::Shutdown()
|
||||||
|
@ -459,7 +462,7 @@ void JitIL::Trace()
|
||||||
|
|
||||||
void JitIL::Jit(u32 em_address)
|
void JitIL::Jit(u32 em_address)
|
||||||
{
|
{
|
||||||
if (IsAlmostFull() || farcode.IsAlmostFull() || blocks.IsFull() ||
|
if (IsAlmostFull() || farcode.IsAlmostFull() || trampolines.IsAlmostFull() || blocks.IsFull() ||
|
||||||
SConfig::GetInstance().bJITNoBlockCache)
|
SConfig::GetInstance().bJITNoBlockCache)
|
||||||
{
|
{
|
||||||
ClearCache();
|
ClearCache();
|
||||||
|
|
|
@ -1018,3 +1018,11 @@ void EmuCodeBlock::JitClearCA()
|
||||||
{
|
{
|
||||||
MOV(8, PPCSTATE(xer_ca), Imm8(0));
|
MOV(8, PPCSTATE(xer_ca), Imm8(0));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void EmuCodeBlock::Clear()
|
||||||
|
{
|
||||||
|
registersInUseAtLoc.clear();
|
||||||
|
pcAtLoc.clear();
|
||||||
|
exceptionHandlerAtLoc.clear();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
|
@ -129,6 +129,7 @@ public:
|
||||||
void ConvertSingleToDouble(Gen::X64Reg dst, Gen::X64Reg src, bool src_is_gpr = false);
|
void ConvertSingleToDouble(Gen::X64Reg dst, Gen::X64Reg src, bool src_is_gpr = false);
|
||||||
void ConvertDoubleToSingle(Gen::X64Reg dst, Gen::X64Reg src);
|
void ConvertDoubleToSingle(Gen::X64Reg dst, Gen::X64Reg src);
|
||||||
void SetFPRF(Gen::X64Reg xmm);
|
void SetFPRF(Gen::X64Reg xmm);
|
||||||
|
void Clear();
|
||||||
protected:
|
protected:
|
||||||
std::unordered_map<u8 *, BitSet32> registersInUseAtLoc;
|
std::unordered_map<u8 *, BitSet32> registersInUseAtLoc;
|
||||||
std::unordered_map<u8 *, u32> pcAtLoc;
|
std::unordered_map<u8 *, u32> pcAtLoc;
|
||||||
|
|
|
@ -40,7 +40,7 @@ namespace JitInterface
|
||||||
void DoState(PointerWrap &p)
|
void DoState(PointerWrap &p)
|
||||||
{
|
{
|
||||||
if (jit && p.GetMode() == PointerWrap::MODE_READ)
|
if (jit && p.GetMode() == PointerWrap::MODE_READ)
|
||||||
jit->GetBlockCache()->Clear();
|
jit->ClearCache();
|
||||||
}
|
}
|
||||||
CPUCoreBase *InitJitCore(int core)
|
CPUCoreBase *InitJitCore(int core)
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in New Issue