diff options
author | Jan Hubicka <hubicka@ucw.cz> | 2014-07-09 18:03:14 +0200 |
---|---|---|
committer | Jan Hubicka <hubicka@gcc.gnu.org> | 2014-07-09 16:03:14 +0000 |
commit | 8ad274d2c28e6687804dfb7f0a529a54a896da00 (patch) | |
tree | 5cee96de52b8985dfd8d07c01815452e6c25067d /gcc | |
parent | 9af4687354ee7ca7acc3ec7d5aac008858851612 (diff) | |
download | gcc-8ad274d2c28e6687804dfb7f0a529a54a896da00.zip gcc-8ad274d2c28e6687804dfb7f0a529a54a896da00.tar.gz gcc-8ad274d2c28e6687804dfb7f0a529a54a896da00.tar.bz2 |
ipa-cp.c (devirtualization_time_bonus): Walk through aliases.
* ipa-cp.c (devirtualization_time_bonus): Walk through aliases.
* ipa-inline-analysis.c (estimate_edge_devirt_benefit): Likewise.
From-SVN: r212395
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/ChangeLog | 5 | ||||
-rw-r--r-- | gcc/ipa-cp.c | 4 | ||||
-rw-r--r-- | gcc/ipa-inline-analysis.c | 4 |
3 files changed, 13 insertions, 0 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index ad07474..0b94921 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,5 +1,10 @@ 2014-07-08 Jan Hubicka <hubicka@ucw.cz> + * ipa-cp.c (devirtualization_time_bonus): Walk through aliases. + * ipa-inline-analysis.c (estimate_edge_devirt_benefit): Likewise. + +2014-07-08 Jan Hubicka <hubicka@ucw.cz> + * rs6000/rs6000-protos.h (rs6000_xcoff_declare_object_name): Declare. * rs6000/rs6000.c: Inline output of .set instruction. (declare_alias_data): New struct. diff --git a/gcc/ipa-cp.c b/gcc/ipa-cp.c index d16d8c2..b6d66d9 100644 --- a/gcc/ipa-cp.c +++ b/gcc/ipa-cp.c @@ -1671,6 +1671,7 @@ devirtualization_time_bonus (struct cgraph_node *node, { struct cgraph_node *callee; struct inline_summary *isummary; + enum availability avail; tree target; target = ipa_get_indirect_edge_target (ie, known_csts, known_binfos, @@ -1683,6 +1684,9 @@ devirtualization_time_bonus (struct cgraph_node *node, callee = cgraph_get_node (target); if (!callee || !callee->definition) continue; + callee = cgraph_function_node (callee, &avail); + if (avail < AVAIL_AVAILABLE) + continue; isummary = inline_summary (callee); if (!isummary->inlinable) continue; diff --git a/gcc/ipa-inline-analysis.c b/gcc/ipa-inline-analysis.c index 9b50258..9e66a4c 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; } |