Hi,
    this small patch prepares remaining infrastructure needed for the new pass.

Changelog:

2014-06-13  Martin Liska  <mli...@suse.cz>
            Honza Hubicka  <hubi...@ucw.cz>

        * ipa-utils.h (polymorphic_type_binfo_p): Function marked external
        instead of static.
        * ipa-devirt.c (polymorphic_type_binfo_p): Likewise.
        * ipa-prop.h (count_formal_params): Likewise.
        * ipa-prop.c (count_formal_params): Likewise.
        * ipa-utils.c (ipa_merge_profiles): Be more tolerant if we merge
        profiles for semantically equivalent functions.
        * passes.c (do_per_function): If we load body of a function during WPA,
        this condition should behave same.
        * varpool.c (ctor_for_folding): More tolerant assert for variable
        aliases created during WPA.
---
 gcc/ipa-devirt.c | 2 +-
 gcc/ipa-prop.c   | 2 +-
 gcc/ipa-prop.h   | 1 +
 gcc/ipa-utils.c  | 9 ++-------
 gcc/ipa-utils.h  | 2 ++
 gcc/passes.c     | 2 +-
 gcc/varpool.c    | 1 +
 7 files changed, 9 insertions(+), 10 deletions(-)

diff --git a/gcc/ipa-devirt.c b/gcc/ipa-devirt.c
index d733461..18592d7 100644
--- a/gcc/ipa-devirt.c
+++ b/gcc/ipa-devirt.c
@@ -176,7 +176,7 @@ struct GTY(()) odr_type_d
    inheritance (because vtables are shared).  Look up the BINFO of type
    and check presence of its vtable.  */
 
-static inline bool
+bool
 polymorphic_type_binfo_p (tree binfo)
 {
   /* See if BINFO's type has an virtual table associtated with it.  */
diff --git a/gcc/ipa-prop.c b/gcc/ipa-prop.c
index b67deed..60bda71 100644
--- a/gcc/ipa-prop.c
+++ b/gcc/ipa-prop.c
@@ -210,7 +210,7 @@ ipa_populate_param_decls (struct cgraph_node *node,
 
 /* Return how many formal parameters FNDECL has.  */
 
-static inline int
+int
 count_formal_params (tree fndecl)
 {
   tree parm;
diff --git a/gcc/ipa-prop.h b/gcc/ipa-prop.h
index cb23698..87573ff 100644
--- a/gcc/ipa-prop.h
+++ b/gcc/ipa-prop.h
@@ -529,6 +529,7 @@ void ipa_free_all_edge_args (void);
 void ipa_free_all_structures_after_ipa_cp (void);
 void ipa_free_all_structures_after_iinln (void);
 void ipa_register_cgraph_hooks (void);
+int count_formal_params (tree fndecl);
 
 /* This function ensures the array of node param infos is big enough to
    accommodate a structure for all nodes and reallocates it if not.  */
diff --git a/gcc/ipa-utils.c b/gcc/ipa-utils.c
index 8e7c7cb..bc2b958 100644
--- a/gcc/ipa-utils.c
+++ b/gcc/ipa-utils.c
@@ -660,13 +660,8 @@ ipa_merge_profiles (struct cgraph_node *dst,
   if (dst->tp_first_run > src->tp_first_run && src->tp_first_run)
     dst->tp_first_run = src->tp_first_run;
 
-  if (src->profile_id)
-    {
-      if (!dst->profile_id)
-       dst->profile_id = src->profile_id;
-      else
-       gcc_assert (src->profile_id == dst->profile_id);
-    }
+  if (src->profile_id && !dst->profile_id)
+    dst->profile_id = src->profile_id;
 
   if (!dst->count)
     return;
diff --git a/gcc/ipa-utils.h b/gcc/ipa-utils.h
index a2c985a..996249a 100644
--- a/gcc/ipa-utils.h
+++ b/gcc/ipa-utils.h
@@ -72,6 +72,8 @@ struct odr_type_d;
 typedef odr_type_d *odr_type;
 void build_type_inheritance_graph (void);
 void update_type_inheritance_graph (void);
+bool polymorphic_type_binfo_p (tree binfo);
+
 vec <cgraph_node *>
 possible_polymorphic_call_targets (tree, HOST_WIDE_INT,
                                   ipa_polymorphic_call_context,
diff --git a/gcc/passes.c b/gcc/passes.c
index 4366251..9fdfe51 100644
--- a/gcc/passes.c
+++ b/gcc/passes.c
@@ -1506,7 +1506,7 @@ do_per_function (void (*callback) (function *, void 
*data), void *data)
     {
       struct cgraph_node *node;
       FOR_EACH_DEFINED_FUNCTION (node)
-       if (node->analyzed && gimple_has_body_p (node->decl)
+       if (node->analyzed && (gimple_has_body_p (node->decl) && !in_lto_p)
            && (!node->clone_of || node->decl != node->clone_of->decl))
          callback (DECL_STRUCT_FUNCTION (node->decl), data);
     }
diff --git a/gcc/varpool.c b/gcc/varpool.c
index ff67127..5cc558e 100644
--- a/gcc/varpool.c
+++ b/gcc/varpool.c
@@ -293,6 +293,7 @@ ctor_for_folding (tree decl)
   if (decl != real_decl)
     {
       gcc_assert (!DECL_INITIAL (decl)
+                 || (node->alias && varpool_alias_target (node) == real_node)
                  || DECL_INITIAL (decl) == error_mark_node);
       if (lookup_attribute ("weakref", DECL_ATTRIBUTES (decl)))
        {
-- 
1.8.4.5


Reply via email to