From 6365c92707e013c1bc7c262bd762ac8bfacbdda3 Mon Sep 17 00:00:00 2001 From: hubicka Date: Thu, 15 Jan 2015 23:11:49 +0000 Subject: [PATCH] PR ipa/64612 * ipa-inline-transform.c (can_remove_node_now_p): Fix handling of comdat locals. (inline_call): Fix removal of aliases. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@219696 138bc75d-0d04-0410-961f-82ee72b054a4 --- gcc/ChangeLog | 7 +++++++ gcc/ipa-inline-transform.c | 5 +++-- 2 files changed, 10 insertions(+), 2 deletions(-) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 087bcd5..d2770f0 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,10 @@ +2015-01-15 Jan Hubicka + + PR ipa/64612 + * ipa-inline-transform.c (can_remove_node_now_p): Fix handling + of comdat locals. + (inline_call): Fix removal of aliases. + 2015-01-15 Jakub Jelinek * flag-types.h (enum sanitize_code): Add SANITIZE_VPTR, diff --git a/gcc/ipa-inline-transform.c b/gcc/ipa-inline-transform.c index 7e5eda9..1c4b23a 100644 --- a/gcc/ipa-inline-transform.c +++ b/gcc/ipa-inline-transform.c @@ -139,7 +139,7 @@ can_remove_node_now_p (struct cgraph_node *node, struct cgraph_edge *e) /* When we see same comdat group, we need to be sure that all items can be removed. */ - if (!node->same_comdat_group) + if (!node->same_comdat_group || !node->externally_visible) return true; for (next = dyn_cast (node->same_comdat_group); next != node; next = dyn_cast (next->same_comdat_group)) @@ -310,7 +310,8 @@ inline_call (struct cgraph_edge *e, bool update_original, while (alias && alias != callee) { if (!alias->callers - && can_remove_node_now_p (alias, e)) + && can_remove_node_now_p (alias, + !e->next_caller && !e->prev_caller ? e : NULL)) { next_alias = alias->get_alias_target (); alias->remove (); -- 2.7.4