mirror of
git://gcc.gnu.org/git/gcc.git
synced 2025-04-04 20:01:21 +08:00
re PR rtl-optimization/46440 (ICE: in rtl_verify_flow_info, at cfgrtl.c:2165 with -fstack-protector-all -fno-tree-dominator-opts -fno-tree-fre)
PR rtl-optimization/46440 * combine.c (update_cfg_for_uncondjump): When changing an indirect jump into unconditional jump, remove BARRIERs from bb's footer. * gcc.dg/pr46440.c: New test. From-SVN: r166867
This commit is contained in:
parent
f79616a446
commit
073d7052e5
@ -1,3 +1,10 @@
|
||||
2010-11-17 Jakub Jelinek <jakub@redhat.com>
|
||||
|
||||
PR rtl-optimization/46440
|
||||
* combine.c (update_cfg_for_uncondjump): When changing
|
||||
an indirect jump into unconditional jump, remove BARRIERs
|
||||
from bb's footer.
|
||||
|
||||
2010-11-17 Joseph Myers <joseph@codesourcery.com>
|
||||
|
||||
* opts.c (target_handle_option): Do not assert that loc ==
|
||||
|
@ -2460,7 +2460,25 @@ update_cfg_for_uncondjump (rtx insn)
|
||||
|
||||
delete_insn (insn);
|
||||
if (at_end && EDGE_COUNT (bb->succs) == 1)
|
||||
single_succ_edge (bb)->flags |= EDGE_FALLTHRU;
|
||||
{
|
||||
rtx insn;
|
||||
|
||||
single_succ_edge (bb)->flags |= EDGE_FALLTHRU;
|
||||
|
||||
/* Remove barriers from the footer if there are any. */
|
||||
for (insn = bb->il.rtl->footer; insn; insn = NEXT_INSN (insn))
|
||||
if (BARRIER_P (insn))
|
||||
{
|
||||
if (PREV_INSN (insn))
|
||||
NEXT_INSN (PREV_INSN (insn)) = NEXT_INSN (insn);
|
||||
else
|
||||
bb->il.rtl->footer = NEXT_INSN (insn);
|
||||
if (NEXT_INSN (insn))
|
||||
PREV_INSN (NEXT_INSN (insn)) = PREV_INSN (insn);
|
||||
}
|
||||
else if (LABEL_P (insn))
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
/* Try to combine the insns I0, I1 and I2 into I3.
|
||||
|
@ -1,5 +1,8 @@
|
||||
2010-11-17 Jakub Jelinek <jakub@redhat.com>
|
||||
|
||||
PR rtl-optimization/46440
|
||||
* gcc.dg/pr46440.c: New test.
|
||||
|
||||
PR testsuite/45429
|
||||
* gcc.dg/vect/no-section-anchors-vect-64.c: New test.
|
||||
|
||||
|
25
gcc/testsuite/gcc.dg/pr46440.c
Normal file
25
gcc/testsuite/gcc.dg/pr46440.c
Normal file
@ -0,0 +1,25 @@
|
||||
/* PR rtl-optimization/46440 */
|
||||
/* { dg-do compile } */
|
||||
/* { dg-options "-O -fstack-protector -fno-tree-dominator-opts -fno-tree-fre" } */
|
||||
/* { dg-require-effective-target fstack_protector } */
|
||||
|
||||
int i;
|
||||
|
||||
void bar (char *);
|
||||
|
||||
void
|
||||
foo (void)
|
||||
{
|
||||
void *l;
|
||||
char c[64];
|
||||
bar (c);
|
||||
i = 1;
|
||||
if (i)
|
||||
l = &&l1;
|
||||
else
|
||||
l = &&l2;
|
||||
goto *l;
|
||||
l2:
|
||||
__builtin_abort ();
|
||||
l1:;
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user