summaryrefslogtreecommitdiff
path: root/gcc/sched-ebb.c
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2011-11-30 19:53:46 +0100
committerJakub Jelinek <jakub@gcc.gnu.org>2011-11-30 19:53:46 +0100
commitbbf81a5faed795d45e982363b9807cd7de74ce49 (patch)
tree722fead98a89b352575082bf5b82d8e3ef6bbeb1 /gcc/sched-ebb.c
parent23ffb99e94f8cbd3ac656f5efa3035c00432e6e2 (diff)
re PR rtl-optimization/48721 (ICE: verify_flow_info failed: missing barrier after block 6 with -foptimize-sibling-calls -fsched2-use-superblocks)
PR rtl-optimization/48721 * sched-ebb.c (begin_move_insn): Insert empty unreachable block after BARRIER if insn is followed by it. From-SVN: r181855
Diffstat (limited to 'gcc/sched-ebb.c')
-rw-r--r--gcc/sched-ebb.c9
1 files changed, 7 insertions, 2 deletions
diff --git a/gcc/sched-ebb.c b/gcc/sched-ebb.c
index 9a28e2bfc4b..cae9f704178 100644
--- a/gcc/sched-ebb.c
+++ b/gcc/sched-ebb.c
@@ -191,8 +191,13 @@ begin_move_insn (rtx insn, rtx last)
gcc_assert (NOTE_INSN_BASIC_BLOCK_P (BB_END (bb)));
}
else
- /* Create an empty unreachable block after the INSN. */
- bb = create_basic_block (NEXT_INSN (insn), NULL_RTX, last_bb);
+ {
+ /* Create an empty unreachable block after the INSN. */
+ rtx next = NEXT_INSN (insn);
+ if (next && BARRIER_P (next))
+ next = NEXT_INSN (next);
+ bb = create_basic_block (next, NULL_RTX, last_bb);
+ }
/* split_edge () creates BB before E->DEST. Keep in mind, that
this operation extends scheduling region till the end of BB.