diff options
author | hubicka <hubicka@138bc75d-0d04-0410-961f-82ee72b054a4> | 2014-07-09 16:03:14 +0000 |
---|---|---|
committer | hubicka <hubicka@138bc75d-0d04-0410-961f-82ee72b054a4> | 2014-07-09 16:03:14 +0000 |
commit | f28422b679fc0745d3a7abffdad3f1fa2f5e6621 (patch) | |
tree | 5cee96de52b8985dfd8d07c01815452e6c25067d /gcc/ipa-inline-analysis.c | |
parent | b93c6f4d28542d8fe0d12aacee07d296150db2cd (diff) | |
download | gcc-f28422b679fc0745d3a7abffdad3f1fa2f5e6621.tar.gz |
* ipa-cp.c (devirtualization_time_bonus): Walk through aliases.
* ipa-inline-analysis.c (estimate_edge_devirt_benefit): Likewise.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@212395 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/ipa-inline-analysis.c')
-rw-r--r-- | gcc/ipa-inline-analysis.c | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/gcc/ipa-inline-analysis.c b/gcc/ipa-inline-analysis.c index 9b50258986e..9e66a4c5a5c 100644 --- a/gcc/ipa-inline-analysis.c +++ b/gcc/ipa-inline-analysis.c @@ -2971,6 +2971,7 @@ estimate_edge_devirt_benefit (struct cgraph_edge *ie, tree target; struct cgraph_node *callee; struct inline_summary *isummary; + enum availability avail; if (!known_vals.exists () && !known_binfos.exists ()) return false; @@ -2991,6 +2992,9 @@ estimate_edge_devirt_benefit (struct cgraph_edge *ie, callee = cgraph_get_node (target); if (!callee || !callee->definition) return false; + callee = cgraph_function_node (callee, &avail); + if (avail < AVAIL_AVAILABLE) + return false; isummary = inline_summary (callee); return isummary->inlinable; } |