nir: make cleanup_cf_node() not use remove_defs_uses()
authorConnor Abbott <cwabbott0@gmail.com>
Wed, 22 Jul 2015 02:54:17 +0000 (19:54 -0700)
committerKenneth Graunke <kenneth@whitecape.org>
Mon, 24 Aug 2015 20:31:41 +0000 (13:31 -0700)
cleanup_cf_node() is part of the control flow modification code, which
we're going to split into its own file, but remove_defs_uses() is an
internal function used by nir_instr_remove(). Break the dependency by
making cleanup_cf_node() use nir_instr_remove() instead, which simply
calls remove_defs_uses() and then removes the instruction from the list.
nir_instr_remove() does do extra things for jumps, though, so we avoid
calling it on jumps which matches the previous behavior (this will be
fixed later in the series).

Signed-off-by: Connor Abbott <connor.w.abbott@intel.com>
Reviewed-by: Kenneth Graunke <kenneth@whitecape.org>
src/glsl/nir/nir.c

index b8a9e98508852be053fa6bce7b04b68599361503..793b341ea10b5b86f9c85bc1a780ee9ff7e7c92d 100644 (file)
@@ -1212,8 +1212,10 @@ cleanup_cf_node(nir_cf_node *node)
    case nir_cf_node_block: {
       nir_block *block = nir_cf_node_as_block(node);
       /* We need to walk the instructions and clean up defs/uses */
-      nir_foreach_instr(block, instr)
-         remove_defs_uses(instr);
+      nir_foreach_instr(block, instr) {
+         if (instr->type != nir_instr_type_jump)
+            nir_instr_remove(instr);
+      }
       break;
    }