re PR bootstrap/82916 (gcc miscompiled during stagefeedback (PGO bootstrap))
PR bootstrap/82916 * gimple-ssa-store-merging.c (pass_store_merging::terminate_all_aliasing_chains): For gimple_store_p stmts also call refs_output_dependent_p. * gcc.dg/store_merging_2.c: Only expect 2 successful mergings instead of 3. * gcc.dg/pr82916.c: New test. From-SVN: r254623
This commit is contained in:
parent
db489777bb
commit
9e875fd864
|
@ -1,5 +1,10 @@
|
|||
2017-11-10 Jakub Jelinek <jakub@redhat.com>
|
||||
|
||||
PR bootstrap/82916
|
||||
* gimple-ssa-store-merging.c
|
||||
(pass_store_merging::terminate_all_aliasing_chains): For
|
||||
gimple_store_p stmts also call refs_output_dependent_p.
|
||||
|
||||
PR rtl-optimization/82913
|
||||
* compare-elim.c (try_merge_compare): Punt if def_insn is not
|
||||
single set.
|
||||
|
|
|
@ -947,6 +947,7 @@ pass_store_merging::terminate_all_aliasing_chains (imm_store_chain_info
|
|||
if (!gimple_vuse (stmt))
|
||||
return false;
|
||||
|
||||
tree store_lhs = gimple_store_p (stmt) ? gimple_get_lhs (stmt) : NULL_TREE;
|
||||
for (imm_store_chain_info *next = m_stores_head, *cur = next; cur; cur = next)
|
||||
{
|
||||
next = cur->next;
|
||||
|
@ -960,8 +961,10 @@ pass_store_merging::terminate_all_aliasing_chains (imm_store_chain_info
|
|||
unsigned int i;
|
||||
FOR_EACH_VEC_ELT (cur->m_store_info, i, info)
|
||||
{
|
||||
if (ref_maybe_used_by_stmt_p (stmt, gimple_assign_lhs (info->stmt))
|
||||
|| stmt_may_clobber_ref_p (stmt, gimple_assign_lhs (info->stmt)))
|
||||
tree lhs = gimple_assign_lhs (info->stmt);
|
||||
if (ref_maybe_used_by_stmt_p (stmt, lhs)
|
||||
|| stmt_may_clobber_ref_p (stmt, lhs)
|
||||
|| (store_lhs && refs_output_dependent_p (store_lhs, lhs)))
|
||||
{
|
||||
if (dump_file && (dump_flags & TDF_DETAILS))
|
||||
{
|
||||
|
|
|
@ -1,3 +1,10 @@
|
|||
2017-11-10 Jakub Jelinek <jakub@redhat.com>
|
||||
|
||||
PR bootstrap/82916
|
||||
* gcc.dg/store_merging_2.c: Only expect 2 successful mergings instead
|
||||
of 3.
|
||||
* gcc.dg/pr82916.c: New test.
|
||||
|
||||
2017-11-10 Thomas Preud'homme <thomas.preudhomme@arm.com>
|
||||
|
||||
* lib/scanasm.exp (scan-assembler): Extract filename from testname used
|
||||
|
|
|
@ -0,0 +1,47 @@
|
|||
/* PR bootstrap/82916 */
|
||||
/* { dg-do run } */
|
||||
/* { dg-options "-O2 -fno-tree-dse" } */
|
||||
|
||||
struct A { struct A *next; };
|
||||
struct C
|
||||
{
|
||||
int *of;
|
||||
struct C *parent, *prev, *next;
|
||||
int depth;
|
||||
int min;
|
||||
struct C *min_occ;
|
||||
};
|
||||
|
||||
__attribute__((noipa)) struct C *
|
||||
foo (int *node)
|
||||
{
|
||||
struct A *p = __builtin_malloc (sizeof (struct C));
|
||||
if (!p)
|
||||
return 0;
|
||||
p->next = 0;
|
||||
/* Originally placement new. */
|
||||
struct C *nw = (struct C *)(void *)p;
|
||||
nw->of = node;
|
||||
nw->parent = 0;
|
||||
nw->prev = 0;
|
||||
nw->next = 0;
|
||||
nw->depth = 0;
|
||||
nw->min_occ = nw;
|
||||
nw->min = 0;
|
||||
return nw;
|
||||
}
|
||||
|
||||
int
|
||||
main ()
|
||||
{
|
||||
int o;
|
||||
struct C *p = foo (&o);
|
||||
if (p)
|
||||
{
|
||||
if (p->of != &o || p->parent || p->prev || p->next || p->depth
|
||||
|| p->min || p->min_occ != p)
|
||||
__builtin_abort ();
|
||||
}
|
||||
__builtin_free (p);
|
||||
return 0;
|
||||
}
|
|
@ -77,4 +77,4 @@ main (void)
|
|||
return 0;
|
||||
}
|
||||
|
||||
/* { dg-final { scan-tree-dump-times "Merging successful" 3 "store-merging" } } */
|
||||
/* { dg-final { scan-tree-dump-times "Merging successful" 2 "store-merging" } } */
|
||||
|
|
Loading…
Reference in New Issue