summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorMai <mathew1800@gmail.com>2022-10-07 20:27:16 -0400
committerGitHub <noreply@github.com>2022-10-07 20:27:16 -0400
commit155213484b9a785c93e16a28285999256587691a (patch)
tree1e30dc76400901553d63f506a7244f9080c702db /src
parentb7ad83383f70650dee3d0fdc4b29bbdfc2f30fbb (diff)
parent7969d4d5de2661348c89c5b5d1481624edfce182 (diff)
Merge pull request #9016 from liamwhite/drunken-schedule
vk_scheduler: wait for command processing to complete
Diffstat (limited to 'src')
-rw-r--r--src/video_core/renderer_vulkan/vk_scheduler.cpp6
1 files changed, 4 insertions, 2 deletions
diff --git a/src/video_core/renderer_vulkan/vk_scheduler.cpp b/src/video_core/renderer_vulkan/vk_scheduler.cpp
index d96720b80..7934f2a51 100644
--- a/src/video_core/renderer_vulkan/vk_scheduler.cpp
+++ b/src/video_core/renderer_vulkan/vk_scheduler.cpp
@@ -139,6 +139,7 @@ void Scheduler::WorkerThread(std::stop_token stop_token) {
Common::SetCurrentThreadName("VulkanWorker");
do {
std::unique_ptr<CommandChunk> work;
+ bool has_submit{false};
{
std::unique_lock lock{work_mutex};
if (work_queue.empty()) {
@@ -150,9 +151,10 @@ void Scheduler::WorkerThread(std::stop_token stop_token) {
}
work = std::move(work_queue.front());
work_queue.pop();
+
+ has_submit = work->HasSubmit();
+ work->ExecuteAll(current_cmdbuf);
}
- const bool has_submit = work->HasSubmit();
- work->ExecuteAll(current_cmdbuf);
if (has_submit) {
AllocateWorkerCommandBuffer();
}