diff options
author | Fernando S <fsahmkow27@gmail.com> | 2023-12-19 16:14:09 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-12-19 16:14:09 +0100 |
commit | 97ad3e75304fdf604e7619986388df9d659c3e52 (patch) | |
tree | ea5ca8448da392fc0a66d5019a694b5bff3a2013 /src/video_core/rasterizer_accelerated.h | |
parent | Merge pull request #12304 from liamwhite/flinger-wtf (diff) | |
parent | Revert "video_core: use interval map for page count tracking" (diff) | |
download | yuzu-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.h | 29 |
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; }; |