Merge pull request #11771 from lioncash/linear

Common/LinearDiskCache: Move interface into Common namespace
This commit is contained in:
JosJuice 2023-04-19 17:45:43 +02:00 committed by GitHub
commit 6d8cabac49
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 17 additions and 14 deletions

View File

@ -27,6 +27,8 @@
// value_type[value_size] value; // value_type[value_size] value;
//} //}
namespace Common
{
template <typename K, typename V> template <typename K, typename V>
class LinearDiskCacheReader class LinearDiskCacheReader
{ {
@ -163,3 +165,4 @@ private:
File::IOFile m_file; File::IOFile m_file;
u32 m_num_entries = 0; u32 m_num_entries = 0;
}; };
} // namespace Common

View File

@ -473,7 +473,7 @@ void ObjectCache::DestroyRenderPassCache()
m_render_pass_cache.clear(); m_render_pass_cache.clear();
} }
class PipelineCacheReadCallback : public LinearDiskCacheReader<u32, u8> class PipelineCacheReadCallback : public Common::LinearDiskCacheReader<u32, u8>
{ {
public: public:
PipelineCacheReadCallback(std::vector<u8>* data) : m_data(data) {} PipelineCacheReadCallback(std::vector<u8>* data) : m_data(data) {}
@ -488,7 +488,7 @@ private:
std::vector<u8>* m_data; std::vector<u8>* m_data;
}; };
class PipelineCacheReadIgnoreCallback : public LinearDiskCacheReader<u32, u8> class PipelineCacheReadIgnoreCallback : public Common::LinearDiskCacheReader<u32, u8>
{ {
public: public:
void Read(const u32& key, const u8* value, u32 value_size) override {} void Read(const u32& key, const u8* value, u32 value_size) override {}
@ -525,7 +525,7 @@ bool ObjectCache::LoadPipelineCache()
m_pipeline_cache_filename = GetDiskShaderCacheFileName(APIType::Vulkan, "Pipeline", false, true); m_pipeline_cache_filename = GetDiskShaderCacheFileName(APIType::Vulkan, "Pipeline", false, true);
std::vector<u8> disk_data; std::vector<u8> disk_data;
LinearDiskCache<u32, u8> disk_cache; Common::LinearDiskCache<u32, u8> disk_cache;
PipelineCacheReadCallback read_callback(&disk_data); PipelineCacheReadCallback read_callback(&disk_data);
if (disk_cache.OpenAndRead(m_pipeline_cache_filename, read_callback) != 1) if (disk_cache.OpenAndRead(m_pipeline_cache_filename, read_callback) != 1)
disk_data.clear(); disk_data.clear();
@ -651,7 +651,7 @@ void ObjectCache::SavePipelineCache()
// We write a single key of 1, with the entire pipeline cache data. // We write a single key of 1, with the entire pipeline cache data.
// Not ideal, but our disk cache class does not support just writing a single blob // Not ideal, but our disk cache class does not support just writing a single blob
// of data without specifying a key. // of data without specifying a key.
LinearDiskCache<u32, u8> disk_cache; Common::LinearDiskCache<u32, u8> disk_cache;
PipelineCacheReadIgnoreCallback callback; PipelineCacheReadIgnoreCallback callback;
disk_cache.OpenAndRead(m_pipeline_cache_filename, callback); disk_cache.OpenAndRead(m_pipeline_cache_filename, callback);
disk_cache.Append(1, data.data(), static_cast<u32>(data.size())); disk_cache.Append(1, data.data(), static_cast<u32>(data.size()));

View File

@ -228,11 +228,11 @@ static void UnserializePipelineUid(const SerializedUidType& uid, UidType& real_u
template <ShaderStage stage, typename K, typename T> template <ShaderStage stage, typename K, typename T>
void ShaderCache::LoadShaderCache(T& cache, APIType api_type, const char* type, bool include_gameid) void ShaderCache::LoadShaderCache(T& cache, APIType api_type, const char* type, bool include_gameid)
{ {
class CacheReader : public LinearDiskCacheReader<K, u8> class CacheReader : public Common::LinearDiskCacheReader<K, u8>
{ {
public: public:
CacheReader(T& cache_) : cache(cache_) {} CacheReader(T& cache_) : cache(cache_) {}
void Read(const K& key, const u8* value, u32 value_size) void Read(const K& key, const u8* value, u32 value_size) override
{ {
auto shader = g_gfx->CreateShaderFromBinary(stage, value, value_size); auto shader = g_gfx->CreateShaderFromBinary(stage, value, value_size);
if (shader) if (shader)
@ -276,15 +276,15 @@ void ShaderCache::ClearShaderCache(T& cache)
} }
template <typename KeyType, typename DiskKeyType, typename T> template <typename KeyType, typename DiskKeyType, typename T>
void ShaderCache::LoadPipelineCache(T& cache, LinearDiskCache<DiskKeyType, u8>& disk_cache, void ShaderCache::LoadPipelineCache(T& cache, Common::LinearDiskCache<DiskKeyType, u8>& disk_cache,
APIType api_type, const char* type, bool include_gameid) APIType api_type, const char* type, bool include_gameid)
{ {
class CacheReader : public LinearDiskCacheReader<DiskKeyType, u8> class CacheReader : public Common::LinearDiskCacheReader<DiskKeyType, u8>
{ {
public: public:
CacheReader(ShaderCache* this_ptr_, T& cache_) : this_ptr(this_ptr_), cache(cache_) {} CacheReader(ShaderCache* this_ptr_, T& cache_) : this_ptr(this_ptr_), cache(cache_) {}
bool AnyFailed() const { return failed; } bool AnyFailed() const { return failed; }
void Read(const DiskKeyType& key, const u8* value, u32 value_size) void Read(const DiskKeyType& key, const u8* value, u32 value_size) override
{ {
KeyType real_uid; KeyType real_uid;
UnserializePipelineUid(key, real_uid); UnserializePipelineUid(key, real_uid);

View File

@ -176,8 +176,8 @@ private:
template <typename T> template <typename T>
void ClearShaderCache(T& cache); void ClearShaderCache(T& cache);
template <typename KeyType, typename DiskKeyType, typename T> template <typename KeyType, typename DiskKeyType, typename T>
void LoadPipelineCache(T& cache, LinearDiskCache<DiskKeyType, u8>& disk_cache, APIType api_type, void LoadPipelineCache(T& cache, Common::LinearDiskCache<DiskKeyType, u8>& disk_cache,
const char* type, bool include_gameid); APIType api_type, const char* type, bool include_gameid);
template <typename T, typename Y> template <typename T, typename Y>
void ClearPipelineCache(T& cache, Y& disk_cache); void ClearPipelineCache(T& cache, Y& disk_cache);
@ -216,7 +216,7 @@ private:
bool pending = false; bool pending = false;
}; };
std::map<Uid, Shader> shader_map; std::map<Uid, Shader> shader_map;
LinearDiskCache<Uid, u8> disk_cache; Common::LinearDiskCache<Uid, u8> disk_cache;
}; };
ShaderModuleCache<VertexShaderUid> m_vs_cache; ShaderModuleCache<VertexShaderUid> m_vs_cache;
ShaderModuleCache<GeometryShaderUid> m_gs_cache; ShaderModuleCache<GeometryShaderUid> m_gs_cache;
@ -229,8 +229,8 @@ private:
std::map<GXUberPipelineUid, std::pair<std::unique_ptr<AbstractPipeline>, bool>> std::map<GXUberPipelineUid, std::pair<std::unique_ptr<AbstractPipeline>, bool>>
m_gx_uber_pipeline_cache; m_gx_uber_pipeline_cache;
File::IOFile m_gx_pipeline_uid_cache_file; File::IOFile m_gx_pipeline_uid_cache_file;
LinearDiskCache<SerializedGXPipelineUid, u8> m_gx_pipeline_disk_cache; Common::LinearDiskCache<SerializedGXPipelineUid, u8> m_gx_pipeline_disk_cache;
LinearDiskCache<SerializedGXUberPipelineUid, u8> m_gx_uber_pipeline_disk_cache; Common::LinearDiskCache<SerializedGXUberPipelineUid, u8> m_gx_uber_pipeline_disk_cache;
// EFB copy to VRAM/RAM pipelines // EFB copy to VRAM/RAM pipelines
std::map<TextureConversionShaderGen::TCShaderUid, std::unique_ptr<AbstractPipeline>> std::map<TextureConversionShaderGen::TCShaderUid, std::unique_ptr<AbstractPipeline>>