Renderers: Support empty shader cache
This commit is contained in:
parent
f396a2c373
commit
9b3e344ad8
|
@ -47,12 +47,15 @@ void ShaderCache::Open(std::string_view base_path, D3D_FEATURE_LEVEL feature_lev
|
||||||
m_feature_level = feature_level;
|
m_feature_level = feature_level;
|
||||||
m_debug = debug;
|
m_debug = debug;
|
||||||
|
|
||||||
|
if (!base_path.empty())
|
||||||
|
{
|
||||||
const std::string base_filename = GetCacheBaseFileName(base_path, feature_level, debug);
|
const std::string base_filename = GetCacheBaseFileName(base_path, feature_level, debug);
|
||||||
const std::string index_filename = base_filename + ".idx";
|
const std::string index_filename = base_filename + ".idx";
|
||||||
const std::string blob_filename = base_filename + ".bin";
|
const std::string blob_filename = base_filename + ".bin";
|
||||||
|
|
||||||
if (!ReadExisting(index_filename, blob_filename))
|
if (!ReadExisting(index_filename, blob_filename))
|
||||||
CreateNew(index_filename, blob_filename);
|
CreateNew(index_filename, blob_filename);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ShaderCache::CreateNew(const std::string& index_filename, const std::string& blob_filename)
|
bool ShaderCache::CreateNew(const std::string& index_filename, const std::string& blob_filename)
|
||||||
|
|
|
@ -72,11 +72,14 @@ void ShaderCache::Open(bool is_gles, std::string_view base_path)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!base_path.empty())
|
||||||
|
{
|
||||||
const std::string index_filename = GetIndexFileName();
|
const std::string index_filename = GetIndexFileName();
|
||||||
const std::string blob_filename = GetBlobFileName();
|
const std::string blob_filename = GetBlobFileName();
|
||||||
|
|
||||||
if (!ReadExisting(index_filename, blob_filename))
|
if (!ReadExisting(index_filename, blob_filename))
|
||||||
CreateNew(index_filename, blob_filename);
|
CreateNew(index_filename, blob_filename);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ShaderCache::CreateNew(const std::string& index_filename, const std::string& blob_filename)
|
bool ShaderCache::CreateNew(const std::string& index_filename, const std::string& blob_filename)
|
||||||
|
@ -256,7 +259,7 @@ std::optional<Program> ShaderCache::GetProgram(const std::string_view vertex_sha
|
||||||
const std::string_view geometry_shader,
|
const std::string_view geometry_shader,
|
||||||
const std::string_view fragment_shader, const PreLinkCallback& callback)
|
const std::string_view fragment_shader, const PreLinkCallback& callback)
|
||||||
{
|
{
|
||||||
if (!m_program_binary_supported)
|
if (!m_program_binary_supported || !m_blob_file)
|
||||||
return CompileProgram(vertex_shader, geometry_shader, fragment_shader, callback, false);
|
return CompileProgram(vertex_shader, geometry_shader, fragment_shader, callback, false);
|
||||||
|
|
||||||
const auto key = GetCacheKey(vertex_shader, geometry_shader, fragment_shader);
|
const auto key = GetCacheKey(vertex_shader, geometry_shader, fragment_shader);
|
||||||
|
|
|
@ -121,6 +121,8 @@ void ShaderCache::Open(std::string_view base_path, bool debug)
|
||||||
{
|
{
|
||||||
m_debug = debug;
|
m_debug = debug;
|
||||||
|
|
||||||
|
if (!base_path.empty())
|
||||||
|
{
|
||||||
m_pipeline_cache_filename = GetPipelineCacheBaseFileName(base_path, debug);
|
m_pipeline_cache_filename = GetPipelineCacheBaseFileName(base_path, debug);
|
||||||
|
|
||||||
const std::string base_filename = GetShaderCacheBaseFileName(base_path, debug);
|
const std::string base_filename = GetShaderCacheBaseFileName(base_path, debug);
|
||||||
|
@ -132,6 +134,11 @@ void ShaderCache::Open(std::string_view base_path, bool debug)
|
||||||
|
|
||||||
if (!ReadExistingPipelineCache())
|
if (!ReadExistingPipelineCache())
|
||||||
CreateNewPipelineCache();
|
CreateNewPipelineCache();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
CreateNewPipelineCache();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
VkPipelineCache ShaderCache::GetPipelineCache(bool set_dirty /*= true*/)
|
VkPipelineCache ShaderCache::GetPipelineCache(bool set_dirty /*= true*/)
|
||||||
|
@ -273,7 +280,7 @@ void ShaderCache::CloseShaderCache()
|
||||||
|
|
||||||
bool ShaderCache::CreateNewPipelineCache()
|
bool ShaderCache::CreateNewPipelineCache()
|
||||||
{
|
{
|
||||||
if (FileSystem::FileExists(m_pipeline_cache_filename.c_str()))
|
if (!m_pipeline_cache_filename.empty() && FileSystem::FileExists(m_pipeline_cache_filename.c_str()))
|
||||||
{
|
{
|
||||||
Log_WarningPrintf("Removing existing pipeline cache '%s'", m_pipeline_cache_filename.c_str());
|
Log_WarningPrintf("Removing existing pipeline cache '%s'", m_pipeline_cache_filename.c_str());
|
||||||
FileSystem::DeleteFile(m_pipeline_cache_filename.c_str());
|
FileSystem::DeleteFile(m_pipeline_cache_filename.c_str());
|
||||||
|
@ -322,7 +329,7 @@ bool ShaderCache::ReadExistingPipelineCache()
|
||||||
|
|
||||||
bool ShaderCache::FlushPipelineCache()
|
bool ShaderCache::FlushPipelineCache()
|
||||||
{
|
{
|
||||||
if (m_pipeline_cache == VK_NULL_HANDLE || !m_pipeline_cache_dirty)
|
if (m_pipeline_cache == VK_NULL_HANDLE || !m_pipeline_cache_dirty || m_pipeline_cache_filename.empty())
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
size_t data_size;
|
size_t data_size;
|
||||||
|
|
Loading…
Reference in New Issue