2019-10-26 23:40:08 -07:00
|
|
|
// Copyright 2019 yuzu Emulator Project
|
|
|
|
// Licensed under GPLv2 or any later version
|
|
|
|
// Refer to the license.txt file included.
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
2021-03-02 16:57:53 -08:00
|
|
|
#include <array>
|
|
|
|
#include <atomic>
|
2019-10-26 23:40:08 -07:00
|
|
|
|
|
|
|
#include "common/common_types.h"
|
|
|
|
#include "video_core/rasterizer_interface.h"
|
|
|
|
|
2020-03-31 12:10:44 -07:00
|
|
|
namespace Core::Memory {
|
2019-11-26 11:10:49 -08:00
|
|
|
class Memory;
|
|
|
|
}
|
|
|
|
|
2019-10-26 23:40:08 -07:00
|
|
|
namespace VideoCore {
|
|
|
|
|
|
|
|
/// Implements the shared part in GPU accelerated rasterizers in RasterizerInterface.
|
|
|
|
class RasterizerAccelerated : public RasterizerInterface {
|
|
|
|
public:
|
2020-03-31 12:10:44 -07:00
|
|
|
explicit RasterizerAccelerated(Core::Memory::Memory& cpu_memory_);
|
2019-10-26 23:40:08 -07:00
|
|
|
~RasterizerAccelerated() override;
|
|
|
|
|
|
|
|
void UpdatePagesCachedCount(VAddr addr, u64 size, int delta) override;
|
|
|
|
|
|
|
|
private:
|
2021-03-02 16:57:53 -08:00
|
|
|
class CacheEntry final {
|
|
|
|
public:
|
|
|
|
CacheEntry() = default;
|
|
|
|
|
2021-05-27 14:47:24 -07:00
|
|
|
std::atomic_uint16_t& Count(std::size_t page) {
|
|
|
|
return values[page & 3];
|
2021-03-02 16:57:53 -08:00
|
|
|
}
|
|
|
|
|
2021-05-27 14:47:24 -07:00
|
|
|
const std::atomic_uint16_t& Count(std::size_t page) const {
|
|
|
|
return values[page & 3];
|
2021-03-02 16:57:53 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
2021-05-27 14:47:24 -07:00
|
|
|
std::array<std::atomic_uint16_t, 4> values{};
|
2021-03-02 16:57:53 -08:00
|
|
|
};
|
|
|
|
static_assert(sizeof(CacheEntry) == 8, "CacheEntry should be 8 bytes!");
|
2019-11-26 11:10:49 -08:00
|
|
|
|
2021-05-27 14:47:24 -07:00
|
|
|
std::array<CacheEntry, 0x1000000> cached_pages;
|
2020-03-31 12:10:44 -07:00
|
|
|
Core::Memory::Memory& cpu_memory;
|
2019-10-26 23:40:08 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace VideoCore
|