aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorEric Botcazou <ebotcazou@adacore.com>2019-11-25 10:48:55 +0000
committerEric Botcazou <ebotcazou@adacore.com>2019-11-25 10:48:55 +0000
commit18ea6e6e1cf48bda0edf99ad5ad0d888132d28c3 (patch)
tree5be921b4dc8697403ff531e31f135ddf88ee3922
parent784022efe10391c5bc9cd5ecc018f2e7b2440eb5 (diff)
PR ada/92362
* gcc-interface/trans.c (gnat_to_gnu) <N_Attribute_Definition_Clause>: Use a temporary instead of clobbering the result with a freeze node. git-svn-id: https://gcc.gnu.org/svn/gcc/trunk@278675 138bc75d-0d04-0410-961f-82ee72b054a4
-rw-r--r--gcc/ada/ChangeLog6
-rw-r--r--gcc/ada/gcc-interface/trans.c8
-rw-r--r--gcc/testsuite/ChangeLog4
-rw-r--r--gcc/testsuite/gnat.dg/addr14.adb24
4 files changed, 38 insertions, 4 deletions
diff --git a/gcc/ada/ChangeLog b/gcc/ada/ChangeLog
index a5b2a7c2b2a..dc00791e10a 100644
--- a/gcc/ada/ChangeLog
+++ b/gcc/ada/ChangeLog
@@ -1,5 +1,11 @@
2019-11-25 Eric Botcazou <ebotcazou@adacore.com>
+ PR ada/92362
+ * gcc-interface/trans.c (gnat_to_gnu) <N_Attribute_Definition_Clause>:
+ Use a temporary instead of clobbering the result with a freeze node.
+
+2019-11-25 Eric Botcazou <ebotcazou@adacore.com>
+
PR ada/92575
* expect.c (__gnat_expect_poll [VMS, HPUX]): Fix typo.
diff --git a/gcc/ada/gcc-interface/trans.c b/gcc/ada/gcc-interface/trans.c
index 61e05d52a54..3d6f381492a 100644
--- a/gcc/ada/gcc-interface/trans.c
+++ b/gcc/ada/gcc-interface/trans.c
@@ -8421,7 +8421,7 @@ gnat_to_gnu (Node_Id gnat_node)
gnat_temp = Entity (Name (gnat_node));
if (Freeze_Node (gnat_temp))
{
- tree gnu_address = gnat_to_gnu (Expression (gnat_node));
+ tree gnu_address = gnat_to_gnu (Expression (gnat_node)), gnu_temp;
/* Get the value to use as the address and save it as the equivalent
for the object; when it is frozen, gnat_to_gnu_entity will do the
@@ -8431,7 +8431,7 @@ gnat_to_gnu (Node_Id gnat_node)
of the object is limited and it is initialized with the result of
a function call. */
if (Is_Subprogram (gnat_temp))
- gnu_result = gnu_address;
+ gnu_temp = gnu_address;
else
{
tree gnu_type = gnat_to_gnu_type (Etype (gnat_temp));
@@ -8440,11 +8440,11 @@ gnat_to_gnu (Node_Id gnat_node)
gnu_type
= build_reference_type_for_mode (gnu_type, ptr_mode, true);
gnu_address = convert (gnu_type, gnu_address);
- gnu_result
+ gnu_temp
= build_unary_op (INDIRECT_REF, NULL_TREE, gnu_address);
}
- save_gnu_tree (gnat_temp, gnu_result, true);
+ save_gnu_tree (gnat_temp, gnu_temp, true);
}
break;
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index b8558187c57..4c0553f0ce8 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,7 @@
+2019-11-25 Eric Botcazou <ebotcazou@adacore.com>
+
+ * gnat.dg/addr14.adb: New test.
+
2019-11-25 Mark Eggleston <mark.eggleston@codethink.com>
Jim MacArthur <jim.macarthur@codethink.co.uk>
diff --git a/gcc/testsuite/gnat.dg/addr14.adb b/gcc/testsuite/gnat.dg/addr14.adb
new file mode 100644
index 00000000000..e92c902f038
--- /dev/null
+++ b/gcc/testsuite/gnat.dg/addr14.adb
@@ -0,0 +1,24 @@
+-- { dg-do run }
+
+with System;
+
+procedure Addr14 is
+
+ type Arr is array (1 .. 4) of aliased Integer;
+
+ A : Arr := (1, 2, 3, 4);
+ I : Natural := 0;
+
+ function Get_Address return System.Address is
+ begin
+ I := I + 1;
+ return A(I)'Address;
+ end;
+
+ Foo : Integer with Address => Get_Address;
+
+begin
+ if Foo /= 1 then
+ raise Program_Error;
+ end if;
+end;