OSDN Git Service

2011-11-09 Richard Guenther <rguenther@suse.de>
authorrguenth <rguenth@138bc75d-0d04-0410-961f-82ee72b054a4>
Wed, 9 Nov 2011 08:32:26 +0000 (08:32 +0000)
committerrguenth <rguenth@138bc75d-0d04-0410-961f-82ee72b054a4>
Wed, 9 Nov 2011 08:32:26 +0000 (08:32 +0000)
* gimple-fold.c (canonicalize_constructor_val): Mark
address-taken variables addressable.

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

gcc/ChangeLog
gcc/gimple-fold.c

index 12425f4..e2d23ea 100644 (file)
@@ -1,3 +1,8 @@
+2011-11-09  Richard Guenther  <rguenther@suse.de>
+
+       * gimple-fold.c (canonicalize_constructor_val): Mark
+       address-taken variables addressable.
+
 2011-11-09  Ira Rosen  <ira.rosen@linaro.org>
 
        PR tree-optimization/51015
index 08b7ccc..0da5eef 100644 (file)
@@ -137,9 +137,12 @@ canonicalize_constructor_val (tree cval)
              || TREE_CODE (base) == FUNCTION_DECL)
          && !can_refer_decl_in_current_unit_p (base))
        return NULL_TREE;
-      if (cfun && gimple_referenced_vars (cfun)
-         && base && TREE_CODE (base) == VAR_DECL)
-       add_referenced_var (base);
+      if (base && TREE_CODE (base) == VAR_DECL)
+       {
+         TREE_ADDRESSABLE (base) = 1;
+         if (cfun && gimple_referenced_vars (cfun))
+           add_referenced_var (base);
+       }
       /* Fixup types in global initializers.  */
       if (TREE_TYPE (TREE_TYPE (cval)) != TREE_TYPE (TREE_OPERAND (cval, 0)))
        cval = build_fold_addr_expr (TREE_OPERAND (cval, 0));