aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorEric Botcazou <ebotcazou@adacore.com>2023-03-27 00:55:08 +0200
committerMarc Poulhiès <poulhies@adacore.com>2023-05-26 09:29:18 +0200
commit9f6cee820f9c8d263dfcd1772127268508360838 (patch)
treeb902f79dc3e7d9174d53de713afa1ed24de5e6db /gcc
parent6b19eb2490675cacf72b8225d953d73029bc53fb (diff)
downloadgcc-9f6cee820f9c8d263dfcd1772127268508360838.zip
gcc-9f6cee820f9c8d263dfcd1772127268508360838.tar.gz
gcc-9f6cee820f9c8d263dfcd1772127268508360838.tar.bz2
ada: Fix double free on finalization of Vector in array aggregate
The handling of finalization is delicate during the expansion of aggregates since the generated assignments must not cause the finalization of the RHS. That's why the No_Ctrl_Actions flag is set on them and the adjustments are generated manually. This was not done in the case of an array of array with controlled component when its subaggregates are not expanded in place but instead are replaced by temporaries, leading to double free or memory corruption. gcc/ada/ * exp_aggr.adb (Initialize_Array_Component): Remove obsolete code. (Expand_Array_Aggregate): In the case where a temporary is created and the parent is an assignment statement with No_Ctrl_Actions set, set Is_Ignored_Transient on the temporary.
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ada/exp_aggr.adb27
1 files changed, 9 insertions, 18 deletions
diff --git a/gcc/ada/exp_aggr.adb b/gcc/ada/exp_aggr.adb
index 1dcbfad..a6a7d81 100644
--- a/gcc/ada/exp_aggr.adb
+++ b/gcc/ada/exp_aggr.adb
@@ -1422,24 +1422,6 @@ package body Exp_Aggr is
Expression => New_Copy_Tree (Init_Expr));
Set_No_Ctrl_Actions (Init_Stmt);
- -- If this is an aggregate for an array of arrays, each
- -- subaggregate will be expanded as well, and even with
- -- No_Ctrl_Actions the assignments of inner components will
- -- require attachment in their assignments to temporaries. These
- -- temporaries must be finalized for each subaggregate. Generate:
-
- -- begin
- -- Arr_Comp := Init_Expr;
- -- end;
-
- if Finalization_OK and then Is_Array_Type (Comp_Typ) then
- Init_Stmt :=
- Make_Block_Statement (Loc,
- Handled_Statement_Sequence =>
- Make_Handled_Sequence_Of_Statements (Loc,
- Statements => New_List (Init_Stmt)));
- end if;
-
Append_To (Blk_Stmts, Init_Stmt);
-- Adjust the tag due to a possible view conversion. Generate:
@@ -7072,6 +7054,15 @@ package body Exp_Aggr is
and then Parent_Kind = N_Allocator
then
Establish_Transient_Scope (N, Manage_Sec_Stack => False);
+
+ -- If the parent is an assignment for which no controlled actions
+ -- should take place, prevent the temporary from being finalized.
+
+ elsif Parent_Kind = N_Assignment_Statement
+ and then No_Ctrl_Actions (Parent_Node)
+ then
+ Mutate_Ekind (Tmp, E_Variable);
+ Set_Is_Ignored_Transient (Tmp);
end if;
Insert_Action (N, Tmp_Decl);