mirror of
https://git.eden-emu.dev/eden-emu/eden
synced 2026-05-19 03:27:00 +02:00
Update src/video_core/dma_pusher.cpp
dropped slow method. retrying sharp ComputeInline filter Signed-off-by: xbzk <xbzk@eden-emu.dev>
This commit is contained in:
parent
8a7239d43f
commit
7bb61a2101
1 changed files with 5 additions and 31 deletions
|
|
@ -83,38 +83,12 @@ bool DmaPusher::Step() {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (header.size > 0) {
|
if (header.size > 0) {
|
||||||
if (Settings::getDebugKnobAt(0)) {
|
if (dma_state.method == ComputeInline || (Settings::IsDMALevelDefault() ? Settings::IsGPULevelLow() : 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)) {
|
|
||||||
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);
|
|
||||||
} else {
|
} else {
|
||||||
if (Settings::IsDMALevelDefault()
|
Tegra::Memory::GpuGuestMemory<Tegra::CommandHeader, Tegra::Memory::GuestMemoryFlags::UnsafeRead>headers(memory_manager, dma_state.dma_get, header.size, &command_headers);
|
||||||
? (Settings::IsGPULevelMedium() || Settings::IsGPULevelHigh())
|
ProcessCommands(headers);
|
||||||
: Settings::IsDMALevelSafe()) {
|
|
||||||
Tegra::Memory::GpuGuestMemory<Tegra::CommandHeader,
|
|
||||||
Tegra::Memory::GuestMemoryFlags::SafeRead>
|
|
||||||
headers(memory_manager, dma_state.dma_get, header.size, &command_headers);
|
|
||||||
ProcessCommands(headers);
|
|
||||||
} else {
|
|
||||||
Tegra::Memory::GpuGuestMemory<Tegra::CommandHeader,
|
|
||||||
Tegra::Memory::GuestMemoryFlags::UnsafeRead>
|
|
||||||
headers(memory_manager, dma_state.dma_get, header.size, &command_headers);
|
|
||||||
ProcessCommands(headers);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (++dma_pushbuffer_subindex >= command_list_size) {
|
if (++dma_pushbuffer_subindex >= command_list_size) {
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue