summaryrefslogtreecommitdiff
path: root/src/video_core/renderer_vulkan
diff options
context:
space:
mode:
Diffstat (limited to 'src/video_core/renderer_vulkan')
-rw-r--r--src/video_core/renderer_vulkan/vk_pipeline_cache.cpp13
1 files changed, 13 insertions, 0 deletions
diff --git a/src/video_core/renderer_vulkan/vk_pipeline_cache.cpp b/src/video_core/renderer_vulkan/vk_pipeline_cache.cpp
index c1314ca99..b1730a170 100644
--- a/src/video_core/renderer_vulkan/vk_pipeline_cache.cpp
+++ b/src/video_core/renderer_vulkan/vk_pipeline_cache.cpp
@@ -664,6 +664,19 @@ std::unique_ptr<GraphicsPipeline> PipelineCache::CreateGraphicsPipeline(
664 std::move(modules), infos); 664 std::move(modules), infos);
665 665
666} catch (const Shader::Exception& exception) { 666} catch (const Shader::Exception& exception) {
667 auto hash = key.Hash();
668 size_t env_index{0};
669 for (size_t index = 0; index < Maxwell::MaxShaderProgram; ++index) {
670 if (key.unique_hashes[index] == 0) {
671 continue;
672 }
673 Shader::Environment& env{*envs[env_index]};
674 ++env_index;
675
676 const u32 cfg_offset{static_cast<u32>(env.StartAddress() + sizeof(Shader::ProgramHeader))};
677 Shader::Maxwell::Flow::CFG cfg(env, pools.flow_block, cfg_offset, index == 0);
678 env.Dump(hash, key.unique_hashes[index]);
679 }
667 LOG_ERROR(Render_Vulkan, "{}", exception.what()); 680 LOG_ERROR(Render_Vulkan, "{}", exception.what());
668 return nullptr; 681 return nullptr;
669} 682}