mirror of
https://git.eden-emu.dev/eden-emu/eden
synced 2026-04-10 07:38:56 +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 (Settings::getDebugKnobAt(0)) {
|
||||
const size_t command_bytes = static_cast<size_t>(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::GpuGuestMemory<Tegra::CommandHeader, Tegra::Memory::GuestMemoryFlags::SafeRead>headers(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<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);
|
||||
}
|
||||
}
|
||||
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) {
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue