diff options
| author | 2019-09-26 19:08:22 -0400 | |
|---|---|---|
| committer | 2019-10-04 19:59:53 -0400 | |
| commit | 3f104464dec13f9ba90eaca5dafca87ee4116a60 (patch) | |
| tree | 29d73dec1ba2a661a9930c63689973a65482ce3b /src/video_core/gpu_thread.cpp | |
| parent | Nvdrv: Correct Event setup in Nvdrv (diff) | |
| download | yuzu-3f104464dec13f9ba90eaca5dafca87ee4116a60.tar.gz yuzu-3f104464dec13f9ba90eaca5dafca87ee4116a60.tar.xz yuzu-3f104464dec13f9ba90eaca5dafca87ee4116a60.zip | |
Core: Wait for GPU to be idle before shutting down.
Diffstat (limited to 'src/video_core/gpu_thread.cpp')
| -rw-r--r-- | src/video_core/gpu_thread.cpp | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/src/video_core/gpu_thread.cpp b/src/video_core/gpu_thread.cpp index d7048b6ae..4a42634d2 100644 --- a/src/video_core/gpu_thread.cpp +++ b/src/video_core/gpu_thread.cpp | |||
| @@ -90,6 +90,11 @@ void ThreadManager::FlushAndInvalidateRegion(CacheAddr addr, u64 size) { | |||
| 90 | InvalidateRegion(addr, size); | 90 | InvalidateRegion(addr, size); |
| 91 | } | 91 | } |
| 92 | 92 | ||
| 93 | void ThreadManager::WaitIdle() const { | ||
| 94 | while (state.last_fence > state.signaled_fence.load()) { | ||
| 95 | } | ||
| 96 | } | ||
| 97 | |||
| 93 | u64 ThreadManager::PushCommand(CommandData&& command_data) { | 98 | u64 ThreadManager::PushCommand(CommandData&& command_data) { |
| 94 | const u64 fence{++state.last_fence}; | 99 | const u64 fence{++state.last_fence}; |
| 95 | state.queue.Push(CommandDataContainer(std::move(command_data), fence)); | 100 | state.queue.Push(CommandDataContainer(std::move(command_data), fence)); |