OSDN Git Service

* gimple-fold.c (gimple_fold_obj_type_ref_known_binfo): Check that
authorhubicka <hubicka@138bc75d-0d04-0410-961f-82ee72b054a4>
Tue, 6 Jul 2010 11:44:34 +0000 (11:44 +0000)
committerhubicka <hubicka@138bc75d-0d04-0410-961f-82ee72b054a4>
Tue, 6 Jul 2010 11:44:34 +0000 (11:44 +0000)
function is still available to fold into.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@161866 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/ChangeLog
gcc/gimple-fold.c

index 156b55a..59455aa 100644 (file)
@@ -1,3 +1,8 @@
+2010-07-05  Jan Hubicka  <jh@suse.cz>
+
+       * gimple-fold.c (gimple_fold_obj_type_ref_known_binfo): Check that
+       function is still available to fold into.
+
 2010-07-05  Nathan Froyd  <froydnj@codesourcery.com>
 
        * vec.h (FOR_EACH_VEC_ELT_REVERSE): New macro.
index 6af6511..659102b 100644 (file)
@@ -1156,7 +1156,7 @@ gimple_fold_builtin (gimple stmt)
               fold_convert (TREE_TYPE (gimple_call_lhs (stmt)), val[0]);
 
          /* If the result is not a valid gimple value, or not a cast
-            of a valid gimple value, then we can not use the result.  */
+            of a valid gimple value, then we cannot use the result.  */
          if (is_gimple_val (new_val)
              || (is_gimple_cast (new_val)
                  && is_gimple_val (TREE_OPERAND (new_val, 0))))
@@ -1351,6 +1351,7 @@ gimple_fold_obj_type_ref_known_binfo (HOST_WIDE_INT token, tree known_binfo)
 {
   HOST_WIDE_INT i;
   tree v, fndecl;
+  struct cgraph_node *node;
 
   v = BINFO_VIRTUALS (known_binfo);
   i = 0;
@@ -1362,6 +1363,14 @@ gimple_fold_obj_type_ref_known_binfo (HOST_WIDE_INT token, tree known_binfo)
     }
 
   fndecl = TREE_VALUE (v);
+  node = cgraph_get_node (fndecl);
+  /* When cgraph node is missing and function is not public, we cannot
+     devirtualize.  This can happen in WHOPR when the actual method
+     ends up in other partition, because we found devirtualization
+     possibility too late.  */
+  if ((!node || !node->analyzed)
+      && (!TREE_PUBLIC (fndecl) || DECL_COMDAT (fndecl)))
+    return NULL;
   return build_fold_addr_expr (fndecl);
 }