Merge pull request #12761 from mitaclaw/core-global-system-5

Core::SetState: Avoid Global System Accessor
This commit is contained in:
Admiral H. Curtiss 2024-05-04 18:19:50 +02:00 committed by GitHub
commit 1a2e315880
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
7 changed files with 20 additions and 21 deletions

View File

@ -247,13 +247,13 @@ JNIEXPORT void JNICALL Java_org_dolphinemu_dolphinemu_NativeLibrary_UnPauseEmula
jclass) jclass)
{ {
HostThreadLock guard; HostThreadLock guard;
Core::SetState(Core::State::Running); Core::SetState(Core::System::GetInstance(), Core::State::Running);
} }
JNIEXPORT void JNICALL Java_org_dolphinemu_dolphinemu_NativeLibrary_PauseEmulation(JNIEnv*, jclass) JNIEXPORT void JNICALL Java_org_dolphinemu_dolphinemu_NativeLibrary_PauseEmulation(JNIEnv*, jclass)
{ {
HostThreadLock guard; HostThreadLock guard;
Core::SetState(Core::State::Paused); Core::SetState(Core::System::GetInstance(), Core::State::Paused);
} }
JNIEXPORT void JNICALL Java_org_dolphinemu_dolphinemu_NativeLibrary_StopEmulation(JNIEnv*, jclass) JNIEXPORT void JNICALL Java_org_dolphinemu_dolphinemu_NativeLibrary_StopEmulation(JNIEnv*, jclass)
@ -469,7 +469,7 @@ JNIEXPORT void JNICALL Java_org_dolphinemu_dolphinemu_NativeLibrary_SurfaceDestr
} }
if (Core::GetState(Core::System::GetInstance()) == Core::State::Running) if (Core::GetState(Core::System::GetInstance()) == Core::State::Running)
Core::SetState(Core::State::Paused); Core::SetState(Core::System::GetInstance(), Core::State::Paused);
} }
std::lock_guard surface_guard(s_surface_lock); std::lock_guard surface_guard(s_surface_lock);

View File

@ -354,9 +354,9 @@ static void CPUSetInitialExecutionState(bool force_paused = false)
{ {
// The CPU starts in stepping state, and will wait until a new state is set before executing. // The CPU starts in stepping state, and will wait until a new state is set before executing.
// SetState must be called on the host thread, so we defer it for later. // SetState must be called on the host thread, so we defer it for later.
QueueHostJob([force_paused](Core::System&) { QueueHostJob([force_paused](Core::System& system) {
bool paused = SConfig::GetInstance().bBootToPause || force_paused; bool paused = SConfig::GetInstance().bBootToPause || force_paused;
SetState(paused ? State::Paused : State::Running); SetState(system, paused ? State::Paused : State::Running);
Host_UpdateDisasmDialog(); Host_UpdateDisasmDialog();
Host_UpdateMainFrame(); Host_UpdateMainFrame();
Host_Message(HostMessageID::WMUserCreate); Host_Message(HostMessageID::WMUserCreate);
@ -700,13 +700,12 @@ static void EmuThread(Core::System& system, std::unique_ptr<BootParameters> boot
// Set or get the running state // Set or get the running state
void SetState(State state, bool report_state_change) void SetState(Core::System& system, State state, bool report_state_change)
{ {
// State cannot be controlled until the CPU Thread is operational // State cannot be controlled until the CPU Thread is operational
if (!IsRunningAndStarted()) if (!IsRunningAndStarted())
return; return;
auto& system = Core::System::GetInstance();
switch (state) switch (state)
{ {
case State::Paused: case State::Paused:
@ -1061,12 +1060,12 @@ void DoFrameStep(Core::System& system)
// if already paused, frame advance for 1 frame // if already paused, frame advance for 1 frame
s_stop_frame_step = false; s_stop_frame_step = false;
s_frame_step = true; s_frame_step = true;
SetState(State::Running, false); SetState(system, State::Running, false);
} }
else if (!s_frame_step) else if (!s_frame_step)
{ {
// if not paused yet, pause immediately instead // if not paused yet, pause immediately instead
SetState(State::Paused); SetState(system, State::Paused);
} }
} }

View File

@ -143,7 +143,7 @@ bool IsHostThread();
bool WantsDeterminism(); bool WantsDeterminism();
// [NOT THREADSAFE] For use by Host only // [NOT THREADSAFE] For use by Host only
void SetState(State state, bool report_state_change = true); void SetState(Core::System& system, State state, bool report_state_change = true);
State GetState(Core::System& system); State GetState(Core::System& system);
void SaveScreenShot(); void SaveScreenShot();

View File

@ -44,9 +44,9 @@
{ {
auto& system = Core::System::GetInstance(); auto& system = Core::System::GetInstance();
if (Core::GetState(system) == Core::State::Running) if (Core::GetState(system) == Core::State::Running)
Core::SetState(Core::State::Paused); Core::SetState(system, Core::State::Paused);
else else
Core::SetState(Core::State::Running); Core::SetState(system, Core::State::Running);
} }
- (void)saveScreenShot - (void)saveScreenShot

View File

@ -203,13 +203,13 @@ void PlatformX11::ProcessEvents()
{ {
if (Config::Get(Config::MAIN_SHOW_CURSOR) == Config::ShowCursor::Never) if (Config::Get(Config::MAIN_SHOW_CURSOR) == Config::ShowCursor::Never)
XUndefineCursor(m_display, m_window); XUndefineCursor(m_display, m_window);
Core::SetState(Core::State::Paused); Core::SetState(Core::System::GetInstance(), Core::State::Paused);
} }
else else
{ {
if (Config::Get(Config::MAIN_SHOW_CURSOR) == Config::ShowCursor::Never) if (Config::Get(Config::MAIN_SHOW_CURSOR) == Config::ShowCursor::Never)
XDefineCursor(m_display, m_window, m_blank_cursor); XDefineCursor(m_display, m_window, m_blank_cursor);
Core::SetState(Core::State::Running); Core::SetState(Core::System::GetInstance(), Core::State::Running);
} }
} }
else if ((key == XK_Return) && (event.xkey.state & Mod1Mask)) else if ((key == XK_Return) && (event.xkey.state & Mod1Mask))

View File

@ -825,7 +825,7 @@ void MainWindow::Play(const std::optional<std::string>& savestate_path)
// Otherwise, prompt for a new game. // Otherwise, prompt for a new game.
if (Core::GetState(Core::System::GetInstance()) == Core::State::Paused) if (Core::GetState(Core::System::GetInstance()) == Core::State::Paused)
{ {
Core::SetState(Core::State::Running); Core::SetState(Core::System::GetInstance(), Core::State::Running);
} }
else else
{ {
@ -853,7 +853,7 @@ void MainWindow::Play(const std::optional<std::string>& savestate_path)
void MainWindow::Pause() void MainWindow::Pause()
{ {
Core::SetState(Core::State::Paused); Core::SetState(Core::System::GetInstance(), Core::State::Paused);
} }
void MainWindow::TogglePause() void MainWindow::TogglePause()
@ -932,7 +932,7 @@ bool MainWindow::RequestStop()
bool pause = !Settings::Instance().GetNetPlayClient(); bool pause = !Settings::Instance().GetNetPlayClient();
if (pause) if (pause)
Core::SetState(Core::State::Paused); Core::SetState(Core::System::GetInstance(), Core::State::Paused);
if (rendered_widget_was_active) if (rendered_widget_was_active)
{ {
@ -962,7 +962,7 @@ bool MainWindow::RequestStop()
m_render_widget->SetWaitingForMessageBox(false); m_render_widget->SetWaitingForMessageBox(false);
if (pause) if (pause)
Core::SetState(state); Core::SetState(Core::System::GetInstance(), state);
return false; return false;
} }
@ -984,7 +984,7 @@ bool MainWindow::RequestStop()
// Unpause because gracefully shutting down needs the game to actually request a shutdown. // Unpause because gracefully shutting down needs the game to actually request a shutdown.
// TODO: Do not unpause in debug mode to allow debugging until the complete shutdown. // TODO: Do not unpause in debug mode to allow debugging until the complete shutdown.
if (Core::GetState(Core::System::GetInstance()) == Core::State::Paused) if (Core::GetState(Core::System::GetInstance()) == Core::State::Paused)
Core::SetState(Core::State::Running); Core::SetState(Core::System::GetInstance(), Core::State::Running);
// Tell NetPlay about the power event // Tell NetPlay about the power event
if (NetPlay::IsNetPlayRunning()) if (NetPlay::IsNetPlayRunning())

View File

@ -424,7 +424,7 @@ bool RenderWidget::event(QEvent* event)
if (m_should_unpause_on_focus && if (m_should_unpause_on_focus &&
Core::GetState(Core::System::GetInstance()) == Core::State::Paused) Core::GetState(Core::System::GetInstance()) == Core::State::Paused)
{ {
Core::SetState(Core::State::Running); Core::SetState(Core::System::GetInstance(), Core::State::Running);
} }
m_should_unpause_on_focus = false; m_should_unpause_on_focus = false;
@ -457,7 +457,7 @@ bool RenderWidget::event(QEvent* event)
if (!Core::IsCPUThread() && !Core::IsGPUThread()) if (!Core::IsCPUThread() && !Core::IsGPUThread())
{ {
m_should_unpause_on_focus = true; m_should_unpause_on_focus = true;
Core::SetState(Core::State::Paused); Core::SetState(Core::System::GetInstance(), Core::State::Paused);
} }
} }