OSDN Git Service

PR opt/10024
authorhubicka <hubicka@138bc75d-0d04-0410-961f-82ee72b054a4>
Mon, 7 Apr 2003 12:36:59 +0000 (12:36 +0000)
committerhubicka <hubicka@138bc75d-0d04-0410-961f-82ee72b054a4>
Mon, 7 Apr 2003 12:36:59 +0000 (12:36 +0000)
* cfglayout.c (cfg_layout_redirect_edge):
Redirect any branch edges unified with the fallthru one.
* cfgrtl.c (force_nonfallthru_and_redirect):  Do not special
case fallthru edges when called via cfglayout.c

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@65330 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/ChangeLog
gcc/cfglayout.c
gcc/cfgrtl.c

index 38ed2cb..8fa41fd 100644 (file)
@@ -1,3 +1,11 @@
+Mon Apr  7 14:36:24 CEST 2003  Jan Hubicka  <jh@suse.cz>
+
+       PR opt/10024
+       * cfglayout.c (cfg_layout_redirect_edge):
+       Redirect any branch edges unified with the fallthru one.
+       * cfgrtl.c (force_nonfallthru_and_redirect):  Do not special
+       case fallthru edges when called via cfglayout.c
+
 2003-04-07  J"orn Rennecke <joern.rennecke@superh.com>
 
        * c-typeck.c (output_init_element): Check for type == error_mark_node.
index b5be7ca..3420bd1 100644 (file)
@@ -904,6 +904,13 @@ cfg_layout_redirect_edge (e, dest)
   src->next_bb = NULL;
   if (e->flags & EDGE_FALLTHRU)
     {
+      /* Redirect any branch edges unified with the fallthru one.  */
+      if (GET_CODE (src->end) == JUMP_INSN
+         && JUMP_LABEL (src->end) == e->dest->head)
+       {
+          if (!redirect_jump (src->end, block_label (dest), 0))
+           abort ();
+       }
       /* In case we are redirecting fallthru edge to the branch edge
          of conditional jump, remove it.  */
       if (src->succ->succ_next
index 185676b..1683ca4 100644 (file)
@@ -927,6 +927,9 @@ force_nonfallthru_and_redirect (e, target)
      by creating an basic block afterwards to redirect fallthru edge.  */
   if (e->src != ENTRY_BLOCK_PTR && e->dest != EXIT_BLOCK_PTR
       && any_condjump_p (e->src->end)
+      /* When called from cfglayout, fallthru edges do not
+         neccessarily go to the next block.  */
+      && e->src->next_bb == e->dest
       && JUMP_LABEL (e->src->end) == e->dest->head)
     {
       rtx note;