aboutsummaryrefslogtreecommitdiff
path: root/gcc/sel-sched-ir.c
diff options
context:
space:
mode:
authorAlexander Monakov <amonakov@ispras.ru>2010-12-15 16:08:41 +0300
committerAlexander Monakov <amonakov@gcc.gnu.org>2010-12-15 16:08:41 +0300
commit9d0dcda15ccb43b5b24b370e793142736d5742d3 (patch)
tree488325a3428239da3b6c7029b84a92513a232674 /gcc/sel-sched-ir.c
parent3ca4d07dffe49b9c51f713cb78c785ecb185b04a (diff)
downloadgcc-9d0dcda15ccb43b5b24b370e793142736d5742d3.zip
gcc-9d0dcda15ccb43b5b24b370e793142736d5742d3.tar.gz
gcc-9d0dcda15ccb43b5b24b370e793142736d5742d3.tar.bz2
re PR rtl-optimization/46649 (ICE: in move_bb_info, at sel-sched-ir.c:5080 with -fschedule-insns -fselective-scheduling)
PR rtl-optimization/46649 * sel-sched-ir.c (purge_empty_blocks): Unconditionally skip the first basic block in the region. testsuite: * g++.dg/opt/pr46649.C: New. From-SVN: r167854
Diffstat (limited to 'gcc/sel-sched-ir.c')
-rw-r--r--gcc/sel-sched-ir.c6
1 files changed, 3 insertions, 3 deletions
diff --git a/gcc/sel-sched-ir.c b/gcc/sel-sched-ir.c
index 468dfd7..43619d9 100644
--- a/gcc/sel-sched-ir.c
+++ b/gcc/sel-sched-ir.c
@@ -3766,10 +3766,10 @@ tidy_control_flow (basic_block xbb, bool full_tidying)
void
purge_empty_blocks (void)
{
- /* Do not attempt to delete preheader. */
- int i = sel_is_loop_preheader_p (BASIC_BLOCK (BB_TO_BLOCK (0))) ? 1 : 0;
+ int i;
- while (i < current_nr_blocks)
+ /* Do not attempt to delete the first basic block in the region. */
+ for (i = 1; i < current_nr_blocks; )
{
basic_block b = BASIC_BLOCK (BB_TO_BLOCK (i));