also use vastcpy for shared memory page stuff
This commit is contained in:
parent
f31869092c
commit
78c9a48bc2
|
@ -406,7 +406,8 @@ bool D3D12SharedMemory::AllocateSparseHostGpuMemoryRange(
|
|||
}
|
||||
|
||||
bool D3D12SharedMemory::UploadRanges(
|
||||
const std::pair<uint32_t, uint32_t>* upload_page_ranges, unsigned num_upload_page_ranges) {
|
||||
const std::pair<uint32_t, uint32_t>* upload_page_ranges,
|
||||
unsigned num_upload_page_ranges) {
|
||||
if (!num_upload_page_ranges) {
|
||||
return true;
|
||||
}
|
||||
|
@ -434,10 +435,20 @@ bool D3D12SharedMemory::UploadRanges(
|
|||
}
|
||||
MakeRangeValid(upload_range_start << page_size_log2(),
|
||||
uint32_t(upload_buffer_size), false, false);
|
||||
std::memcpy(
|
||||
|
||||
if (upload_buffer_size < (1ULL << 32) && upload_buffer_size > 8192) {
|
||||
dma::vastcpy(
|
||||
upload_buffer_mapping,
|
||||
memory().TranslatePhysical(upload_range_start << page_size_log2()),
|
||||
static_cast<uint32_t>(upload_buffer_size));
|
||||
swcache::WriteFence();
|
||||
|
||||
} else {
|
||||
memcpy(
|
||||
upload_buffer_mapping,
|
||||
memory().TranslatePhysical(upload_range_start << page_size_log2()),
|
||||
upload_buffer_size);
|
||||
}
|
||||
command_list.D3DCopyBufferRegion(
|
||||
buffer_, upload_range_start << page_size_log2(), upload_buffer,
|
||||
UINT64(upload_buffer_offset), UINT64(upload_buffer_size));
|
||||
|
|
Loading…
Reference in New Issue