diff options
author | Liam <byteslice@airmail.cc> | 2023-12-12 17:15:52 -0500 |
---|---|---|
committer | Liam <byteslice@airmail.cc> | 2023-12-14 21:54:36 -0500 |
commit | 030e6b3980aa5ce6069041c339d49d21d68ca73b (patch) | |
tree | 428a3d3a1e322a4cfad696bdcd756dd7332acefa /src/tests/video_core | |
parent | 462ba1b360c4c314d5ae57cbe6df240562664f8c (diff) |
video_core: use interval map for page count tracking
Diffstat (limited to 'src/tests/video_core')
-rw-r--r-- | src/tests/video_core/memory_tracker.cpp | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/src/tests/video_core/memory_tracker.cpp b/src/tests/video_core/memory_tracker.cpp index 618793668..2dbff21af 100644 --- a/src/tests/video_core/memory_tracker.cpp +++ b/src/tests/video_core/memory_tracker.cpp @@ -23,13 +23,13 @@ constexpr VAddr c = 16 * HIGH_PAGE_SIZE; class RasterizerInterface { public: - void UpdatePagesCachedCount(VAddr addr, u64 size, int delta) { + void UpdatePagesCachedCount(VAddr addr, u64 size, bool cache) { const u64 page_start{addr >> Core::Memory::YUZU_PAGEBITS}; const u64 page_end{(addr + size + Core::Memory::YUZU_PAGESIZE - 1) >> Core::Memory::YUZU_PAGEBITS}; for (u64 page = page_start; page < page_end; ++page) { int& value = page_table[page]; - value += delta; + value += (cache ? 1 : -1); if (value < 0) { throw std::logic_error{"negative page"}; } @@ -546,4 +546,4 @@ TEST_CASE("MemoryTracker: Cached write downloads") { REQUIRE(!memory_track->IsRegionGpuModified(c + PAGE, PAGE)); memory_track->MarkRegionAsCpuModified(c, WORD); REQUIRE(rasterizer.Count() == 0); -}
\ No newline at end of file +} |