From 730974b17020231f7d8a027ce1522dc0900c3f98 Mon Sep 17 00:00:00 2001 From: CamilleLaVey Date: Tue, 13 Jan 2026 19:16:51 -0400 Subject: [PATCH] [video_core, macro, scheduler] Following Lizzie's request of change --- src/video_core/control/scheduler.cpp | 16 ++++++---------- 1 file changed, 6 insertions(+), 10 deletions(-) diff --git a/src/video_core/control/scheduler.cpp b/src/video_core/control/scheduler.cpp index bd3b8b860e..c2267acede 100644 --- a/src/video_core/control/scheduler.cpp +++ b/src/video_core/control/scheduler.cpp @@ -17,16 +17,12 @@ Scheduler::Scheduler(GPU& gpu_) : gpu{gpu_} {} Scheduler::~Scheduler() = default; void Scheduler::Push(s32 channel, CommandList&& entries) { - std::shared_ptr channel_state; - { - std::unique_lock lk(scheduling_guard); - auto it = channels.find(channel); - ASSERT(it != channels.end()); - channel_state = it->second; - gpu.BindChannel(channel_state->bind_id); - } - // Process commands outside the lock to reduce contention. - // Multiple channels can prepare their commands in parallel. + std::unique_lock lk(scheduling_guard); + auto it = channels.find(channel); + ASSERT(it != channels.end()); + auto& channel_state = it->second; + gpu.BindChannel(channel_state->bind_id); + lk.unlock(); channel_state->dma_pusher->Push(std::move(entries)); channel_state->dma_pusher->DispatchCalls(); }