DmaPusher::Step (endermag dash2crash fix)
This commit is contained in:
parent
50ec0892c6
commit
5d268b1321
|
|
@ -83,13 +83,21 @@ bool DmaPusher::Step() {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (header.size > 0) {
|
if (header.size > 0) {
|
||||||
if (Settings::IsDMALevelDefault() ? (Settings::IsGPULevelMedium() || Settings::IsGPULevelHigh()) : Settings::IsDMALevelSafe()) {
|
const size_t command_bytes = static_cast<size_t>(header.size) * sizeof(CommandHeader);
|
||||||
Tegra::Memory::GpuGuestMemory<Tegra::CommandHeader, Tegra::Memory::GuestMemoryFlags::SafeRead>headers(memory_manager, dma_state.dma_get, header.size, &command_headers);
|
|
||||||
ProcessCommands(headers);
|
if (memory_manager.IsMemoryDirty(dma_state.dma_get, command_bytes)) {
|
||||||
} else {
|
memory_manager.FlushRegion(dma_state.dma_get, command_bytes);
|
||||||
Tegra::Memory::GpuGuestMemory<Tegra::CommandHeader, Tegra::Memory::GuestMemoryFlags::UnsafeRead>headers(memory_manager, dma_state.dma_get, header.size, &command_headers);
|
|
||||||
ProcessCommands(headers);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
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_pushbuffer_subindex >= command_list_size) {
|
if (++dma_pushbuffer_subindex >= command_list_size) {
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue