From ddcf995800da99c255383b8f64b45715b84324ae Mon Sep 17 00:00:00 2001 From: felk Date: Fri, 22 Oct 2021 18:15:50 +0200 Subject: [PATCH] Scripting: fix deadlocks when using savestates --- Source/Core/Core/Core.cpp | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/Source/Core/Core/Core.cpp b/Source/Core/Core/Core.cpp index f53c8f81d8c0..378e87fa01da 100644 --- a/Source/Core/Core/Core.cpp +++ b/Source/Core/Core/Core.cpp @@ -113,6 +113,7 @@ static bool s_is_throttler_temp_disabled = false; static std::atomic s_last_actual_emulation_speed{1.0}; static bool s_frame_step = false; static std::atomic s_stop_frame_step; +static std::atomic s_frame_advanced; #ifdef USE_MEMORYWATCHER static std::unique_ptr s_memory_watcher; @@ -887,7 +888,10 @@ void Callback_FramePresented(double actual_emulation_speed) s_drawn_frame++; s_stop_frame_step.store(true); - API::GetEventHub().EmitEvent(API::Events::FrameAdvance{}); + // Emitting the frame advanced event may cause work on the CPU thread, + // but synchronizing from the GPU thread with CPU thread deadlocks. + // So we cannot emit the event here and have to have the CPU thread do it. + s_frame_advanced.store(true); } // Called from VideoInterface::Update (CPU thread) at emulated field boundaries @@ -909,6 +913,11 @@ void Callback_NewField() CallOnStateChangedCallbacks(Core::GetState()); } } + if (s_frame_advanced.load()) + { + s_frame_advanced.store(false); + API::GetEventHub().EmitEvent(API::Events::FrameAdvance{}); + } } void UpdateTitle(u32 ElapseTime)