nir/cf: fix link_blocks() when there are no successors
authorConnor Abbott <cwabbott0@gmail.com>
Wed, 22 Jul 2015 02:54:29 +0000 (19:54 -0700)
committerKenneth Graunke <kenneth@whitecape.org>
Mon, 24 Aug 2015 20:31:42 +0000 (13:31 -0700)
When we insert a single basic block A into another basic block B, we
will split B into C and D, insert A in the middle, and then splice
together C, A, and D. When we splice together C and A, we need to move
the successors of A into C -- except A has no successors, since it
hasn't been inserted yet. So in move_successors(), we need to handle the
case where the block whose successors are to be moved doesn't have any
successors. Fixing link_blocks() here prevents a segfault and makes it
work correctly.

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

index 91788adb85f59c62f898a19490d838abd047066f..9ae113f3959d385f25d0dbc19c65cc4e79d1d484 100644 (file)
@@ -57,7 +57,8 @@ static void
 link_blocks(nir_block *pred, nir_block *succ1, nir_block *succ2)
 {
    pred->successors[0] = succ1;
-   block_add_pred(succ1, pred);
+   if (succ1 != NULL)
+      block_add_pred(succ1, pred);
 
    pred->successors[1] = succ2;
    if (succ2 != NULL)