aboutsummaryrefslogtreecommitdiff
path: root/src/video_core/rasterizer_accelerated.h
diff options
context:
space:
mode:
authorbunnei <bunneidev@gmail.com>2021-03-12 21:57:27 -0800
committerGitHub <noreply@github.com>2021-03-12 21:57:27 -0800
commit4735d18bb96b2f22fc463dae6e591f13e69cfde1 (patch)
treed2c80ae83a8298da1fb25f422cdb8392b2cab81e /src/video_core/rasterizer_accelerated.h
parent5dae45b958908fedb4fb55def3d5ee5ad51f8266 (diff)
parenta9d24b0df36b7e3bb5e8f5e71f3b6a9a2485f44b (diff)
Merge pull request #6028 from bunnei/raster-cache
video_core: rasterizer_accelerated: Use a flat array instead of interval_map for cached pages.
Diffstat (limited to 'src/video_core/rasterizer_accelerated.h')
-rw-r--r--src/video_core/rasterizer_accelerated.h25
1 files changed, 19 insertions, 6 deletions
diff --git a/src/video_core/rasterizer_accelerated.h b/src/video_core/rasterizer_accelerated.h
index 91866d7dd..9227a4adc 100644
--- a/src/video_core/rasterizer_accelerated.h
+++ b/src/video_core/rasterizer_accelerated.h
@@ -4,9 +4,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"
@@ -26,10 +25,24 @@ public:
void UpdatePagesCachedCount(VAddr addr, u64 size, int delta) override;
private:
- using CachedPageMap = boost::icl::interval_map<u64, int>;
- CachedPageMap cached_pages;
- std::mutex pages_mutex;
+ class CacheEntry final {
+ public:
+ CacheEntry() = default;
+
+ std::atomic_uint8_t& Count(std::size_t page) {
+ return values[page & 7];
+ }
+
+ const std::atomic_uint8_t& Count(std::size_t page) const {
+ return values[page & 7];
+ }
+
+ private:
+ std::array<std::atomic_uint8_t, 8> values{};
+ };
+ static_assert(sizeof(CacheEntry) == 8, "CacheEntry should be 8 bytes!");
+ std::array<CacheEntry, 0x800000> cached_pages;
Core::Memory::Memory& cpu_memory;
};