summaryrefslogtreecommitdiffstats
path: root/src/video_core/renderer_opengl/gl_shader_cache.cpp
diff options
context:
space:
mode:
authorFernando Sahmkow <fsahmkow27@gmail.com>2021-11-17 04:19:29 +0100
committerFernando Sahmkow <fsahmkow27@gmail.com>2022-01-04 02:39:00 +0100
commitf58ee3f15f7427a8b834286384931bcf821ed771 (patch)
tree1ef8367f64cbee6220c4e5600249697e5cd8e826 /src/video_core/renderer_opengl/gl_shader_cache.cpp
parentMerge pull request #7648 from bunnei/thread-pinning (diff)
downloadyuzu-f58ee3f15f7427a8b834286384931bcf821ed771.tar
yuzu-f58ee3f15f7427a8b834286384931bcf821ed771.tar.gz
yuzu-f58ee3f15f7427a8b834286384931bcf821ed771.tar.bz2
yuzu-f58ee3f15f7427a8b834286384931bcf821ed771.tar.lz
yuzu-f58ee3f15f7427a8b834286384931bcf821ed771.tar.xz
yuzu-f58ee3f15f7427a8b834286384931bcf821ed771.tar.zst
yuzu-f58ee3f15f7427a8b834286384931bcf821ed771.zip
Diffstat (limited to 'src/video_core/renderer_opengl/gl_shader_cache.cpp')
-rw-r--r--src/video_core/renderer_opengl/gl_shader_cache.cpp11
1 files changed, 10 insertions, 1 deletions
diff --git a/src/video_core/renderer_opengl/gl_shader_cache.cpp b/src/video_core/renderer_opengl/gl_shader_cache.cpp
index ec558a9af..f71e01a34 100644
--- a/src/video_core/renderer_opengl/gl_shader_cache.cpp
+++ b/src/video_core/renderer_opengl/gl_shader_cache.cpp
@@ -425,6 +425,11 @@ std::unique_ptr<GraphicsPipeline> ShaderCache::CreateGraphicsPipeline(
const u32 cfg_offset{static_cast<u32>(env.StartAddress() + sizeof(Shader::ProgramHeader))};
Shader::Maxwell::Flow::CFG cfg(env, pools.flow_block, cfg_offset, index == 0);
+
+ if (Settings::values.dump_shaders) {
+ env.Dump(key.unique_hashes[index]);
+ }
+
if (!uses_vertex_a || index != 1) {
// Normal path
programs[index] = TranslateProgram(pools.inst, pools.block, env, cfg, host_info);
@@ -511,8 +516,12 @@ std::unique_ptr<ComputePipeline> ShaderCache::CreateComputePipeline(
LOG_INFO(Render_OpenGL, "0x{:016x}", key.Hash());
Shader::Maxwell::Flow::CFG cfg{env, pools.flow_block, env.StartAddress()};
- auto program{TranslateProgram(pools.inst, pools.block, env, cfg, host_info)};
+ if (Settings::values.dump_shaders) {
+ env.Dump(key.Hash());
+ }
+
+ auto program{TranslateProgram(pools.inst, pools.block, env, cfg, host_info)};
const u32 num_storage_buffers{Shader::NumDescriptors(program.info.storage_buffers_descriptors)};
Shader::RuntimeInfo info;
info.glasm_use_storage_buffers = num_storage_buffers <= device.GetMaxGLASMStorageBufferBlocks();