st,ir3,radeonsi: push lower_deref_instrs back into driver
authorRob Clark <robdclark@gmail.com>
Thu, 17 May 2018 19:04:08 +0000 (15:04 -0400)
committerJason Ekstrand <jason.ekstrand@intel.com>
Sat, 23 Jun 2018 03:54:00 +0000 (20:54 -0700)
vc4+vc5 is not really effected by the deref chain to deref instr
conversion, so it no longer needs this pass.  For others, now that
all the passes mesa/st uses are using deref instructions, push the
lowering to deref chains back into driver.

Signed-off-by: Rob Clark <robdclark@gmail.com>
Acked-by: Rob Clark <robdclark@gmail.com>
Acked-by: Bas Nieuwenhuizen <bas@basnieuwenhuizen.nl>
Acked-by: Dave Airlie <airlied@redhat.com>
Reviewed-by: Kenneth Graunke <kenneth@whitecape.org>
src/gallium/drivers/freedreno/ir3/ir3_compiler_nir.c
src/gallium/drivers/freedreno/ir3/ir3_nir.c
src/gallium/drivers/v3d/v3d_program.c
src/gallium/drivers/vc4/vc4_program.c
src/mesa/state_tracker/st_glsl_to_nir.cpp

index 323d278b431b97b0b52afde9250729cf633ae32a..cfe22c4415ae44ac1d44e7a0f8336685ce69aa97 100644 (file)
@@ -206,6 +206,8 @@ compile_init(struct ir3_compiler *compiler,
                ctx->s = so->shader->nir;
        }
 
+       NIR_PASS_V(ctx->s, nir_lower_deref_instrs, ~0);
+
        /* this needs to be the last pass run, so do this here instead of
         * in ir3_optimize_nir():
         */
index 52b6168f3a39675f3f4518d61f24cd178c797d51..6dc8213e5a930ed2f5f8f7cb1e8c5ff7749d021d 100644 (file)
@@ -57,9 +57,7 @@ static const nir_shader_compiler_options options = {
 struct nir_shader *
 ir3_tgsi_to_nir(const struct tgsi_token *tokens)
 {
-       struct nir_shader *shader = tgsi_to_nir(tokens, &options);
-       NIR_PASS_V(shader, nir_lower_deref_instrs, ~0);
-       return shader;
+       return tgsi_to_nir(tokens, &options);
 }
 
 const nir_shader_compiler_options *
index 55c6dc071a25238176c72a32030bec1ea50ac2da..ef7dd375bf72659b3045be60b3f96798c6ca1916 100644 (file)
@@ -209,7 +209,6 @@ v3d_shader_state_create(struct pipe_context *pctx,
                         fprintf(stderr, "\n");
                 }
                 s = tgsi_to_nir(cso->tokens, &v3d_nir_options);
-                NIR_PASS_V(s, nir_lower_deref_instrs, ~0);
 
                 so->was_tgsi = true;
         }
index e4ad329d1b93bc24235219cdfc2b6dbd98ae49e9..367613130bb68e7134d612ec854510b37f23faa8 100644 (file)
@@ -2480,7 +2480,6 @@ vc4_shader_state_create(struct pipe_context *pctx,
                         fprintf(stderr, "\n");
                 }
                 s = tgsi_to_nir(cso->tokens, &nir_options);
-                NIR_PASS_V(s, nir_lower_deref_instrs, ~0);
         }
 
         NIR_PASS_V(s, nir_opt_global_to_local);
index 40dd8daca52883baf06e6d99b960f0d1830f8e5d..d24944c6af513590b1b813c68bee9d6886947845 100644 (file)
@@ -841,8 +841,6 @@ st_finalize_nir(struct st_context *st, struct gl_program *prog,
       NIR_PASS_V(nir, gl_nir_lower_samplers_as_deref, shader_program);
    else
       NIR_PASS_V(nir, gl_nir_lower_samplers, shader_program);
-
-   NIR_PASS_V(nir, nir_lower_deref_instrs, (nir_lower_deref_flags)~0);
 }
 
 } /* extern "C" */