diff options
| author | Fernando Sahmkow <fsahmkow27@gmail.com> | 2019-04-15 23:05:05 -0400 | 
|---|---|---|
| committer | FernandoS27 <fsahmkow27@gmail.com> | 2019-04-15 23:10:24 -0400 | 
| commit | ef381e6924ee28162d3ce1cff0523ea7a88981d2 (patch) | |
| tree | 59967fcddc8f7c4586818dea3378c924cd53d426 /src/video_core | |
| parent | 367704aa829a515188d87860ffd230b1b2a136c8 (diff) | |
Use ReadBlockUnsafe on TIC and TSC reading
Use ReadBlockUnsafe on TIC and TSC reading as memory is never flushed
from host GPU there.
Diffstat (limited to 'src/video_core')
| -rw-r--r-- | src/video_core/engines/maxwell_3d.cpp | 4 | ||||
| -rw-r--r-- | src/video_core/memory_manager.cpp | 2 | 
2 files changed, 4 insertions, 2 deletions
| diff --git a/src/video_core/engines/maxwell_3d.cpp b/src/video_core/engines/maxwell_3d.cpp index 74403eed4..69401fcda 100644 --- a/src/video_core/engines/maxwell_3d.cpp +++ b/src/video_core/engines/maxwell_3d.cpp @@ -418,7 +418,7 @@ Texture::TICEntry Maxwell3D::GetTICEntry(u32 tic_index) const {      const GPUVAddr tic_address_gpu{regs.tic.TICAddress() + tic_index * sizeof(Texture::TICEntry)};      Texture::TICEntry tic_entry; -    memory_manager.ReadBlock(tic_address_gpu, &tic_entry, sizeof(Texture::TICEntry)); +    memory_manager.ReadBlockUnsafe(tic_address_gpu, &tic_entry, sizeof(Texture::TICEntry));      ASSERT_MSG(tic_entry.header_version == Texture::TICHeaderVersion::BlockLinear ||                     tic_entry.header_version == Texture::TICHeaderVersion::Pitch, @@ -439,7 +439,7 @@ Texture::TSCEntry Maxwell3D::GetTSCEntry(u32 tsc_index) const {      const GPUVAddr tsc_address_gpu{regs.tsc.TSCAddress() + tsc_index * sizeof(Texture::TSCEntry)};      Texture::TSCEntry tsc_entry; -    memory_manager.ReadBlock(tsc_address_gpu, &tsc_entry, sizeof(Texture::TSCEntry)); +    memory_manager.ReadBlockUnsafe(tsc_address_gpu, &tsc_entry, sizeof(Texture::TSCEntry));      return tsc_entry;  } diff --git a/src/video_core/memory_manager.cpp b/src/video_core/memory_manager.cpp index 3b9f6caf0..20d744c61 100644 --- a/src/video_core/memory_manager.cpp +++ b/src/video_core/memory_manager.cpp @@ -234,6 +234,7 @@ void MemoryManager::ReadBlockUnsafe(GPUVAddr src_addr, void* dest_buffer, std::s      while (remaining_size > 0) {          const std::size_t copy_amount{              std::min(static_cast<std::size_t>(page_size) - page_offset, remaining_size)}; +        const u8* src_ptr{page_table.pointers[page_index] + page_offset};          std::memcpy(dest_buffer, src_ptr, copy_amount);          page_index++;          page_offset = 0; @@ -277,6 +278,7 @@ void MemoryManager::WriteBlockUnsafe(GPUVAddr dest_addr, const void* src_buffer,      while (remaining_size > 0) {          const std::size_t copy_amount{              std::min(static_cast<std::size_t>(page_size) - page_offset, remaining_size)}; +        u8* dest_ptr{page_table.pointers[page_index] + page_offset};          std::memcpy(dest_ptr, src_buffer, copy_amount);          page_index++;          page_offset = 0; | 
