Commit 9e875fd8 by Jakub Jelinek Committed by Jakub Jelinek

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
parent db489777
2017-11-10 Jakub Jelinek <jakub@redhat.com> 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 PR rtl-optimization/82913
* compare-elim.c (try_merge_compare): Punt if def_insn is not * compare-elim.c (try_merge_compare): Punt if def_insn is not
single set. single set.
...@@ -947,6 +947,7 @@ pass_store_merging::terminate_all_aliasing_chains (imm_store_chain_info ...@@ -947,6 +947,7 @@ pass_store_merging::terminate_all_aliasing_chains (imm_store_chain_info
if (!gimple_vuse (stmt)) if (!gimple_vuse (stmt))
return false; 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) for (imm_store_chain_info *next = m_stores_head, *cur = next; cur; cur = next)
{ {
next = cur->next; next = cur->next;
...@@ -960,8 +961,10 @@ pass_store_merging::terminate_all_aliasing_chains (imm_store_chain_info ...@@ -960,8 +961,10 @@ pass_store_merging::terminate_all_aliasing_chains (imm_store_chain_info
unsigned int i; unsigned int i;
FOR_EACH_VEC_ELT (cur->m_store_info, i, info) FOR_EACH_VEC_ELT (cur->m_store_info, i, info)
{ {
if (ref_maybe_used_by_stmt_p (stmt, gimple_assign_lhs (info->stmt)) tree lhs = gimple_assign_lhs (info->stmt);
|| stmt_may_clobber_ref_p (stmt, 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)) if (dump_file && (dump_flags & TDF_DETAILS))
{ {
......
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> 2017-11-10 Thomas Preud'homme <thomas.preudhomme@arm.com>
* lib/scanasm.exp (scan-assembler): Extract filename from testname used * lib/scanasm.exp (scan-assembler): Extract filename from testname used
......
/* 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) ...@@ -77,4 +77,4 @@ main (void)
return 0; return 0;
} }
/* { dg-final { scan-tree-dump-times "Merging successful" 3 "store-merging" } } */ /* { dg-final { scan-tree-dump-times "Merging successful" 2 "store-merging" } } */
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment