aboutsummaryrefslogtreecommitdiff
path: root/gcc/ipa-inline-analysis.c
diff options
context:
space:
mode:
authorJan Hubicka <jh@suse.cz>2011-06-04 16:24:20 +0200
committerJan Hubicka <hubicka@gcc.gnu.org>2011-06-04 14:24:20 +0000
commite3195c52b954dd2956385f6b209e2d51785d13a1 (patch)
tree5ae5e94e0ba3f23be6459d3fd1878156e922be26 /gcc/ipa-inline-analysis.c
parent047d33a0d40c52a5b227766c9af65d695d10b190 (diff)
downloadgcc-e3195c52b954dd2956385f6b209e2d51785d13a1.zip
gcc-e3195c52b954dd2956385f6b209e2d51785d13a1.tar.gz
gcc-e3195c52b954dd2956385f6b209e2d51785d13a1.tar.bz2
re PR tree-optimization/48929 (ICE: in estimate_size_after_inlining, at ipa-inline-analysis.c:1961 with -findirect-inlining)
PR tree-optimize/48929 * gcc.c-torture/compile/pr48929.c: New testcase. * ipa-inline-analysis.c (remap_edge_predicates): Fix handling of empty predicate. From-SVN: r174638
Diffstat (limited to 'gcc/ipa-inline-analysis.c')
-rw-r--r--gcc/ipa-inline-analysis.c4
1 files changed, 4 insertions, 0 deletions
diff --git a/gcc/ipa-inline-analysis.c b/gcc/ipa-inline-analysis.c
index 4a65dd5..45bfeb6 100644
--- a/gcc/ipa-inline-analysis.c
+++ b/gcc/ipa-inline-analysis.c
@@ -1949,6 +1949,8 @@ remap_edge_predicates (struct cgraph_node *node,
if (!e->inline_failed)
remap_edge_predicates (e->callee, info, callee_info, operand_map,
possible_truths, toplev_predicate);
+ else
+ edge_set_predicate (e, toplev_predicate);
}
for (e = node->indirect_calls; e; e = e->next_callee)
{
@@ -1969,6 +1971,8 @@ remap_edge_predicates (struct cgraph_node *node,
e->frequency = 0;
}
}
+ else
+ edge_set_predicate (e, toplev_predicate);
}
}