aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorEric Botcazou <ebotcazou@adacore.com>2016-03-07 08:08:27 +0000
committerEric Botcazou <ebotcazou@gcc.gnu.org>2016-03-07 08:08:27 +0000
commit1878be32235c6f9c52a5368b18650b215dbdd508 (patch)
tree2113fdf3d1c062b5b541d1e6edecc119214043c0 /gcc
parent51b3616138665bd00e16a197326ddacb2050c5b0 (diff)
downloadgcc-1878be32235c6f9c52a5368b18650b215dbdd508.zip
gcc-1878be32235c6f9c52a5368b18650b215dbdd508.tar.gz
gcc-1878be32235c6f9c52a5368b18650b215dbdd508.tar.bz2
decl.c (gnat_to_gnu_entity): Always mark the expression of a renaming manually in case #3.
* gcc-interface/decl.c (gnat_to_gnu_entity) <E_Variable>: Always mark the expression of a renaming manually in case #3. From-SVN: r234018
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ada/ChangeLog5
-rw-r--r--gcc/ada/gcc-interface/decl.c10
-rw-r--r--gcc/testsuite/ChangeLog4
-rw-r--r--gcc/testsuite/gnat.dg/renaming9.adb12
-rw-r--r--gcc/testsuite/gnat.dg/renaming9.ads16
5 files changed, 41 insertions, 6 deletions
diff --git a/gcc/ada/ChangeLog b/gcc/ada/ChangeLog
index cb5aeb5..0573865 100644
--- a/gcc/ada/ChangeLog
+++ b/gcc/ada/ChangeLog
@@ -1,3 +1,8 @@
+2016-03-07 Eric Botcazou <ebotcazou@adacore.com>
+
+ * gcc-interface/decl.c (gnat_to_gnu_entity) <E_Variable>: Always mark
+ the expression of a renaming manually in case #3.
+
2016-03-02 Dominik Vogt <vogt@linux.vnet.ibm.com>
* system-linux-s390.adsx: Enable Stack_Check_Probes.
diff --git a/gcc/ada/gcc-interface/decl.c b/gcc/ada/gcc-interface/decl.c
index 7ea5ff8..4b0ce28 100644
--- a/gcc/ada/gcc-interface/decl.c
+++ b/gcc/ada/gcc-interface/decl.c
@@ -1058,12 +1058,10 @@ gnat_to_gnu_entity (Entity_Id gnat_entity, tree gnu_expr, int definition)
= elaborate_reference (gnu_expr, gnat_entity, definition,
&init);
- /* If we are not defining the entity, the expression will not
- be attached through DECL_INITIAL so it needs to be marked
- manually because it will likely be shared. Likewise for a
- dereference as it will be folded by the ADDR_EXPR below. */
- if ((!definition || TREE_CODE (renamed_obj) == INDIRECT_REF)
- && global_bindings_p ())
+ /* The expression needs to be marked manually because it will
+ likely be shared, even for a definition since the ADDR_EXPR
+ built below can cause the first few nodes to be folded. */
+ if (global_bindings_p ())
MARK_VISITED (renamed_obj);
if (type_annotate_only
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 808b0c8..182e917 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,7 @@
+2016-03-07 Eric Botcazou <ebotcazou@adacore.com>
+
+ * gnat.dg/renaming9.ad[sb]: New testcase.
+
2016-03-05 Jakub Jelinek <jakub@redhat.com>
PR c++/70084
diff --git a/gcc/testsuite/gnat.dg/renaming9.adb b/gcc/testsuite/gnat.dg/renaming9.adb
new file mode 100644
index 0000000..c50243e
--- /dev/null
+++ b/gcc/testsuite/gnat.dg/renaming9.adb
@@ -0,0 +1,12 @@
+-- { dg-do compile }
+
+package body Renaming9 is
+
+ procedure Proc is
+ begin
+ Obj.I := 0;
+ end;
+
+begin
+ Obj.I := 0;
+end Renaming9;
diff --git a/gcc/testsuite/gnat.dg/renaming9.ads b/gcc/testsuite/gnat.dg/renaming9.ads
new file mode 100644
index 0000000..ce6b4ed
--- /dev/null
+++ b/gcc/testsuite/gnat.dg/renaming9.ads
@@ -0,0 +1,16 @@
+package Renaming9 is
+
+ pragma Elaborate_Body;
+
+ type Object is tagged null record;
+
+ type Pointer is access all Object'Class;
+
+ type Derived is new Object with record
+ I : Integer;
+ end record;
+
+ Ptr : Pointer := new Derived;
+ Obj : Derived renames Derived (Ptr.all);
+
+end Renaming9;