diff options
author | Jakub Jelinek <jakub@redhat.com> | 2014-09-30 12:30:45 +0200 |
---|---|---|
committer | Jakub Jelinek <jakub@gcc.gnu.org> | 2014-09-30 12:30:45 +0200 |
commit | b58fd59ad5ece79c494cbac3b30ff2ca8458563a (patch) | |
tree | 4f5654a607bd4ec71f788a795ac7f43acdb48eeb /gcc/ifcvt.c | |
parent | 2f6403f1337686599ddce4c01798274081fe2c35 (diff) | |
download | gcc-b58fd59ad5ece79c494cbac3b30ff2ca8458563a.zip gcc-b58fd59ad5ece79c494cbac3b30ff2ca8458563a.tar.gz gcc-b58fd59ad5ece79c494cbac3b30ff2ca8458563a.tar.bz2 |
re PR inline-asm/63282 (ICE in redirect_jump_1)
PR inline-asm/63282
* ifcvt.c (dead_or_predicable): Don't call redirect_jump_1
or invert_jump_1 if jump isn't any_condjump_p.
* gcc.c-torture/compile/pr63282.c: New test.
From-SVN: r215712
Diffstat (limited to 'gcc/ifcvt.c')
-rw-r--r-- | gcc/ifcvt.c | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/gcc/ifcvt.c b/gcc/ifcvt.c index 6bcc23a..b6b479f 100644 --- a/gcc/ifcvt.c +++ b/gcc/ifcvt.c @@ -4357,6 +4357,9 @@ dead_or_predicable (basic_block test_bb, basic_block merge_bb, old_dest = JUMP_LABEL (jump); if (other_bb != new_dest) { + if (!any_condjump_p (jump)) + goto cancel; + if (JUMP_P (BB_END (dest_edge->src))) new_dest_label = JUMP_LABEL (BB_END (dest_edge->src)); else if (new_dest == EXIT_BLOCK_PTR_FOR_FN (cfun)) |