aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorJan Hubicka <hubicka@ucw.cz>2014-07-09 18:03:14 +0200
committerJan Hubicka <hubicka@gcc.gnu.org>2014-07-09 16:03:14 +0000
commit8ad274d2c28e6687804dfb7f0a529a54a896da00 (patch)
tree5cee96de52b8985dfd8d07c01815452e6c25067d /gcc
parent9af4687354ee7ca7acc3ec7d5aac008858851612 (diff)
downloadgcc-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/ChangeLog5
-rw-r--r--gcc/ipa-cp.c4
-rw-r--r--gcc/ipa-inline-analysis.c4
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;
}