summaryrefslogtreecommitdiffstats
path: root/src/video_core/memory_manager.cpp
diff options
context:
space:
mode:
authorFernando Sahmkow <fsahmkow27@gmail.com>2019-04-20 02:35:54 +0200
committerFernando Sahmkow <fsahmkow27@gmail.com>2019-04-20 02:35:54 +0200
commitdb4b2bc798388fd22d3ea60eb82c5f894b2b3506 (patch)
tree76bba32ad408596e82d1d3394c269ba723b91d59 /src/video_core/memory_manager.cpp
parentImplement IsBlockContinous (diff)
downloadyuzu-db4b2bc798388fd22d3ea60eb82c5f894b2b3506.tar
yuzu-db4b2bc798388fd22d3ea60eb82c5f894b2b3506.tar.gz
yuzu-db4b2bc798388fd22d3ea60eb82c5f894b2b3506.tar.bz2
yuzu-db4b2bc798388fd22d3ea60eb82c5f894b2b3506.tar.lz
yuzu-db4b2bc798388fd22d3ea60eb82c5f894b2b3506.tar.xz
yuzu-db4b2bc798388fd22d3ea60eb82c5f894b2b3506.tar.zst
yuzu-db4b2bc798388fd22d3ea60eb82c5f894b2b3506.zip
Diffstat (limited to 'src/video_core/memory_manager.cpp')
-rw-r--r--src/video_core/memory_manager.cpp16
1 files changed, 12 insertions, 4 deletions
diff --git a/src/video_core/memory_manager.cpp b/src/video_core/memory_manager.cpp
index 095a7e5a4..6c98c6701 100644
--- a/src/video_core/memory_manager.cpp
+++ b/src/video_core/memory_manager.cpp
@@ -243,8 +243,13 @@ void MemoryManager::ReadBlockUnsafe(GPUVAddr src_addr, void* dest_buffer,
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);
+ const u8* page_pointer = page_table.pointers[page_index];
+ if (page_pointer) {
+ const u8* src_ptr{page_pointer + page_offset};
+ std::memcpy(dest_buffer, src_ptr, copy_amount);
+ } else {
+ std::memset(dest_buffer, 0, copy_amount);
+ }
page_index++;
page_offset = 0;
dest_buffer = static_cast<u8*>(dest_buffer) + copy_amount;
@@ -288,8 +293,11 @@ 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);
+ u8* page_pointer = page_table.pointers[page_index];
+ if (page_pointer) {
+ u8* dest_ptr{page_pointer + page_offset};
+ std::memcpy(dest_ptr, src_buffer, copy_amount);
+ }
page_index++;
page_offset = 0;
src_buffer = static_cast<const u8*>(src_buffer) + copy_amount;