aboutsummaryrefslogtreecommitdiff
path: root/gcc/ifcvt.c
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2014-09-30 12:30:45 +0200
committerJakub Jelinek <jakub@gcc.gnu.org>2014-09-30 12:30:45 +0200
commitb58fd59ad5ece79c494cbac3b30ff2ca8458563a (patch)
tree4f5654a607bd4ec71f788a795ac7f43acdb48eeb /gcc/ifcvt.c
parent2f6403f1337686599ddce4c01798274081fe2c35 (diff)
downloadgcc-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.c3
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))