re PR ada/92362 (double elaboration of expression in Address aspect)
authorEric Botcazou <ebotcazou@adacore.com>
Mon, 25 Nov 2019 10:48:55 +0000 (10:48 +0000)
committerEric Botcazou <ebotcazou@gcc.gnu.org>
Mon, 25 Nov 2019 10:48:55 +0000 (10:48 +0000)
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.

From-SVN: r278675

gcc/ada/ChangeLog
gcc/ada/gcc-interface/trans.c
gcc/testsuite/ChangeLog
gcc/testsuite/gnat.dg/addr14.adb [new file with mode: 0644]

index a5b2a7c2b2ad43e3494b0b7ad2568d40fa4a0c96..dc00791e10a263833fa82bd33d76cdcb541a7253 100644 (file)
@@ -1,3 +1,9 @@
+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
index 61e05d52a54b0a816a9aad26912587ee123ad206..3d6f381492abdd4da62d876b266275b7ab0fb122 100644 (file)
@@ -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;
 
index b8558187c57a7a5b5c85b9a66fac3605b63e17e6..4c0553f0ce823c1d63c8b57b9f7cada25ea5cb17 100644 (file)
@@ -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 (file)
index 0000000..e92c902
--- /dev/null
@@ -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;