aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBob Duff <duff@adacore.com>2018-05-23 10:21:53 +0000
committerPierre-Marie de Rodat <pmderodat@gcc.gnu.org>2018-05-23 10:21:53 +0000
commit326776548e5959daf62f8583ee2356f2352452fc (patch)
tree6cc0ad0f60d5fe93ba5f79ae3bd4fc3e32ea5141
parent95872381f0e22ef13e95788e7000ae2623ed03cd (diff)
downloadgcc-326776548e5959daf62f8583ee2356f2352452fc.zip
gcc-326776548e5959daf62f8583ee2356f2352452fc.tar.gz
gcc-326776548e5959daf62f8583ee2356f2352452fc.tar.bz2
[Ada] Build-in-place aggregates and Address clauses
This patch fixes a bug in which if a limited volatile variable with an Address aspect is initialized with a build-in-place aggregate containing build-in-place function calls, the compiler can crash. 2018-05-23 Bob Duff <duff@adacore.com> gcc/ada/ * freeze.adb: (Check_Address_Clause): Deal with build-in-place aggregates in addition to build-in-place calls. gcc/testsuite/ * gnat.dg/addr10.adb: New testcase. From-SVN: r260574
-rw-r--r--gcc/ada/ChangeLog5
-rw-r--r--gcc/ada/freeze.adb13
-rw-r--r--gcc/testsuite/ChangeLog4
-rw-r--r--gcc/testsuite/gnat.dg/addr10.adb24
4 files changed, 39 insertions, 7 deletions
diff --git a/gcc/ada/ChangeLog b/gcc/ada/ChangeLog
index 98720a3..f9ad159 100644
--- a/gcc/ada/ChangeLog
+++ b/gcc/ada/ChangeLog
@@ -1,5 +1,10 @@
2018-05-23 Bob Duff <duff@adacore.com>
+ * freeze.adb: (Check_Address_Clause): Deal with build-in-place
+ aggregates in addition to build-in-place calls.
+
+2018-05-23 Bob Duff <duff@adacore.com>
+
* einfo.ads: Minor reformatting.
* sem_ch3.adb: Likewise.
* sinfo.ads: Likewise.
diff --git a/gcc/ada/freeze.adb b/gcc/ada/freeze.adb
index 66f9dcc..032dcf51 100644
--- a/gcc/ada/freeze.adb
+++ b/gcc/ada/freeze.adb
@@ -710,13 +710,12 @@ package body Freeze is
end;
end if;
- -- Remove side effects from initial expression, except in the case
- -- of a build-in-place call, which has its own later expansion.
+ -- Remove side effects from initial expression, except in the case of
+ -- limited build-in-place calls and aggregates, which have their own
+ -- expansion elsewhere. This exception is necessary to avoid copying
+ -- limited objects.
- if Present (Init)
- and then (Nkind (Init) /= N_Function_Call
- or else not Is_Expanded_Build_In_Place_Call (Init))
- then
+ if Present (Init) and then not Is_Limited_View (Typ) then
-- Capture initialization value at point of declaration, and make
-- explicit assignment legal, because object may be a constant.
@@ -735,7 +734,7 @@ package body Freeze is
Set_No_Initialization (Decl);
- -- If the objet is tagged, check whether the tag must be
+ -- If the object is tagged, check whether the tag must be
-- reassigned explicitly.
Tag_Assign := Make_Tag_Assignment (Decl);
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 5a80e1d..b12fb9e 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,7 @@
+2018-05-23 Bob Duff <duff@adacore.com>
+
+ * gnat.dg/addr10.adb: New testcase.
+
2018-05-23 Richard Biener <rguenther@suse.de>
PR middle-end/85874
diff --git a/gcc/testsuite/gnat.dg/addr10.adb b/gcc/testsuite/gnat.dg/addr10.adb
new file mode 100644
index 0000000..16efa28
--- /dev/null
+++ b/gcc/testsuite/gnat.dg/addr10.adb
@@ -0,0 +1,24 @@
+-- { dg-do compile }
+
+with System;
+
+procedure Addr10 is
+ type Limited_Type is limited record
+ Element : Integer;
+ end record;
+
+ function Initial_State return Limited_Type is ((Element => 0));
+
+ type Double_Limited_Type is
+ record
+ A : Limited_Type;
+ end record;
+
+ Double_Limited : Double_Limited_Type :=
+ (A => Initial_State)
+ with
+ Volatile,
+ Address => System'To_Address (16#1234_5678#);
+begin
+ null;
+end Addr10;