aboutsummaryrefslogtreecommitdiff
path: root/gcc/ada
diff options
context:
space:
mode:
authorMarc Poulhiès <poulhies@adacore.com>2023-03-27 16:47:04 +0200
committerMarc Poulhiès <poulhies@adacore.com>2023-05-29 10:23:20 +0200
commit8196b58e0a1a466a41d2fd2f3c6eb3f6ee68685c (patch)
tree1acd91609d94cfa01603511af1979b096c70e753 /gcc/ada
parentf8bf6ae4cf087a9947c431a06f77104fa20ae36f (diff)
downloadgcc-8196b58e0a1a466a41d2fd2f3c6eb3f6ee68685c.zip
gcc-8196b58e0a1a466a41d2fd2f3c6eb3f6ee68685c.tar.gz
gcc-8196b58e0a1a466a41d2fd2f3c6eb3f6ee68685c.tar.bz2
ada: Fix crash on vector initialization
Initializing a vector using Vec : V.Vector := [Some_Type'(Some_Abstract_Type with F => 0)]; may crash the compiler. The expander marks the N_Extension_Aggregate for delayed expansion which never happens and incorrectly ends up in gigi. The delayed expansion is needed for nested aggregates, which the original code is testing for, but container aggregates are handled differently. Such assignments to container aggregates are later transformed into procedure calls to the procedures named in the Aggregate aspect definition, for which the delayed expansion is not required/expected. gcc/ada/ * exp_aggr.adb (Convert_To_Assignments): Do not mark node for delayed expansion if parent type has the Aggregate aspect. * sem_util.adb (Is_Container_Aggregate): Move... * sem_util.ads (Is_Container_Aggregate): ... here and make it public.
Diffstat (limited to 'gcc/ada')
-rw-r--r--gcc/ada/exp_aggr.adb7
-rw-r--r--gcc/ada/sem_util.adb3
-rw-r--r--gcc/ada/sem_util.ads3
3 files changed, 8 insertions, 5 deletions
diff --git a/gcc/ada/exp_aggr.adb b/gcc/ada/exp_aggr.adb
index a6a7d81..75e5e14 100644
--- a/gcc/ada/exp_aggr.adb
+++ b/gcc/ada/exp_aggr.adb
@@ -5000,9 +5000,12 @@ package body Exp_Aggr is
if
-- Internal aggregate (transformed when expanding the parent)
+ -- excluding the Container aggregate as these are transformed to
+ -- procedure call later.
- Parent_Kind in
- N_Aggregate | N_Extension_Aggregate | N_Component_Association
+ (Parent_Kind in
+ N_Component_Association | N_Aggregate | N_Extension_Aggregate
+ and then not Is_Container_Aggregate (Parent_Node))
-- Allocator (see Convert_Aggr_In_Allocator)
diff --git a/gcc/ada/sem_util.adb b/gcc/ada/sem_util.adb
index 64abfb1..a42b2dff 100644
--- a/gcc/ada/sem_util.adb
+++ b/gcc/ada/sem_util.adb
@@ -132,9 +132,6 @@ package body Sem_Util is
-- Determine whether arbitrary entity Id denotes an atomic object as per
-- RM C.6(7).
- function Is_Container_Aggregate (Exp : Node_Id) return Boolean;
- -- Is the given expression a container aggregate?
-
generic
with function Is_Effectively_Volatile_Entity
(Id : Entity_Id) return Boolean;
diff --git a/gcc/ada/sem_util.ads b/gcc/ada/sem_util.ads
index b5bcd26..d1bbc6a 100644
--- a/gcc/ada/sem_util.ads
+++ b/gcc/ada/sem_util.ads
@@ -1475,6 +1475,9 @@ package Sem_Util is
-- Return True if the loop has no side effect and can therefore be
-- marked for removal. Return False if N is not a N_Loop_Statement.
+ function Is_Container_Aggregate (Exp : Node_Id) return Boolean;
+ -- Is the given expression a container aggregate?
+
function Is_Newly_Constructed
(Exp : Node_Id; Context_Requires_NC : Boolean) return Boolean;
-- Indicates whether a given expression is "newly constructed" (RM 4.4).