]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
Fix 41626 from Jan Hubicka
authorJan Hubicka <jh@suse.cz>
Thu, 8 Oct 2009 18:52:57 +0000 (20:52 +0200)
committerMichael Meissner <meissner@gcc.gnu.org>
Thu, 8 Oct 2009 18:52:57 +0000 (18:52 +0000)
From-SVN: r152569

gcc/ChangeLog
gcc/cgraph.h
gcc/cgraphbuild.c
gcc/varasm.c
gcc/varpool.c

index c128a74a183c0d6087695212f1a476ec42a3e428..14eca8eae887c86fa66e8c4a1b718b9a9bd3031d 100644 (file)
@@ -1,3 +1,14 @@
+2009-10-08  Jan Hubicka  <jh@suse.cz>
+
+       PR middle-end/41626
+       * cgraphbuild.c (record_reference): When parameter DATA is NULL,
+       do not mark cgraph nodes as needed.
+       (record_references_in_initializer): Add new only_vars parameter.
+       * cgraph.h (record_references_in_initializer): New parameter.
+       * varasm.c (assemble_variable): Update call.
+       * varpool.c (varpool_analyze_pending_decls): Always look for
+       referenced vars.
+
 2009-10-08  Anatoly Sokolov  <aesok@post.ru>
 
        * config/avr/avr.c (last_insn_address) Remove variable.
index 438cd1e6fae0f6ba7a6ef01244d67118072926ce..016ce9de14c9b6437c623a8b0f9a31aed3419bd9 100644 (file)
@@ -459,7 +459,7 @@ struct cgraph_node *cgraph_function_versioning (struct cgraph_node *,
                                                bitmap);
 void tree_function_versioning (tree, tree, VEC (ipa_replace_map_p,gc)*, bool, bitmap);
 struct cgraph_node *save_inline_function_body (struct cgraph_node *);
-void record_references_in_initializer (tree);
+void record_references_in_initializer (tree, bool);
 bool cgraph_process_new_functions (void);
 
 bool cgraph_decide_is_function_needed (struct cgraph_node *, tree);
index d61def279ad44476ef37bec143c135055925bd08..65e3d67e14c8cc8e2fa4391b9a4bb6caf2154287 100644 (file)
@@ -33,13 +33,16 @@ along with GCC; see the file COPYING3.  If not see
 #include "tree-pass.h"
 
 /* Walk tree and record all calls and references to functions/variables.
-   Called via walk_tree: TP is pointer to tree to be examined.  */
+   Called via walk_tree: TP is pointer to tree to be examined.  
+   When DATA is non-null, record references to callgraph.
+   */
 
 static tree
-record_reference (tree *tp, int *walk_subtrees, void *data ATTRIBUTE_UNUSED)
+record_reference (tree *tp, int *walk_subtrees, void *data)
 {
   tree t = *tp;
   tree decl;
+  bool do_callgraph = data != NULL;
 
   switch (TREE_CODE (t))
     {
@@ -57,7 +60,7 @@ record_reference (tree *tp, int *walk_subtrees, void *data ATTRIBUTE_UNUSED)
       /* Record dereferences to the functions.  This makes the
         functions reachable unconditionally.  */
       decl = TREE_OPERAND (*tp, 0);
-      if (TREE_CODE (decl) == FUNCTION_DECL)
+      if (TREE_CODE (decl) == FUNCTION_DECL && do_callgraph)
        cgraph_mark_address_taken_node (cgraph_node (decl));
       break;
 
@@ -218,13 +221,15 @@ struct gimple_opt_pass pass_build_cgraph_edges =
 };
 
 /* Record references to functions and other variables present in the
-   initial value of DECL, a variable.  */
+   initial value of DECL, a variable.  
+   When ONLY_VARS is true, we mark needed only variables, not functions.  */
 
 void
-record_references_in_initializer (tree decl)
+record_references_in_initializer (tree decl, bool only_vars)
 {
   struct pointer_set_t *visited_nodes = pointer_set_create ();
-  walk_tree (&DECL_INITIAL (decl), record_reference, NULL, visited_nodes);
+  walk_tree (&DECL_INITIAL (decl), record_reference, 
+            only_vars ? NULL : decl, visited_nodes);
   pointer_set_destroy (visited_nodes);
 }
 
index 46ec00da18043b182765b1326985585980951d81..4c0b9a663a5ccdb26cf13779abe2194c40b811ce 100644 (file)
@@ -2082,7 +2082,7 @@ assemble_variable (tree decl, int top_level ATTRIBUTE_UNUSED,
             Without this, if the variable is placed in a
             section-anchored block, the template will only be marked
             when it's too late.  */
-         record_references_in_initializer (to);
+         record_references_in_initializer (to, false);
        }
 
       decl = to;
index f7b338ff44b0486e0a2a62846494122476c49399..8815efda249c71bca51b6a89bf9d077970082be2 100644 (file)
@@ -364,10 +364,9 @@ varpool_analyze_pending_decls (void)
           /* Compute the alignment early so function body expanders are
             already informed about increased alignment.  */
           align_variable (decl, 0);
-
-          if (DECL_INITIAL (decl))
-           record_references_in_initializer (decl);
        }
+      if (DECL_INITIAL (decl))
+       record_references_in_initializer (decl, analyzed);
       changed = true;
     }
   timevar_pop (TV_CGRAPH);