From: Hristian Kirtchev Date: Thu, 4 Aug 2011 08:28:33 +0000 (+0000) Subject: exp_ch4.adb (Expand_Allocator_Expression): Disable the generation of Set_Finalize_Add... X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=f65df6093be0c1a6a519122683ed0b305850203a;p=gcc.git exp_ch4.adb (Expand_Allocator_Expression): Disable the generation of Set_Finalize_Address_Ptr for CodePeer because... 2011-08-04 Hristian Kirtchev * exp_ch4.adb (Expand_Allocator_Expression): Disable the generation of Set_Finalize_Address_Ptr for CodePeer because Finalize_Address was not built in the first place. (Expand_N_Allocator): Disable the generation of Set_Finalize_Address_Ptr for CodePeer because Finalize_Address was not built to begin with. * exp_ch6.adb (Make_Build_In_Place_Call_In_Allocator): Ditto. From-SVN: r177330 --- diff --git a/gcc/ada/ChangeLog b/gcc/ada/ChangeLog index c4dd6f1dfd4..e922351eaf8 100644 --- a/gcc/ada/ChangeLog +++ b/gcc/ada/ChangeLog @@ -1,3 +1,12 @@ +2011-08-04 Hristian Kirtchev + + * exp_ch4.adb (Expand_Allocator_Expression): Disable the generation of + Set_Finalize_Address_Ptr for CodePeer because Finalize_Address was not + built in the first place. + (Expand_N_Allocator): Disable the generation of Set_Finalize_Address_Ptr + for CodePeer because Finalize_Address was not built to begin with. + * exp_ch6.adb (Make_Build_In_Place_Call_In_Allocator): Ditto. + 2011-08-04 Pascal Obry * adaint.c (__gnat_tmp_name): Use current process id to create temp diff --git a/gcc/ada/exp_ch4.adb b/gcc/ada/exp_ch4.adb index e340fee75a1..7f9fdb23c37 100644 --- a/gcc/ada/exp_ch4.adb +++ b/gcc/ada/exp_ch4.adb @@ -1076,9 +1076,11 @@ package body Exp_Ch4 is -- (Collection, 'Unrestricted_Access) -- Since .NET/JVM compilers do not support address arithmetic, - -- this call is skipped. + -- this call is skipped. The same is done for CodePeer because + -- Finalize_Address is never generated. if VM_Target = No_VM + and then not CodePeer_Mode and then Present (Associated_Collection (PtrT)) then Insert_Action (N, @@ -3847,7 +3849,10 @@ package body Exp_Ch4 is -- Set_Finalize_Address_Ptr -- (Pool, 'Unrestricted_Access) - else + -- Do not generate the above for CodePeer compilations + -- because Finalize_Address is never built. + + elsif not CodePeer_Mode then Insert_Action (N, Make_Set_Finalize_Address_Ptr_Call (Loc => Loc, diff --git a/gcc/ada/exp_ch6.adb b/gcc/ada/exp_ch6.adb index eabd3ef086c..1d9544dd9f3 100644 --- a/gcc/ada/exp_ch6.adb +++ b/gcc/ada/exp_ch6.adb @@ -7187,7 +7187,10 @@ package body Exp_Ch6 is then null; - else + -- Do not generate the call to Make_Set_Finalize_Address_Ptr for + -- CodePeer compilations becase Finalize_Address is never built. + + elsif not CodePeer_Mode then Insert_Action (Allocator, Make_Set_Finalize_Address_Ptr_Call (Loc, Typ => Etype (Function_Id),