Merge pull request #6112 from stenzek/videoconfig-race

VideoConfig: Prevent race condition on g_Config when refreshing
This commit is contained in:
Leo Lam 2017-10-11 11:05:47 +02:00 committed by GitHub
commit 6230860925
3 changed files with 10 additions and 3 deletions

View File

@ -321,6 +321,9 @@ VideoConfigDiag::VideoConfigDiag(wxWindow* parent, const std::string& title)
wxGetTranslation(StrToWxStr(title)))), wxGetTranslation(StrToWxStr(title)))),
vconfig(g_Config) vconfig(g_Config)
{ {
// We don't need to load the config if the core is running, since it would have been done
// at startup time already.
if (!Core::IsRunning())
vconfig.Refresh(); vconfig.Refresh();
Bind(wxEVT_UPDATE_UI, &VideoConfigDiag::OnUpdateUI, this); Bind(wxEVT_UPDATE_UI, &VideoConfigDiag::OnUpdateUI, this);

View File

@ -192,7 +192,6 @@ void VideoBackendBase::InitializeShared()
g_Config.Refresh(); g_Config.Refresh();
g_Config.UpdateProjectionHack(); g_Config.UpdateProjectionHack();
g_Config.VerifyValidity();
UpdateActiveConfig(); UpdateActiveConfig();
} }

View File

@ -48,7 +48,12 @@ void VideoConfig::Refresh()
{ {
if (!s_has_registered_callback) if (!s_has_registered_callback)
{ {
Config::AddConfigChangedCallback([]() { g_Config.Refresh(); }); // There was a race condition between the video thread and the host thread here, if
// corrections need to be made by VerifyValidity(). Briefly, the config will contain
// invalid values. Instead, pause emulation first, which will flush the video thread,
// update the config and correct it, then resume emulation, after which the video
// thread will detect the config has changed and act accordingly.
Config::AddConfigChangedCallback([]() { Core::RunAsCPUThread([]() { g_Config.Refresh(); }); });
s_has_registered_callback = true; s_has_registered_callback = true;
} }