nir: Return progress from nir_lower_64bit_pack().
authorMatt Turner <mattst88@gmail.com>
Fri, 24 Feb 2017 23:29:24 +0000 (15:29 -0800)
committerMatt Turner <mattst88@gmail.com>
Thu, 23 Mar 2017 21:34:43 +0000 (14:34 -0700)
Reviewed-by: Jason Ekstrand <jason@jlekstrand.net>
src/compiler/nir/nir.h
src/compiler/nir/nir_lower_64bit_packing.c

index 1b9e17fe89d1e75df2455987237eb95c95bb622b..a3235739192e91787e03b48d48a9e70d5d6b40b4 100644 (file)
@@ -2568,7 +2568,7 @@ typedef enum {
 } nir_lower_doubles_options;
 
 bool nir_lower_doubles(nir_shader *shader, nir_lower_doubles_options options);
-void nir_lower_64bit_pack(nir_shader *shader);
+bool nir_lower_64bit_pack(nir_shader *shader);
 
 bool nir_normalize_cubemap_coords(nir_shader *shader);
 
index f523cebf4741816e64807edaf9862b4e19a1feb9..abae173ce3b8d8e7386cbb4030254abd6489832e 100644 (file)
@@ -48,11 +48,12 @@ lower_unpack_64(nir_builder *b, nir_ssa_def *src)
                       nir_unpack_64_2x32_split_y(b, src));
 }
 
-static void
+static bool
 lower_64bit_pack_impl(nir_function_impl *impl)
 {
    nir_builder b;
    nir_builder_init(&b, impl);
+   bool progress = false;
 
    nir_foreach_block(block, impl) {
       nir_foreach_instr_safe(instr, block) {
@@ -83,15 +84,24 @@ lower_64bit_pack_impl(nir_function_impl *impl)
 
          nir_ssa_def_rewrite_uses(&alu_instr->dest.dest.ssa, nir_src_for_ssa(dest));
          nir_instr_remove(&alu_instr->instr);
+         nir_metadata_preserve(impl, nir_metadata_block_index |
+                                     nir_metadata_dominance);
+         progress = true;
       }
    }
+
+   return progress;
 }
 
-void
+bool
 nir_lower_64bit_pack(nir_shader *shader)
 {
+   bool progress = false;
+
    nir_foreach_function(function, shader) {
       if (function->impl)
-         lower_64bit_pack_impl(function->impl);
+         progress |= lower_64bit_pack_impl(function->impl);
    }
+
+   return false;
 }