From: marxin Date: Sun, 5 Apr 2015 17:17:29 +0000 (+0000) Subject: Fix PR ipa/65665 X-Git-Tag: upstream/5.3.0~1024 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=1bb258de981c3ddfb69df5df119beaf71786ce23;p=platform%2Fupstream%2Flinaro-gcc.git Fix PR ipa/65665 PR ipa/65665 * ipa-icf.c (sem_function::equals_wpa): Verify that IPA CP has computed data structure. (sem_item_optimizer::update_hash_by_addr_refs): Likewise. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@221872 138bc75d-0d04-0410-961f-82ee72b054a4 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index a0e973b..f9cb04c 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,10 @@ +2015-04-05 Martin Liska + + PR ipa/65665 + * ipa-icf.c (sem_function::equals_wpa): Verify that IPA CP + has computed data structure. + (sem_item_optimizer::update_hash_by_addr_refs): Likewise. + 2015-04-04 Jan Hubicka * invoke.texi (inline-unit-growth): Increase growth to 20% diff --git a/gcc/ipa-icf.c b/gcc/ipa-icf.c index 8626730..8f8a0cf 100644 --- a/gcc/ipa-icf.c +++ b/gcc/ipa-icf.c @@ -535,7 +535,8 @@ sem_function::equals_wpa (sem_item *item, && (TREE_CODE (TREE_TYPE (decl)) == METHOD_TYPE || TREE_CODE (TREE_TYPE (item->decl)) == METHOD_TYPE) && (ipa_node_params_sum == NULL - || ipa_is_param_used (IPA_NODE_REF (dyn_cast (node)), + || IPA_NODE_REF (get_node ())->descriptors.is_empty () + || ipa_is_param_used (IPA_NODE_REF (get_node ()), 0)) && compare_polymorphic_p ()) { @@ -2501,14 +2502,15 @@ sem_item_optimizer::update_hash_by_addr_refs () m_items[i]->update_hash_by_addr_refs (m_symtab_node_map); if (m_items[i]->type == FUNC) { + cgraph_node *cnode = dyn_cast (m_items[i]->node); + if (TREE_CODE (TREE_TYPE (m_items[i]->decl)) == METHOD_TYPE && contains_polymorphic_type_p (method_class_type (TREE_TYPE (m_items[i]->decl))) && (DECL_CXX_CONSTRUCTOR_P (m_items[i]->decl) || ((ipa_node_params_sum == NULL - || ipa_is_param_used ( - IPA_NODE_REF - (dyn_cast (m_items[i]->node)), 0)) + || IPA_NODE_REF (cnode)->descriptors.is_empty () + || ipa_is_param_used (IPA_NODE_REF (cnode), 0)) && static_cast (m_items[i]) ->compare_polymorphic_p ()))) {