Mesa (master): mesa/st: Don't expect prog->nir to already exist

GitLab Mirror gitlab-mirror at kemper.freedesktop.org
Tue Sep 10 22:07:03 UTC 2019


Module: Mesa
Branch: master
Commit: 1a12b0fe36fa50d8591c998723e25bdfbdea8b9e
URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=1a12b0fe36fa50d8591c998723e25bdfbdea8b9e

Author: Caio Marcelo de Oliveira Filho <caio.oliveira at intel.com>
Date:   Thu Aug 22 11:23:51 2019 -0700

mesa/st: Don't expect prog->nir to already exist

There's no such case, if we load prog->nir from the shader cache, we
shouldn't hit this path.

Suggested-by: Kenneth Graunke <kenneth at whitecape.org>
Reviewed-by: Timothy Arceri <tarceri at itsqueeze.com>

---

 src/mesa/state_tracker/st_glsl_to_nir.cpp | 11 +++++------
 1 file changed, 5 insertions(+), 6 deletions(-)

diff --git a/src/mesa/state_tracker/st_glsl_to_nir.cpp b/src/mesa/state_tracker/st_glsl_to_nir.cpp
index fead0ccc625..39203435515 100644
--- a/src/mesa/state_tracker/st_glsl_to_nir.cpp
+++ b/src/mesa/state_tracker/st_glsl_to_nir.cpp
@@ -633,6 +633,8 @@ st_link_nir(struct gl_context *ctx,
       struct gl_program *prog = shader->Program;
       _mesa_copy_linked_program_data(shader_program, shader);
 
+      assert(!prog->nir);
+
       if (shader_program->data->spirv) {
          const nir_shader_compiler_options *options =
             st->ctx->Const.ShaderCompilerOptions[shader->Stage].NirOptions;
@@ -640,7 +642,6 @@ st_link_nir(struct gl_context *ctx,
          prog->Parameters = _mesa_new_parameter_list();
          /* Parameters will be filled during NIR linking. */
 
-         /* TODO: Properly handle or dismiss `if (prog->nir)` case. */
          prog->nir = _mesa_spirv_to_nir(ctx, shader_program, shader->Stage, options);
          set_st_program(prog, shader_program, prog->nir);
       } else {
@@ -670,11 +671,9 @@ st_link_nir(struct gl_context *ctx,
             st->ctx->Const.ShaderCompilerOptions[prog->info.stage].NirOptions;
          assert(options);
 
-         if (!prog->nir) {
-            prog->nir = glsl_to_nir(st->ctx, shader_program, shader->Stage, options);
-            set_st_program(prog, shader_program, prog->nir);
-            st_nir_preprocess(st, prog, shader_program, shader->Stage);
-         }
+         prog->nir = glsl_to_nir(st->ctx, shader_program, shader->Stage, options);
+         set_st_program(prog, shader_program, prog->nir);
+         st_nir_preprocess(st, prog, shader_program, shader->Stage);
       }
 
       last_stage = i;




More information about the mesa-commit mailing list