Jit: Fix fastmem initialization order

When evaluating whether jo.fastmem should be set to true, we check the
value of jo.fastmem_arena. However, due to a change made in 28e8117b90,
jo.fastmem_arena wasn't set until after the first time we set
jo.fastmem, so jo.fastmem would end up always being false until the next
time RefreshConfig was called.

Fixes https://bugs.dolphin-emu.org/issues/13364.
This commit is contained in:
JosJuice 2023-09-30 14:46:08 +02:00
parent 7c995000ae
commit 02d76ba2a0
5 changed files with 20 additions and 14 deletions

View File

@ -82,7 +82,7 @@ CachedInterpreter::~CachedInterpreter() = default;
void CachedInterpreter::Init() void CachedInterpreter::Init()
{ {
RefreshConfig(); RefreshConfig(InitFastmemArena::No);
m_code.reserve(CODE_SIZE / sizeof(Instruction)); m_code.reserve(CODE_SIZE / sizeof(Instruction));
@ -384,5 +384,5 @@ void CachedInterpreter::ClearCache()
{ {
m_code.clear(); m_code.clear();
m_block_cache.Clear(); m_block_cache.Clear();
RefreshConfig(); RefreshConfig(InitFastmemArena::No);
} }

View File

@ -251,13 +251,10 @@ bool Jit64::BackPatch(SContext* ctx)
void Jit64::Init() void Jit64::Init()
{ {
RefreshConfig(); RefreshConfig(InitFastmemArena::Yes);
EnableBlockLink(); EnableBlockLink();
auto& memory = m_system.GetMemory();
jo.fastmem_arena = m_fastmem_enabled && memory.InitFastmemArena();
jo.optimizeGatherPipe = true; jo.optimizeGatherPipe = true;
jo.accurateSinglePrecision = true; jo.accurateSinglePrecision = true;
js.fastmemLoadStore = nullptr; js.fastmemLoadStore = nullptr;
@ -307,7 +304,7 @@ void Jit64::ClearCache()
m_const_pool.Clear(); m_const_pool.Clear();
ClearCodeSpace(); ClearCodeSpace();
Clear(); Clear();
RefreshConfig(); RefreshConfig(InitFastmemArena::No);
ResetFreeMemoryRanges(); ResetFreeMemoryRanges();
} }

View File

@ -47,15 +47,12 @@ JitArm64::~JitArm64() = default;
void JitArm64::Init() void JitArm64::Init()
{ {
RefreshConfig(); RefreshConfig(InitFastmemArena::Yes);
const size_t child_code_size = jo.memcheck ? FARCODE_SIZE_MMU : FARCODE_SIZE; const size_t child_code_size = jo.memcheck ? FARCODE_SIZE_MMU : FARCODE_SIZE;
AllocCodeSpace(CODE_SIZE + child_code_size); AllocCodeSpace(CODE_SIZE + child_code_size);
AddChildCodeSpace(&m_far_code, child_code_size); AddChildCodeSpace(&m_far_code, child_code_size);
auto& memory = m_system.GetMemory();
jo.fastmem_arena = m_fastmem_enabled && memory.InitFastmemArena();
jo.optimizeGatherPipe = true; jo.optimizeGatherPipe = true;
SetBlockLinkingEnabled(true); SetBlockLinkingEnabled(true);
SetOptimizationEnabled(true); SetOptimizationEnabled(true);
@ -158,7 +155,7 @@ void JitArm64::ClearCache()
const Common::ScopedJITPageWriteAndNoExecute enable_jit_page_writes; const Common::ScopedJITPageWriteAndNoExecute enable_jit_page_writes;
ClearCodeSpace(); ClearCodeSpace();
m_far_code.ClearCodeSpace(); m_far_code.ClearCodeSpace();
RefreshConfig(); RefreshConfig(InitFastmemArena::No);
GenerateAsm(); GenerateAsm();

View File

@ -115,7 +115,7 @@ bool JitBase::DoesConfigNeedRefresh()
}); });
} }
void JitBase::RefreshConfig() void JitBase::RefreshConfig(InitFastmemArena init_fastmem_arena)
{ {
for (const auto& [member, config_info] : JIT_SETTINGS) for (const auto& [member, config_info] : JIT_SETTINGS)
this->*member = Config::Get(*config_info); this->*member = Config::Get(*config_info);
@ -132,6 +132,12 @@ void JitBase::RefreshConfig()
analyzer.SetFloatExceptionsEnabled(m_enable_float_exceptions); analyzer.SetFloatExceptionsEnabled(m_enable_float_exceptions);
analyzer.SetDivByZeroExceptionsEnabled(m_enable_div_by_zero_exceptions); analyzer.SetDivByZeroExceptionsEnabled(m_enable_div_by_zero_exceptions);
if (init_fastmem_arena != InitFastmemArena::No)
{
auto& memory = m_system.GetMemory();
jo.fastmem_arena = m_fastmem_enabled && memory.InitFastmemArena();
}
bool any_watchpoints = m_system.GetPowerPC().GetMemChecks().HasAny(); bool any_watchpoints = m_system.GetPowerPC().GetMemChecks().HasAny();
jo.fastmem = m_fastmem_enabled && jo.fastmem_arena && (m_ppc_state.msr.DR || !any_watchpoints) && jo.fastmem = m_fastmem_enabled && jo.fastmem_arena && (m_ppc_state.msr.DR || !any_watchpoints) &&
EMM::IsExceptionHandlerSupported(); EMM::IsExceptionHandlerSupported();

View File

@ -163,8 +163,14 @@ protected:
static const std::array<std::pair<bool JitBase::*, const Config::Info<bool>*>, 22> JIT_SETTINGS; static const std::array<std::pair<bool JitBase::*, const Config::Info<bool>*>, 22> JIT_SETTINGS;
enum class InitFastmemArena
{
No,
Yes,
};
bool DoesConfigNeedRefresh(); bool DoesConfigNeedRefresh();
void RefreshConfig(); void RefreshConfig(InitFastmemArena init_fastmem_arena);
void InitBLROptimization(); void InitBLROptimization();
void ProtectStack(); void ProtectStack();