2022-04-23 20:49:07 +02:00
|
|
|
// SPDX-FileCopyrightText: Copyright 2019 yuzu Emulator Project
|
|
|
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
2020-12-28 16:15:37 +01:00
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
2021-03-03 03:38:05 +01:00
|
|
|
#include <array>
|
|
|
|
#include <atomic>
|
2020-12-28 16:15:37 +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;
|
|
|
|
|
|
|
|
void UpdatePagesCachedCount(VAddr addr, u64 size, int delta) override;
|
|
|
|
|
|
|
|
private:
|
2021-03-03 03:38:05 +01:00
|
|
|
class CacheEntry final {
|
|
|
|
public:
|
|
|
|
CacheEntry() = default;
|
|
|
|
|
2021-05-28 01:49:55 +02:00
|
|
|
std::atomic_uint16_t& Count(std::size_t page) {
|
|
|
|
return values[page & 3];
|
2021-03-03 03:38:05 +01:00
|
|
|
}
|
|
|
|
|
2021-05-28 01:49:55 +02:00
|
|
|
const std::atomic_uint16_t& Count(std::size_t page) const {
|
|
|
|
return values[page & 3];
|
2021-03-03 03:38:05 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
2021-05-28 01:49:55 +02:00
|
|
|
std::array<std::atomic_uint16_t, 4> values{};
|
2021-03-03 03:38:05 +01:00
|
|
|
};
|
|
|
|
static_assert(sizeof(CacheEntry) == 8, "CacheEntry should be 8 bytes!");
|
2020-12-28 16:15:37 +01:00
|
|
|
|
2021-10-05 01:33:40 +02:00
|
|
|
std::array<CacheEntry, 0x2000000> cached_pages;
|
2020-12-28 16:15:37 +01:00
|
|
|
Core::Memory::Memory& cpu_memory;
|
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace VideoCore
|