summaryrefslogtreecommitdiff
path: root/src/video_core/gpu_thread.cpp
diff options
context:
space:
mode:
authorGravatar liamwhite2023-03-23 10:00:31 -0400
committerGravatar GitHub2023-03-23 10:00:31 -0400
commitac3927074b190965bacbf99f70e8c5e95c953788 (patch)
tree324b95f908f83dde8b1b78cde131a8145f032508 /src/video_core/gpu_thread.cpp
parentMerge pull request #9964 from liamwhite/typed-address (diff)
parentbounded_threadsafe_queue: Refactor Pop (diff)
downloadyuzu-ac3927074b190965bacbf99f70e8c5e95c953788.tar.gz
yuzu-ac3927074b190965bacbf99f70e8c5e95c953788.tar.xz
yuzu-ac3927074b190965bacbf99f70e8c5e95c953788.zip
Merge pull request #9971 from Morph1984/q
bounded_threadsafe_queue: Use simplified impl of bounded queue
Diffstat (limited to 'src/video_core/gpu_thread.cpp')
-rw-r--r--src/video_core/gpu_thread.cpp7
1 files changed, 4 insertions, 3 deletions
diff --git a/src/video_core/gpu_thread.cpp b/src/video_core/gpu_thread.cpp
index f52f9e28f..3c5317777 100644
--- a/src/video_core/gpu_thread.cpp
+++ b/src/video_core/gpu_thread.cpp
@@ -31,9 +31,10 @@ static void RunThread(std::stop_token stop_token, Core::System& system,
31 auto current_context = context.Acquire(); 31 auto current_context = context.Acquire();
32 VideoCore::RasterizerInterface* const rasterizer = renderer.ReadRasterizer(); 32 VideoCore::RasterizerInterface* const rasterizer = renderer.ReadRasterizer();
33 33
34 CommandDataContainer next;
35
34 while (!stop_token.stop_requested()) { 36 while (!stop_token.stop_requested()) {
35 CommandDataContainer next; 37 state.queue.PopWait(next, stop_token);
36 state.queue.Pop(next, stop_token);
37 if (stop_token.stop_requested()) { 38 if (stop_token.stop_requested()) {
38 break; 39 break;
39 } 40 }
@@ -117,7 +118,7 @@ u64 ThreadManager::PushCommand(CommandData&& command_data, bool block) {
117 118
118 std::unique_lock lk(state.write_lock); 119 std::unique_lock lk(state.write_lock);
119 const u64 fence{++state.last_fence}; 120 const u64 fence{++state.last_fence};
120 state.queue.Push(CommandDataContainer(std::move(command_data), fence, block)); 121 state.queue.EmplaceWait(std::move(command_data), fence, block);
121 122
122 if (block) { 123 if (block) {
123 Common::CondvarWait(state.cv, lk, thread.get_stop_token(), [this, fence] { 124 Common::CondvarWait(state.cv, lk, thread.get_stop_token(), [this, fence] {