diff --git a/src/video_core/dma_pusher.cpp b/src/video_core/dma_pusher.cpp index 32017d26f9..3bad67618e 100644 --- a/src/video_core/dma_pusher.cpp +++ b/src/video_core/dma_pusher.cpp @@ -83,38 +83,12 @@ bool DmaPusher::Step() { } if (header.size > 0) { - if (Settings::getDebugKnobAt(0)) { - const size_t command_bytes = static_cast(header.size) * sizeof(CommandHeader); - - if (memory_manager.IsMemoryDirty(dma_state.dma_get, command_bytes)) { - memory_manager.FlushRegion(dma_state.dma_get, command_bytes); - } - - command_headers.resize_destructive(header.size); - if (Settings::IsDMALevelDefault() - ? (Settings::IsGPULevelMedium() || Settings::IsGPULevelHigh()) - : Settings::IsDMALevelSafe()) { - memory_manager.ReadBlock(dma_state.dma_get, command_headers.data(), command_bytes); - } else { - memory_manager.ReadBlockUnsafe(dma_state.dma_get, command_headers.data(), - command_bytes); - } - ProcessCommands(command_headers); + if (dma_state.method == ComputeInline || (Settings::IsDMALevelDefault() ? Settings::IsGPULevelLow() : Settings::IsDMALevelSafe())) { + Tegra::Memory::GpuGuestMemoryheaders(memory_manager, dma_state.dma_get, header.size, &command_headers); + ProcessCommands(headers); } else { - if (Settings::IsDMALevelDefault() - ? (Settings::IsGPULevelMedium() || Settings::IsGPULevelHigh()) - : Settings::IsDMALevelSafe()) { - Tegra::Memory::GpuGuestMemory - headers(memory_manager, dma_state.dma_get, header.size, &command_headers); - ProcessCommands(headers); - } else { - Tegra::Memory::GpuGuestMemory - headers(memory_manager, dma_state.dma_get, header.size, &command_headers); - ProcessCommands(headers); - } - } + Tegra::Memory::GpuGuestMemoryheaders(memory_manager, dma_state.dma_get, header.size, &command_headers); + ProcessCommands(headers); } if (++dma_pushbuffer_subindex >= command_list_size) {