aboutsummaryrefslogtreecommitdiffstats
path: root/gcc-4.9/gcc/tree-sra.c
diff options
context:
space:
mode:
authorRong Xu <xur@google.com>2014-07-21 16:47:22 -0700
committerRong Xu <xur@google.com>2014-07-29 15:31:03 -0700
commit38a8aecfb882072900434499696b5c32a2274515 (patch)
tree2aac97f0ae24b03cd98c1a06e989c031c173f889 /gcc-4.9/gcc/tree-sra.c
parentc231900e5dcc14d8296bd9f62b45997a49d4d5e7 (diff)
downloadtoolchain_gcc-38a8aecfb882072900434499696b5c32a2274515.tar.gz
toolchain_gcc-38a8aecfb882072900434499696b5c32a2274515.tar.bz2
toolchain_gcc-38a8aecfb882072900434499696b5c32a2274515.zip
[4.9] Switch gcc-4.9 to use google/gcc-4_9 branch.
This source drop uses svn version r212828 of google/gcc-4.9 branch. We also cherry-picked r213062, r213063 and r213064 to fix windows build issues. All gcc-4.9 patches before July 3rd are ported to google/gcc-4.9. The following prior commits has not been merged to google branch yet. (They are included in this commit). e7af147f979e657fe2df00808e5b4319b0e088c6, baf87df3cb2683649ba7e9872362a7e721117c23, and c231900e5dcc14d8296bd9f62b45997a49d4d5e7. Change-Id: I4bea3ea470387ff751c2be4cb0d4a12059b9299b
Diffstat (limited to 'gcc-4.9/gcc/tree-sra.c')
-rw-r--r--gcc-4.9/gcc/tree-sra.c13
1 files changed, 10 insertions, 3 deletions
diff --git a/gcc-4.9/gcc/tree-sra.c b/gcc-4.9/gcc/tree-sra.c
index ffef13d16..535df57c0 100644
--- a/gcc-4.9/gcc/tree-sra.c
+++ b/gcc-4.9/gcc/tree-sra.c
@@ -105,11 +105,13 @@ along with GCC; see the file COPYING3. If not see
#include "ipa-prop.h"
#include "statistics.h"
#include "params.h"
+#include "toplev.h"
#include "target.h"
#include "flags.h"
#include "dbgcnt.h"
#include "tree-inline.h"
#include "gimple-pretty-print.h"
+#include "l-ipo.h"
#include "ipa-inline.h"
#include "ipa-utils.h"
@@ -4801,7 +4803,8 @@ convert_callers_for_node (struct cgraph_node *node,
xstrdup (cs->callee->name ()),
cs->callee->order);
- ipa_modify_call_arguments (cs, cs->call_stmt, *adjustments);
+ if (cs->call_stmt)
+ ipa_modify_call_arguments (cs, cs->call_stmt, *adjustments);
pop_cfun ();
}
@@ -4861,12 +4864,15 @@ modify_function (struct cgraph_node *node, ipa_parm_adjustment_vec adjustments)
{
struct cgraph_node *new_node;
bool cfg_changed;
- vec<cgraph_edge_p> redirect_callers = collect_callers_of_node (node);
rebuild_cgraph_edges ();
free_dominance_info (CDI_DOMINATORS);
pop_cfun ();
+ /* This must be done after rebuilding cgraph edges for node above.
+ Otherwise any recursive calls to node that are recorded in
+ redirect_callers will be corrupted. */
+ vec<cgraph_edge_p> redirect_callers = collect_callers_of_node (node);
new_node = cgraph_function_versioning (node, redirect_callers,
NULL,
NULL, false, NULL, NULL, "isra");
@@ -4878,6 +4884,7 @@ modify_function (struct cgraph_node *node, ipa_parm_adjustment_vec adjustments)
sra_ipa_reset_debug_stmts (adjustments);
convert_callers (new_node, node->decl, adjustments);
cgraph_make_node_local (new_node);
+
return cfg_changed;
}
@@ -5049,7 +5056,7 @@ ipa_early_sra (void)
static bool
ipa_early_sra_gate (void)
{
- return flag_ipa_sra && dbg_cnt (eipa_sra);
+ return flag_ipa_sra && !flag_dyn_ipa && dbg_cnt (eipa_sra);
}
namespace {