diff options
author | ReinUsesLisp <reinuseslisp@airmail.cc> | 2019-11-21 18:21:42 +0100 |
---|---|---|
committer | ReinUsesLisp <reinuseslisp@airmail.cc> | 2019-11-23 01:28:49 +0100 |
commit | 36d9b409fc8793b617c4ce5525d8dc297cb4d579 (patch) | |
tree | 33e3f8cd5a039acdacbf16c80436cbd8ff3461f6 /src/video_core/renderer_opengl/gl_shader_decompiler.cpp | |
parent | gl_rasterizer: Add missing cbuf counter reset on compute (diff) | |
download | yuzu-36d9b409fc8793b617c4ce5525d8dc297cb4d579.tar yuzu-36d9b409fc8793b617c4ce5525d8dc297cb4d579.tar.gz yuzu-36d9b409fc8793b617c4ce5525d8dc297cb4d579.tar.bz2 yuzu-36d9b409fc8793b617c4ce5525d8dc297cb4d579.tar.lz yuzu-36d9b409fc8793b617c4ce5525d8dc297cb4d579.tar.xz yuzu-36d9b409fc8793b617c4ce5525d8dc297cb4d579.tar.zst yuzu-36d9b409fc8793b617c4ce5525d8dc297cb4d579.zip |
Diffstat (limited to 'src/video_core/renderer_opengl/gl_shader_decompiler.cpp')
-rw-r--r-- | src/video_core/renderer_opengl/gl_shader_decompiler.cpp | 12 |
1 files changed, 4 insertions, 8 deletions
diff --git a/src/video_core/renderer_opengl/gl_shader_decompiler.cpp b/src/video_core/renderer_opengl/gl_shader_decompiler.cpp index 5ad285c25..040370c83 100644 --- a/src/video_core/renderer_opengl/gl_shader_decompiler.cpp +++ b/src/video_core/renderer_opengl/gl_shader_decompiler.cpp @@ -619,10 +619,9 @@ private: } void DeclareConstantBuffers() { - for (const auto& entry : ir.GetConstantBuffers()) { - const auto [index, size] = entry; - const u32 binding = device.GetBaseBindings(stage).uniform_buffer + index; - code.AddLine("layout (std140, binding = {}) uniform {} {{", binding, + u32 binding = device.GetBaseBindings(stage).uniform_buffer; + for (const auto& [index, cbuf] : ir.GetConstantBuffers()) { + code.AddLine("layout (std140, binding = {}) uniform {} {{", binding++, GetConstBufferBlock(index)); code.AddLine(" uvec4 {}[{}];", GetConstBuffer(index), MAX_CONSTBUFFER_ELEMENTS); code.AddLine("}};"); @@ -632,10 +631,7 @@ private: void DeclareGlobalMemory() { u32 binding = device.GetBaseBindings(stage).shader_storage_buffer; - - for (const auto& gmem : ir.GetGlobalMemory()) { - const auto& [base, usage] = gmem; - + for (const auto& [base, usage] : ir.GetGlobalMemory()) { // Since we don't know how the shader will use the shader, hint the driver to disable as // much optimizations as possible std::string qualifier = "coherent volatile"; |