diff options
author | Mike Blumenkrantz <michael.blumenkrantz@gmail.com> | 2022-02-09 15:41:02 -0500 |
---|---|---|
committer | Marge Bot <emma+marge@anholt.net> | 2022-02-11 01:29:39 +0000 |
commit | f2baa0638b68e20e5affe9306dab1c8042edc9e9 (patch) | |
tree | 9263699d4ade95a110b82b32b9944617d43f1543 | |
parent | 64f1960915b8d7f144d7286a7b1f22a06852bfbc (diff) |
zink: store the tcs_vertices_out spirv word
Reviewed-by: Dave Airlie <airlied@redhat.com>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/14976>
-rw-r--r-- | src/gallium/drivers/zink/nir_to_spirv/nir_to_spirv.c | 7 |
1 files changed, 4 insertions, 3 deletions
diff --git a/src/gallium/drivers/zink/nir_to_spirv/nir_to_spirv.c b/src/gallium/drivers/zink/nir_to_spirv/nir_to_spirv.c index c9a85b97134..774484fabd2 100644 --- a/src/gallium/drivers/zink/nir_to_spirv/nir_to_spirv.c +++ b/src/gallium/drivers/zink/nir_to_spirv/nir_to_spirv.c @@ -3851,6 +3851,7 @@ nir_to_spirv(struct nir_shader *s, const struct zink_shader_info *sinfo, uint32_ if (sinfo->last_vertex) emit_so_info(&ctx, sinfo, max_output + 1); + uint32_t tcs_vertices_out_word = 0; /* we have to reverse iterate to match what's done in zink_compiler.c */ foreach_list_typed_reverse(nir_variable, var, node, &s->variables) @@ -3896,9 +3897,9 @@ nir_to_spirv(struct nir_shader *s, const struct zink_shader_info *sinfo, uint32_ spirv_builder_emit_exec_mode(&ctx.builder, entry_point, SpvExecutionModeSampleInterlockUnorderedEXT); break; case MESA_SHADER_TESS_CTRL: - spirv_builder_emit_exec_mode_literal(&ctx.builder, entry_point, - SpvExecutionModeOutputVertices, - s->info.tess.tcs_vertices_out); + tcs_vertices_out_word = spirv_builder_emit_exec_mode_literal(&ctx.builder, entry_point, + SpvExecutionModeOutputVertices, + s->info.tess.tcs_vertices_out); break; case MESA_SHADER_TESS_EVAL: spirv_builder_emit_exec_mode(&ctx.builder, entry_point, |