early-access version 1879
This commit is contained in:
@@ -550,10 +550,6 @@ bool BufferCache<P>::DMACopy(GPUVAddr src_address, GPUVAddr dest_address, u64 am
|
||||
auto& src_buffer = slot_buffers[buffer_a];
|
||||
auto& dest_buffer = slot_buffers[buffer_b];
|
||||
SynchronizeBuffer(src_buffer, *cpu_src_address, static_cast<u32>(amount));
|
||||
const VAddr aligned_dst = Common::AlignUp(*cpu_dest_address, 64);
|
||||
const u64 align_diff = aligned_dst - *cpu_dest_address;
|
||||
const u64 new_amount = align_diff > amount ? 0 : amount - align_diff;
|
||||
dest_buffer.UnmarkRegionAsCpuModified(aligned_dst, Common::AlignDown(new_amount, 64));
|
||||
SynchronizeBuffer(dest_buffer, *cpu_dest_address, static_cast<u32>(amount));
|
||||
std::array copies{BufferCopy{
|
||||
.src_offset = src_buffer.Offset(*cpu_src_address),
|
||||
@@ -610,10 +606,12 @@ bool BufferCache<P>::DMAClear(GPUVAddr dst_address, u64 amount, u32 value) {
|
||||
buffer = FindBuffer(*cpu_dst_address, static_cast<u32>(size));
|
||||
} while (has_deleted_buffers);
|
||||
|
||||
const VAddr aligned_dst = Common::AlignUp(*cpu_dst_address, 64);
|
||||
const u64 align_diff = aligned_dst - *cpu_dst_address;
|
||||
const u64 new_amount = align_diff > size ? 0 : size - align_diff;
|
||||
auto& dest_buffer = slot_buffers[buffer];
|
||||
const u32 offset = static_cast<u32>(*cpu_dst_address - dest_buffer.CpuAddr());
|
||||
runtime.ClearBuffer(dest_buffer, offset, size, value);
|
||||
dest_buffer.UnmarkRegionAsCpuModified(*cpu_dst_address, size);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user