aboutsummaryrefslogtreecommitdiff
path: root/gcc/ada
diff options
context:
space:
mode:
authorJavier Miranda <miranda@adacore.com>2019-12-26 15:29:24 -0500
committerPierre-Marie de Rodat <derodat@adacore.com>2020-06-02 04:58:22 -0400
commite09092000a8ad3e28639a15ee4bca77e4b1edbdf (patch)
tree1b9b627cc05c09b4f822e39e3b3fa26958d63298 /gcc/ada
parentb60be63da23e0db9435e8620fab9edd531e4ed6b (diff)
downloadgcc-e09092000a8ad3e28639a15ee4bca77e4b1edbdf.zip
gcc-e09092000a8ad3e28639a15ee4bca77e4b1edbdf.tar.gz
gcc-e09092000a8ad3e28639a15ee4bca77e4b1edbdf.tar.bz2
[Ada] Improved support for aspect alignment in CCG
2020-06-02 Javier Miranda <miranda@adacore.com> gcc/ada/ * sem_ch3.adb (Analyze_Object_Declaration): Set attribute Expansion_Delayed on aggregates that initialize an object that has aspect alignment or address clause. Done to allow ther initialization by means of multiple assignments. * exp_ch3.adb (Expand_N_Object_Declaration): Resolve delayed aggregates. This patch complements the patch applied to sem_ch3.adb
Diffstat (limited to 'gcc/ada')
-rw-r--r--gcc/ada/exp_ch3.adb8
-rw-r--r--gcc/ada/sem_ch3.adb6
2 files changed, 11 insertions, 3 deletions
diff --git a/gcc/ada/exp_ch3.adb b/gcc/ada/exp_ch3.adb
index 15d468b..cfc01f5 100644
--- a/gcc/ada/exp_ch3.adb
+++ b/gcc/ada/exp_ch3.adb
@@ -6610,9 +6610,13 @@ package body Exp_Ch3 is
-- An aggregate that must be built in place is not resolved and
-- expanded until the enclosing construct is expanded. This will
-- happen when the aggregate is limited and the declared object
- -- has a following address clause.
+ -- has a following address clause; it happens also when generating
+ -- C code for an aggregate that has an alignment or address clause
+ -- (see Analyze_Object_Declaration).
- if Is_Limited_Type (Typ) and then not Analyzed (Expr) then
+ if (Is_Limited_Type (Typ) or else Modify_Tree_For_C)
+ and then not Analyzed (Expr)
+ then
Resolve (Expr, Typ);
end if;
diff --git a/gcc/ada/sem_ch3.adb b/gcc/ada/sem_ch3.adb
index c57be77..1479e34 100644
--- a/gcc/ada/sem_ch3.adb
+++ b/gcc/ada/sem_ch3.adb
@@ -4318,7 +4318,11 @@ package body Sem_Ch3 is
-- If the aggregate is limited it will be built in place, and its
-- expansion is deferred until the object declaration is expanded.
- if Is_Limited_Type (T) then
+ -- This is also required when generating C code to ensure that an
+ -- object with an alignment or address clause can be initialized
+ -- by means of component by component assignments.
+
+ if Is_Limited_Type (T) or else Modify_Tree_For_C then
Set_Expansion_Delayed (E);
end if;