diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 2b47e8e3f40b..bfdad2f05197 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2010-12-21 Steven Bosscher + + PR rtl-optimization/46755 + * ira.c (ira): If some dead edges were removed, find and delete + any blocks that might have become unreachable. + 2010-12-21 Jakub Jelinek PR rtl-optimization/47008 diff --git a/gcc/ira.c b/gcc/ira.c index 6db1fba5a6f2..5f27fc2f320d 100644 --- a/gcc/ira.c +++ b/gcc/ira.c @@ -3158,7 +3158,8 @@ ira (FILE *f) { timevar_push (TV_JUMP); rebuild_jump_labels (get_insns ()); - purge_all_dead_edges (); + if (purge_all_dead_edges ()) + delete_unreachable_blocks (); timevar_pop (TV_JUMP); } } diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 3a66f1c15d39..d66df22e1e0a 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2010-12-21 Steven Bosscher + + PR rtl-optimization/46755 + * gfortran.dg/pr46755.f: New test. + 2010-12-21 Jakub Jelinek PR rtl-optimization/47008 diff --git a/gcc/testsuite/gfortran.dg/pr46755.f b/gcc/testsuite/gfortran.dg/pr46755.f new file mode 100644 index 000000000000..ff764a7d88df --- /dev/null +++ b/gcc/testsuite/gfortran.dg/pr46755.f @@ -0,0 +1,23 @@ +C { dg-do compile } +C { dg-options "-O" } + IMPLICIT NONE + INTEGER I640,I760,I800 + INTEGER I,ITER,ITMX,LENCM + LOGICAL QDISK,QDW + ASSIGN 801 TO I800 + GOTO I800 + 801 CONTINUE + ASSIGN 761 TO I760 + 761 CONTINUE + DO I=1,LENCM + ENDDO + DO WHILE(ITER.LT.ITMX) + IF(QDW) THEN + ASSIGN 641 to I640 + GOTO I760 + 641 CONTINUE + ENDIF + ENDDO + RETURN + END +