cfgloopmanip.c (duplicate_loop_to_header_edge): Update irreducible flag correctly.
authorZdenek Dvorak <rakdver@atrey.karlin.mff.cuni.cz>
Thu, 24 Jul 2003 18:54:26 +0000 (20:54 +0200)
committerZdenek Dvorak <rakdver@gcc.gnu.org>
Thu, 24 Jul 2003 18:54:26 +0000 (18:54 +0000)
* cfgloopmanip.c (duplicate_loop_to_header_edge): Update irreducible
flag correctly.

From-SVN: r69755

gcc/ChangeLog
gcc/cfgloopmanip.c

index 50ae6251715b216f37d26b6f9f2673951af1bdea..e7685659ac96595116d7302997dd030de24bdde2 100644 (file)
@@ -1,3 +1,8 @@
+2003-07-24  Zdenek Dvorak  <rakdver@atrey.karlin.mff.cuni.cz>
+
+       * cfgloopmanip.c (duplicate_loop_to_header_edge): Update irreducible
+       flag correctly.
+
 2003-07-24  Zack Weinberg  <zack@codesourcery.com>
 
        * c-decl.c: Search-and-replace change 'binding level' to
index 8892720069d36330737b47646e0d96255d29a9ce..26eb9fd6e3bf6e4c8b16ba814a6cc901139f91c9 100644 (file)
@@ -988,6 +988,27 @@ duplicate_loop_to_header_edge (struct loop *loop, edge e, struct loops *loops,
       /* Copy bbs.  */
       copy_bbs (bbs, n, new_bbs, spec_edges, 2, new_spec_edges, loop, loops);
 
+      /* Note whether the blocks and edges belong to an irreducible loop.  */
+      if (add_irreducible_flag)
+       {
+         for (i = 0; i < n; i++)
+           new_bbs[i]->rbi->duplicated = 1;
+         for (i = 0; i < n; i++)
+           {
+             new_bb = new_bbs[i];
+             if (new_bb->loop_father == target)
+               new_bb->flags |= BB_IRREDUCIBLE_LOOP;
+
+             for (ae = new_bb->succ; ae; ae = ae->succ_next)
+               if (ae->dest->rbi->duplicated
+                   && (ae->src->loop_father == target
+                       || ae->dest->loop_father == target))
+                 ae->flags |= EDGE_IRREDUCIBLE_LOOP;
+           }
+         for (i = 0; i < n; i++)
+           new_bbs[i]->rbi->duplicated = 0;
+       }
+
       /* Redirect the special edges.  */
       if (is_latch)
        {
@@ -1011,22 +1032,6 @@ duplicate_loop_to_header_edge (struct loop *loop, edge e, struct loops *loops,
       if (orig && TEST_BIT (wont_exit, j + 1))
        to_remove[(*n_to_remove)++] = new_spec_edges[SE_ORIG];
 
-      /* Note whether the blocks and edges belong to an irreducible loop.  */
-      if (add_irreducible_flag)
-       {
-         for (i = 0; i < n; i++)
-           {
-             new_bb = new_bbs[i];
-             if (new_bb->loop_father == target)
-               new_bb->flags |= BB_IRREDUCIBLE_LOOP;
-
-             for (ae = new_bb->succ; ae; ae = ae->succ_next)
-               if (ae->src->loop_father == target
-                   || ae->dest->loop_father == target)
-                 ae->flags |= EDGE_IRREDUCIBLE_LOOP;
-           }
-       }
-
       /* Record the first copy in the control flow order if it is not
         the original loop (i.e. in case of peeling).  */
       if (!first_active_latch)