summaryrefslogtreecommitdiffstats
path: root/src/video_core/rasterizer_accelerated.h
diff options
context:
space:
mode:
authorFernando S <fsahmkow27@gmail.com>2023-12-19 16:14:09 +0100
committerGitHub <noreply@github.com>2023-12-19 16:14:09 +0100
commit97ad3e75304fdf604e7619986388df9d659c3e52 (patch)
treeea5ca8448da392fc0a66d5019a694b5bff3a2013 /src/video_core/rasterizer_accelerated.h
parentMerge pull request #12304 from liamwhite/flinger-wtf (diff)
parentRevert "video_core: use interval map for page count tracking" (diff)
downloadyuzu-97ad3e75304fdf604e7619986388df9d659c3e52.tar
yuzu-97ad3e75304fdf604e7619986388df9d659c3e52.tar.gz
yuzu-97ad3e75304fdf604e7619986388df9d659c3e52.tar.bz2
yuzu-97ad3e75304fdf604e7619986388df9d659c3e52.tar.lz
yuzu-97ad3e75304fdf604e7619986388df9d659c3e52.tar.xz
yuzu-97ad3e75304fdf604e7619986388df9d659c3e52.tar.zst
yuzu-97ad3e75304fdf604e7619986388df9d659c3e52.zip
Diffstat (limited to 'src/video_core/rasterizer_accelerated.h')
-rw-r--r--src/video_core/rasterizer_accelerated.h29
1 files changed, 20 insertions, 9 deletions
diff --git a/src/video_core/rasterizer_accelerated.h b/src/video_core/rasterizer_accelerated.h
index f1968f186..e6c0ea87a 100644
--- a/src/video_core/rasterizer_accelerated.h
+++ b/src/video_core/rasterizer_accelerated.h
@@ -3,8 +3,8 @@
#pragma once
-#include <mutex>
-#include <boost/icl/interval_map.hpp>
+#include <array>
+#include <atomic>
#include "common/common_types.h"
#include "video_core/rasterizer_interface.h"
@@ -21,17 +21,28 @@ public:
explicit RasterizerAccelerated(Core::Memory::Memory& cpu_memory_);
~RasterizerAccelerated() override;
- void UpdatePagesCachedCount(VAddr addr, u64 size, bool cache) override;
+ void UpdatePagesCachedCount(VAddr addr, u64 size, int delta) override;
private:
- using PageIndex = VAddr;
- using PageReferenceCount = u16;
+ class CacheEntry final {
+ public:
+ CacheEntry() = default;
- using IntervalMap = boost::icl::interval_map<PageIndex, PageReferenceCount>;
- using IntervalType = IntervalMap::interval_type;
+ std::atomic_uint16_t& Count(std::size_t page) {
+ return values[page & 3];
+ }
- IntervalMap map;
- std::mutex map_lock;
+ const std::atomic_uint16_t& Count(std::size_t page) const {
+ return values[page & 3];
+ }
+
+ private:
+ std::array<std::atomic_uint16_t, 4> values{};
+ };
+ static_assert(sizeof(CacheEntry) == 8, "CacheEntry should be 8 bytes!");
+
+ using CachedPages = std::array<CacheEntry, 0x2000000>;
+ std::unique_ptr<CachedPages> cached_pages;
Core::Memory::Memory& cpu_memory;
};