From: Jakub Jelinek Date: Tue, 5 Jan 2010 08:40:50 +0000 (+0100) Subject: re PR tree-optimization/42508 (wrong code with "-O1 -fipa-sra") X-Git-Tag: releases/gcc-4.5.0~1394 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=566f27e42ca00f65d101e6a7b0096554a0cc452d;p=thirdparty%2Fgcc.git re PR tree-optimization/42508 (wrong code with "-O1 -fipa-sra") PR tree-optimization/42508 * tree-sra.c (convert_callers): Check for recursive call by comparing cgraph nodes instead of decls. (modify_function): Call ipa_modify_formal_parameters also on all same_body aliases. * g++.dg/opt/pr42508.C: New test. * cgraphunit.c (cgraph_materialize_all_clones): Compare cgraph nodes when checking for same_body aliases. From-SVN: r155640 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index da9ed1af3373..b45e59c54979 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,14 @@ +2010-01-05 Jakub Jelinek + + PR tree-optimization/42508 + * tree-sra.c (convert_callers): Check for recursive call + by comparing cgraph nodes instead of decls. + (modify_function): Call ipa_modify_formal_parameters also + on all same_body aliases. + + * cgraphunit.c (cgraph_materialize_all_clones): Compare + cgraph nodes when checking for same_body aliases. + 2010-01-05 Richard Guenther * tree-ssa-pre.c (get_or_alloc_expr_for_name): Avoid redundant diff --git a/gcc/cgraphunit.c b/gcc/cgraphunit.c index cf1a00154727..ebe662ad6393 100644 --- a/gcc/cgraphunit.c +++ b/gcc/cgraphunit.c @@ -1,5 +1,5 @@ /* Callgraph based interprocedural optimizations. - Copyright (C) 2003, 2004, 2005, 2006, 2007, 2008, 2009 + Copyright (C) 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010 Free Software Foundation, Inc. Contributed by Jan Hubicka @@ -2323,20 +2323,9 @@ cgraph_materialize_all_clones (void) gimple new_stmt; gimple_stmt_iterator gsi; - if (e->callee->same_body) - { - struct cgraph_node *alias; - - for (alias = e->callee->same_body; - alias; - alias = alias->next) - if (decl == alias->decl) - break; - /* Don't update call from same body alias to the real - function. */ - if (alias) - continue; - } + if (cgraph_get_node (decl) == cgraph_get_node (e->callee->decl)) + /* Don't update call from same body alias to the real function. */ + continue; if (cgraph_dump_file) { diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 08622cb1fda2..89358798c846 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2010-01-05 Jakub Jelinek + + PR tree-optimization/42508 + * g++.dg/opt/pr42508.C: New test. + 2010-01-05 Tobias Burnus PR fortran/41872 diff --git a/gcc/testsuite/g++.dg/opt/pr42508.C b/gcc/testsuite/g++.dg/opt/pr42508.C new file mode 100644 index 000000000000..68dd4c693975 --- /dev/null +++ b/gcc/testsuite/g++.dg/opt/pr42508.C @@ -0,0 +1,33 @@ +// PR tree-optimization/42508 +// { dg-do run } +// { dg-options "-O1 -fipa-sra" } + +extern "C" void abort (); + +int v[10], vidx; + +struct A +{ + A *prev; + int i; + ~A() + { + v[vidx++] = i; + delete prev; + } +}; + +int +main () +{ + A *a1 = new A (); + A *a2 = new A (); + a1->prev = 0; + a1->i = 1; + a2->prev = a1; + a2->i = 2; + delete a2; + if (vidx != 2 || v[0] != 2 || v[1] != 1) + abort (); + return 0; +} diff --git a/gcc/tree-sra.c b/gcc/tree-sra.c index f45169277e76..f0e874f2053e 100644 --- a/gcc/tree-sra.c +++ b/gcc/tree-sra.c @@ -3800,8 +3800,11 @@ convert_callers (struct cgraph_node *node, ipa_parm_adjustment_vec adjustments) for (gsi = gsi_start_bb (this_block); !gsi_end_p (gsi); gsi_next (&gsi)) { gimple stmt = gsi_stmt (gsi); - if (gimple_code (stmt) == GIMPLE_CALL - && gimple_call_fndecl (stmt) == node->decl) + tree call_fndecl; + if (gimple_code (stmt) != GIMPLE_CALL) + continue; + call_fndecl = gimple_call_fndecl (stmt); + if (call_fndecl && cgraph_get_node (call_fndecl) == node) { if (dump_file) fprintf (dump_file, "Adjusting recursive call"); @@ -3819,6 +3822,11 @@ convert_callers (struct cgraph_node *node, ipa_parm_adjustment_vec adjustments) static void modify_function (struct cgraph_node *node, ipa_parm_adjustment_vec adjustments) { + struct cgraph_node *alias; + for (alias = node->same_body; alias; alias = alias->next) + ipa_modify_formal_parameters (alias->decl, adjustments, "ISRA"); + /* current_function_decl must be handled last, after same_body aliases, + as following functions will use what it computed. */ ipa_modify_formal_parameters (current_function_decl, adjustments, "ISRA"); scan_function (sra_ipa_modify_expr, sra_ipa_modify_assign, replace_removed_params_ssa_names, false, adjustments);