Merge pull request #7078 from ameerj/vc-jthread-fixes

video_core: Fix jthread related hangs when stopping emulation
This commit is contained in:
Morph 2021-09-26 16:40:13 -04:00 committed by GitHub
commit 5114819b6b
WARNING! Although there is a key with this ID in the database it does not verify this commit! This commit is SUSPICIOUS.
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 2 additions and 2 deletions

View file

@ -305,7 +305,6 @@ struct System::Impl {
is_powered_on = false; is_powered_on = false;
exit_lock = false; exit_lock = false;
gpu_core.reset();
services.reset(); services.reset();
service_manager.reset(); service_manager.reset();
cheat_engine.reset(); cheat_engine.reset();
@ -315,6 +314,7 @@ struct System::Impl {
core_timing.Shutdown(); core_timing.Shutdown();
app_loader.reset(); app_loader.reset();
perf_stats.reset(); perf_stats.reset();
gpu_core.reset();
kernel.Shutdown(); kernel.Shutdown();
memory.Reset(); memory.Reset();
applet_manager.ClearAll(); applet_manager.ClearAll();

View file

@ -212,7 +212,6 @@ private:
vk::CommandBuffer current_cmdbuf; vk::CommandBuffer current_cmdbuf;
std::unique_ptr<CommandChunk> chunk; std::unique_ptr<CommandChunk> chunk;
std::jthread worker_thread;
State state; State state;
@ -226,6 +225,7 @@ private:
std::mutex work_mutex; std::mutex work_mutex;
std::condition_variable_any work_cv; std::condition_variable_any work_cv;
std::condition_variable wait_cv; std::condition_variable wait_cv;
std::jthread worker_thread;
}; };
} // namespace Vulkan } // namespace Vulkan