2022-11-05 13:58:44 +01:00
|
|
|
// SPDX-FileCopyrightText: Copyright 2019 yuzu Emulator Project
|
|
|
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
2023-12-19 22:36:20 +01:00
|
|
|
#include <array>
|
|
|
|
#include <atomic>
|
2022-11-05 13:58:44 +01:00
|
|
|
|
|
|
|
#include "common/common_types.h"
|
|
|
|
#include "video_core/rasterizer_interface.h"
|
|
|
|
|
|
|
|
namespace Core::Memory {
|
|
|
|
class Memory;
|
|
|
|
}
|
|
|
|
|
|
|
|
namespace VideoCore {
|
|
|
|
|
|
|
|
/// Implements the shared part in GPU accelerated rasterizers in RasterizerInterface.
|
|
|
|
class RasterizerAccelerated : public RasterizerInterface {
|
|
|
|
public:
|
|
|
|
explicit RasterizerAccelerated(Core::Memory::Memory& cpu_memory_);
|
|
|
|
~RasterizerAccelerated() override;
|
|
|
|
|
2023-12-19 22:36:20 +01:00
|
|
|
void UpdatePagesCachedCount(VAddr addr, u64 size, int delta) override;
|
2022-11-05 13:58:44 +01:00
|
|
|
|
|
|
|
private:
|
2023-12-19 22:36:20 +01:00
|
|
|
class CacheEntry final {
|
|
|
|
public:
|
|
|
|
CacheEntry() = default;
|
2022-11-05 13:58:44 +01:00
|
|
|
|
2023-12-19 22:36:20 +01:00
|
|
|
std::atomic_uint16_t& Count(std::size_t page) {
|
|
|
|
return values[page & 3];
|
|
|
|
}
|
2022-11-05 13:58:44 +01:00
|
|
|
|
2023-12-19 22:36:20 +01:00
|
|
|
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;
|
2022-11-05 13:58:44 +01:00
|
|
|
Core::Memory::Memory& cpu_memory;
|
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace VideoCore
|