From 1cbcd142fa3d058891eb71ea3cd295f9c9cff81d Mon Sep 17 00:00:00 2001 From: Zephyron Date: Thu, 2 Jan 2025 16:38:18 +1000 Subject: [PATCH] video_core: Enforce safe memory reads for compute dispatch - Modify DmaPusher to use safe memory reads when handling compute operations at High GPU accuracy - Prevent potential memory corruption issues that could lead to invalid dispatch parameters - Previously, unsafe reads could result in corrupted launch_description data in KeplerCompute::ProcessLaunch, causing invalid vkCmdDispatch calls - By enforcing safe reads specifically for compute operations, we maintain performance for other GPU tasks while ensuring compute dispatch stability This change requires >= High GPU accuracy level to take effect. --- src/video_core/dma_pusher.cpp | 15 +++++++++------ 1 file changed, 9 insertions(+), 6 deletions(-) diff --git a/src/video_core/dma_pusher.cpp b/src/video_core/dma_pusher.cpp index 7dc4d5855..57210882d 100644 --- a/src/video_core/dma_pusher.cpp +++ b/src/video_core/dma_pusher.cpp @@ -98,19 +98,22 @@ bool DmaPusher::Step() { &command_headers); ProcessCommands(headers); }; + + // Only use unsafe reads for non-compute macro operations if (Settings::IsGPULevelHigh()) { - if (dma_state.method >= MacroRegistersStart) { - unsafe_process(); - return true; - } - if (subchannel_type[dma_state.subchannel] == Engines::EngineTypes::KeplerCompute && - dma_state.method == ComputeInline) { + const bool is_compute = (subchannel_type[dma_state.subchannel] == + Engines::EngineTypes::KeplerCompute); + + if (dma_state.method >= MacroRegistersStart && !is_compute) { unsafe_process(); return true; } + + // Always use safe reads for compute operations safe_process(); return true; } + unsafe_process(); } return true;