diff options
| author | Liam <byteslice@airmail.cc> | 2024-02-12 20:02:53 -0500 | 
|---|---|---|
| committer | Liam <byteslice@airmail.cc> | 2024-02-12 20:02:59 -0500 | 
| commit | 461eaca7e83e45a311a1d92a2de6d6a54b2405ab (patch) | |
| tree | ac8971f2ec89d1f1979901533ed041e4ae98cf80 | |
| parent | 2ff45cd0da941dce2564f5c18c580d0283da27bf (diff) | |
device_memory_manager: skip unregistered interfaces on invalidate
| -rw-r--r-- | src/core/device_memory_manager.inc | 12 | 
1 files changed, 8 insertions, 4 deletions
diff --git a/src/core/device_memory_manager.inc b/src/core/device_memory_manager.inc index 6dfee806c..d636621de 100644 --- a/src/core/device_memory_manager.inc +++ b/src/core/device_memory_manager.inc @@ -522,13 +522,17 @@ void DeviceMemoryManager<Traits>::UpdatePagesCachedCount(DAddr addr, size_t size      auto* memory_device_inter = registered_processes[asid.id];      const auto release_pending = [&] {          if (uncache_bytes > 0) { -            MarkRegionCaching(memory_device_inter, uncache_begin << Memory::YUZU_PAGEBITS, -                              uncache_bytes, false); +            if (memory_device_inter != nullptr) { +                MarkRegionCaching(memory_device_inter, uncache_begin << Memory::YUZU_PAGEBITS, +                                  uncache_bytes, false); +            }              uncache_bytes = 0;          }          if (cache_bytes > 0) { -            MarkRegionCaching(memory_device_inter, cache_begin << Memory::YUZU_PAGEBITS, -                              cache_bytes, true); +            if (memory_device_inter != nullptr) { +                MarkRegionCaching(memory_device_inter, cache_begin << Memory::YUZU_PAGEBITS, +                                  cache_bytes, true); +            }              cache_bytes = 0;          }      };  | 
