GeckoCode: Don't spam retry after the install fails

If the installation fails because codehandler.bin is missing or
unusable then Dolphin will try again every single frame even though
it's highly unlikely a disk file will have changed. Better to just
fail once then only try again when the active code set is changed.

Suppresses generating 60 log messages per second.
This commit is contained in:
EmptyChaos 2016-09-24 03:17:39 +00:00
parent 541a42a7e3
commit 249d8a76e1
1 changed files with 18 additions and 9 deletions

View File

@ -39,7 +39,14 @@ bool GeckoCode::Compare(const GeckoCode& compare) const
}); });
} }
static bool s_code_handler_installed = false; enum class Installation
{
Uninstalled,
Installed,
Failed
};
static Installation s_code_handler_installed = Installation::Uninstalled;
// the currently active codes // the currently active codes
static std::vector<GeckoCode> s_active_codes; static std::vector<GeckoCode> s_active_codes;
static std::mutex s_active_codes_lock; static std::mutex s_active_codes_lock;
@ -54,24 +61,24 @@ void SetActiveCodes(const std::vector<GeckoCode>& gcodes)
[](const GeckoCode& code) { return code.enabled; }); [](const GeckoCode& code) { return code.enabled; });
s_active_codes.shrink_to_fit(); s_active_codes.shrink_to_fit();
s_code_handler_installed = false; s_code_handler_installed = Installation::Uninstalled;
} }
// Requires s_active_codes_lock // Requires s_active_codes_lock
// NOTE: Refer to "codehandleronly.s" from Gecko OS. // NOTE: Refer to "codehandleronly.s" from Gecko OS.
static bool InstallCodeHandlerLocked() static Installation InstallCodeHandlerLocked()
{ {
std::string data; std::string data;
if (!File::ReadFileToString(File::GetSysDirectory() + GECKO_CODE_HANDLER, data)) if (!File::ReadFileToString(File::GetSysDirectory() + GECKO_CODE_HANDLER, data))
{ {
ERROR_LOG(ACTIONREPLAY, "Could not enable cheats because " GECKO_CODE_HANDLER " was missing."); ERROR_LOG(ACTIONREPLAY, "Could not enable cheats because " GECKO_CODE_HANDLER " was missing.");
return false; return Installation::Failed;
} }
if (data.size() > INSTALLER_END_ADDRESS - INSTALLER_BASE_ADDRESS - CODE_SIZE) if (data.size() > INSTALLER_END_ADDRESS - INSTALLER_BASE_ADDRESS - CODE_SIZE)
{ {
ERROR_LOG(ACTIONREPLAY, GECKO_CODE_HANDLER " is too big. The file may be corrupt."); ERROR_LOG(ACTIONREPLAY, GECKO_CODE_HANDLER " is too big. The file may be corrupt.");
return false; return Installation::Failed;
} }
u8 mmio_addr = 0xCC; u8 mmio_addr = 0xCC;
@ -148,7 +155,7 @@ static bool InstallCodeHandlerLocked()
{ {
PowerPC::ppcState.iCache.Invalidate(INSTALLER_BASE_ADDRESS + j); PowerPC::ppcState.iCache.Invalidate(INSTALLER_BASE_ADDRESS + j);
} }
return true; return Installation::Installed;
} }
void RunCodeHandler() void RunCodeHandler()
@ -157,15 +164,17 @@ void RunCodeHandler()
return; return;
std::lock_guard<std::mutex> codes_lock(s_active_codes_lock); std::lock_guard<std::mutex> codes_lock(s_active_codes_lock);
if (s_active_codes.empty()) // Don't spam retry if the install failed. The corrupt / missing disk file is not likely to be
// fixed within 1 frame of the last error.
if (s_active_codes.empty() || s_code_handler_installed == Installation::Failed)
return; return;
if (!s_code_handler_installed) if (s_code_handler_installed != Installation::Installed)
{ {
s_code_handler_installed = InstallCodeHandlerLocked(); s_code_handler_installed = InstallCodeHandlerLocked();
// A warning was already issued for the install failing // A warning was already issued for the install failing
if (!s_code_handler_installed) if (s_code_handler_installed != Installation::Installed)
return; return;
} }