https://gcc.gnu.org/g:ba0b16a527b6d658dddca2e2609ab6b6c1fe32d4
commit r15-459-gba0b16a527b6d658dddca2e2609ab6b6c1fe32d4 Author: Eric Botcazou <ebotca...@adacore.com> Date: Mon Feb 12 19:25:39 2024 +0100 ada: Follow-up adjustment after fix to Default_Initialize_Object Now that Default_Initialize_Object honors the No_Initialization flag in all cases, objects of an access type declared without initialization expression can no longer be considered as being automatically initialized to null. gcc/ada/ * exp_ch3.adb (Expand_N_Object_Declaration): Examine the Expression field after the call to Default_Initialize_Object in order to set Is_Known_Null, as well as Is_Known_Non_Null, on an access object. Diff: --- gcc/ada/exp_ch3.adb | 16 ++++++++++------ 1 file changed, 10 insertions(+), 6 deletions(-) diff --git a/gcc/ada/exp_ch3.adb b/gcc/ada/exp_ch3.adb index e34cb8fb58f6..9109d5926905 100644 --- a/gcc/ada/exp_ch3.adb +++ b/gcc/ada/exp_ch3.adb @@ -7604,6 +7604,16 @@ package body Exp_Ch3 is if not Special_Ret_Obj then Default_Initialize_Object (Init_After); + + -- Check whether an access object has been initialized above + + if Is_Access_Type (Typ) and then Present (Expression (N)) then + if Known_Non_Null (Expression (N)) then + Set_Is_Known_Non_Null (Def_Id); + elsif Known_Null (Expression (N)) then + Set_Is_Known_Null (Def_Id); + end if; + end if; end if; -- Generate attribute for Persistent_BSS if needed @@ -7625,12 +7635,6 @@ package body Exp_Ch3 is end; end if; - -- If access type, then we know it is null if not initialized - - if Is_Access_Type (Typ) then - Set_Is_Known_Null (Def_Id); - end if; - -- Explicit initialization present else