diff options
author | Ian Romanick <[email protected]> | 2014-12-01 14:07:30 -0800 |
---|---|---|
committer | Ian Romanick <[email protected]> | 2014-12-03 11:33:49 -0800 |
commit | a909b995d95892798a189818454905fdefd4bc9b (patch) | |
tree | 1eadf377ee72309871a9a7f75a08b77807ded20f /src/glsl/linker.cpp | |
parent | 5eca78a00a5de442aaf541a1095d5cfa6b4f45de (diff) |
linker: Assign varying locations geometry shader inputs for SSO
Previously only geometry shader outputs would be assigned locations if
the geometry shader was the only stage in the linked program.
Signed-off-by: Ian Romanick <[email protected]>
Cc: [email protected]
Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=82585
Reviewed-by: Jordan Justen <[email protected]>
Diffstat (limited to 'src/glsl/linker.cpp')
-rw-r--r-- | src/glsl/linker.cpp | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/src/glsl/linker.cpp b/src/glsl/linker.cpp index de6b1fb9f37..6713df14a08 100644 --- a/src/glsl/linker.cpp +++ b/src/glsl/linker.cpp @@ -2746,6 +2746,21 @@ link_shaders(struct gl_context *ctx, struct gl_shader_program *prog) if (last >= 0 && last < MESA_SHADER_FRAGMENT) { gl_shader *const sh = prog->_LinkedShaders[last]; + if (first == MESA_SHADER_GEOMETRY) { + /* There was no vertex shader, but we still have to assign varying + * locations for use by geometry shader inputs in SSO. + * + * If the shader is not separable (i.e., prog->SeparateShader is + * false), linking will have already failed when first is + * MESA_SHADER_GEOMETRY. + */ + if (!assign_varying_locations(ctx, mem_ctx, prog, + NULL, sh, + num_tfeedback_decls, tfeedback_decls, + prog->Geom.VerticesIn)) + goto done; + } + if (num_tfeedback_decls != 0 || prog->SeparateShader) { /* There was no fragment shader, but we still have to assign varying * locations for use by transform feedback. |