diff options
author | Alexander Monakov <amonakov@ispras.ru> | 2010-12-15 16:08:41 +0300 |
---|---|---|
committer | Alexander Monakov <amonakov@gcc.gnu.org> | 2010-12-15 16:08:41 +0300 |
commit | 9d0dcda15ccb43b5b24b370e793142736d5742d3 (patch) | |
tree | 488325a3428239da3b6c7029b84a92513a232674 /gcc/sel-sched-ir.c | |
parent | 3ca4d07dffe49b9c51f713cb78c785ecb185b04a (diff) | |
download | gcc-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.c | 6 |
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)); |