diff options
Diffstat (limited to 'gcc/ada/targparm.adb')
-rw-r--r-- | gcc/ada/targparm.adb | 533 |
1 files changed, 416 insertions, 117 deletions
diff --git a/gcc/ada/targparm.adb b/gcc/ada/targparm.adb index 2621dbf2045..6e911fba3cb 100644 --- a/gcc/ada/targparm.adb +++ b/gcc/ada/targparm.adb @@ -6,7 +6,7 @@ -- -- -- B o d y -- -- -- --- Copyright (C) 1999-2001 Free Software Foundation, Inc. -- +-- Copyright (C) 1999-2003 Free Software Foundation, Inc. -- -- -- -- GNAT is free software; you can redistribute it and/or modify it under -- -- terms of the GNU General Public License as published by the Free Soft- -- @@ -24,95 +24,175 @@ -- -- ------------------------------------------------------------------------------ -with Namet; use Namet; -with Output; use Output; -with Sinput; use Sinput; -with Sinput.L; use Sinput.L; -with Types; use Types; +with Csets; use Csets; +with Namet; use Namet; +with Opt; use Opt; +with Osint; use Osint; +with Output; use Output; package body Targparm is + use ASCII; + + Parameters_Obtained : Boolean := False; + -- Set True after first call to Get_Target_Parameters. Used to avoid + -- reading system.ads more than once, since it cannot change. + + -- The following array defines a tag name for each entry type Targparm_Tags is - (AAM, -- AAMP; - BDC, -- Backend_Divide_Checks; - BOC, -- Backend_Overflow_Checks; - CLA, -- Command_Line_Args; - DEN, -- Denorm; - DSP, -- Functions_Return_By_DSP; - FEL, -- Frontend_Layout; + (AAM, -- AAMP + BDC, -- Backend_Divide_Checks + BOC, -- Backend_Overflow_Checks + CLA, -- Command_Line_Args + CRT, -- Configurable_Run_Time + D32, -- Duration_32_Bits + DEN, -- Denorm + DSP, -- Functions_Return_By_DSP + EXS, -- Exit_Status_Supported + FEL, -- Frontend_Layout FFO, -- Fractional_Fixed_Ops - HIM, -- High_Integrity_Mode; - LSI, -- Long_Shifts_Inlined; - MOV, -- Machine_Overflows; - MRN, -- Machine_Rounds; - SCD, -- Stack_Check_Default; - SCP, -- Stack_Check_Probes; - SNZ, -- Signed_Zeros; - UAM, -- Use_Ada_Main_Program_Name; - VMS, -- OpenVMS; - ZCD, -- ZCX_By_Default; - ZCG, -- GCC_ZCX_Support; - ZCF); -- Front_End_ZCX_Support; + MOV, -- Machine_Overflows + MRN, -- Machine_Rounds + S64, -- Support_64_Bit_Divides + SAG, -- Support_Aggregates + SCA, -- Support_Composite_Assign + SCC, -- Support_Composite_Compare + SCD, -- Stack_Check_Default + SCP, -- Stack_Check_Probes + SLS, -- Support_Long_Shifts + SNZ, -- Signed_Zeros + SSL, -- Suppress_Standard_Library + UAM, -- Use_Ada_Main_Program_Name + VMS, -- OpenVMS + ZCD, -- ZCX_By_Default + ZCG, -- GCC_ZCX_Support + ZCF, -- Front_End_ZCX_Support + + -- The following entries are obsolete and can eventually be removed + + HIM, -- High_Integrity_Mode + LSI); -- Long_Shifts_Inlined + + subtype Targparm_Tags_OK is Targparm_Tags range AAM .. ZCF; + -- Range excluding obsolete entries Targparm_Flags : array (Targparm_Tags) of Boolean := (others => False); -- Flag is set True if corresponding parameter is scanned + -- The following list of string constants gives the parameter names + AAM_Str : aliased constant Source_Buffer := "AAMP"; BDC_Str : aliased constant Source_Buffer := "Backend_Divide_Checks"; BOC_Str : aliased constant Source_Buffer := "Backend_Overflow_Checks"; CLA_Str : aliased constant Source_Buffer := "Command_Line_Args"; + CRT_Str : aliased constant Source_Buffer := "Configurable_Run_Time"; + D32_Str : aliased constant Source_Buffer := "Duration_32_Bits"; DEN_Str : aliased constant Source_Buffer := "Denorm"; DSP_Str : aliased constant Source_Buffer := "Functions_Return_By_DSP"; + EXS_Str : aliased constant Source_Buffer := "Exit_Status_Supported"; FEL_Str : aliased constant Source_Buffer := "Frontend_Layout"; FFO_Str : aliased constant Source_Buffer := "Fractional_Fixed_Ops"; - HIM_Str : aliased constant Source_Buffer := "High_Integrity_Mode"; - LSI_Str : aliased constant Source_Buffer := "Long_Shifts_Inlined"; MOV_Str : aliased constant Source_Buffer := "Machine_Overflows"; MRN_Str : aliased constant Source_Buffer := "Machine_Rounds"; + S64_Str : aliased constant Source_Buffer := "Support_64_Bit_Divides"; + SAG_Str : aliased constant Source_Buffer := "Support_Aggregates"; + SCA_Str : aliased constant Source_Buffer := "Support_Composite_Assign"; + SCC_Str : aliased constant Source_Buffer := "Support_Composite_Compare"; SCD_Str : aliased constant Source_Buffer := "Stack_Check_Default"; SCP_Str : aliased constant Source_Buffer := "Stack_Check_Probes"; + SLS_Str : aliased constant Source_Buffer := "Support_Long_Shifts"; SNZ_Str : aliased constant Source_Buffer := "Signed_Zeros"; + SSL_Str : aliased constant Source_Buffer := "Suppress_Standard_Library"; UAM_Str : aliased constant Source_Buffer := "Use_Ada_Main_Program_Name"; VMS_Str : aliased constant Source_Buffer := "OpenVMS"; ZCD_Str : aliased constant Source_Buffer := "ZCX_By_Default"; ZCG_Str : aliased constant Source_Buffer := "GCC_ZCX_Support"; ZCF_Str : aliased constant Source_Buffer := "Front_End_ZCX_Support"; + -- Obsolete entries + + HIM_Str : aliased constant Source_Buffer := "High_Integrity_Mode"; + LSI_Str : aliased constant Source_Buffer := "Long_Shifts_Inlined"; + + -- The following defines a set of pointers to the above strings, + -- indexed by the tag values. + type Buffer_Ptr is access constant Source_Buffer; - Targparm_Str : array (Targparm_Tags) of Buffer_Ptr := + Targparm_Str : constant array (Targparm_Tags) of Buffer_Ptr := (AAM_Str'Access, BDC_Str'Access, BOC_Str'Access, CLA_Str'Access, + CRT_Str'Access, + D32_Str'Access, DEN_Str'Access, DSP_Str'Access, + EXS_Str'Access, FEL_Str'Access, FFO_Str'Access, - HIM_Str'Access, - LSI_Str'Access, MOV_Str'Access, MRN_Str'Access, + S64_Str'Access, + SAG_Str'Access, + SCA_Str'Access, + SCC_Str'Access, SCD_Str'Access, SCP_Str'Access, + SLS_Str'Access, SNZ_Str'Access, + SSL_Str'Access, UAM_Str'Access, VMS_Str'Access, ZCD_Str'Access, ZCG_Str'Access, - ZCF_Str'Access); + ZCF_Str'Access, + + -- Obsolete entries + + HIM_Str'Access, + LSI_Str'Access); --------------------------- -- Get_Target_Parameters -- --------------------------- + -- Version which reads in system.ads + procedure Get_Target_Parameters is - use ASCII; + Text : Source_Buffer_Ptr; + Hi : Source_Ptr; + + begin + if Parameters_Obtained then + return; + end if; - S : Source_File_Index; - N : Name_Id; - T : Source_Buffer_Ptr; + Name_Buffer (1 .. 10) := "system.ads"; + Name_Len := 10; + + Read_Source_File (Name_Find, Lo => 0, Hi => Hi, Src => Text); + + if Text = null then + Write_Line ("fatal error, run-time library not installed correctly"); + Write_Line ("cannot locate file system.ads"); + raise Unrecoverable_Error; + end if; + + Targparm.Get_Target_Parameters + (System_Text => Text, + Source_First => 0, + Source_Last => Hi); + end Get_Target_Parameters; + + -- Version where caller supplies system.ads text + + procedure Get_Target_Parameters + (System_Text : Source_Buffer_Ptr; + Source_First : Source_Ptr; + Source_Last : Source_Ptr) + is P : Source_Ptr; - Z : Source_Ptr; + V : Uint; Fatal : Boolean := False; -- Set True if a fatal error is detected @@ -121,113 +201,332 @@ package body Targparm is -- Records boolean from system line begin - Name_Buffer (1 .. 10) := "system.ads"; - Name_Len := 10; - N := Name_Find; - S := Load_Source_File (N); + if Parameters_Obtained then + return; + else + Parameters_Obtained := True; + end if; - if S = No_Source_File then - Write_Line ("fatal error, run-time library not installed correctly"); - Write_Str ("cannot locate file "); - Write_Line (Name_Buffer (1 .. Name_Len)); - raise Unrecoverable_Error; + P := Source_First; + Line_Loop : while System_Text (P .. P + 10) /= "end System;" loop - -- This must always be the first source file read, and we have defined - -- a constant Types.System_Source_File_Index as 1 to reflect this. + -- Skip comments quickly - else - pragma Assert (S = System_Source_File_Index); - null; - end if; + if System_Text (P) = '-' then + goto Line_Loop_Continue; + + -- Test for pragma Restrictions + + elsif System_Text (P .. P + 20) = "pragma Restrictions (" then + P := P + 21; + + Rloop : for K in Partition_Restrictions loop + declare + Rname : constant String := Restriction_Id'Image (K); + + begin + for J in Rname'Range loop + if Fold_Upper (System_Text (P + Source_Ptr (J - 1))) + /= Rname (J) + then + goto Rloop_Continue; + end if; + end loop; + + if System_Text (P + Rname'Length) = ')' then + Restrictions_On_Target (K) := True; + goto Line_Loop_Continue; + end if; + end; + + <<Rloop_Continue>> + null; + end loop Rloop; + + Ploop : for K in Restriction_Parameter_Id loop + declare + Rname : constant String := + Restriction_Parameter_Id'Image (K); + + begin + for J in Rname'Range loop + if Fold_Upper (System_Text (P + Source_Ptr (J - 1))) + /= Rname (J) + then + goto Ploop_Continue; + end if; + end loop; + + if System_Text (P + Rname'Length .. P + Rname'Length + 3) = + " => " + then + P := P + Rname'Length + 4; + V := Uint_0; + + loop + if System_Text (P) in '0' .. '9' then + V := 10 * V + Character'Pos (System_Text (P)) - 48; + elsif System_Text (P) = '_' then + null; + elsif System_Text (P) = ')' then + Restriction_Parameters_On_Target (K) := V; + goto Line_Loop_Continue; + else + goto Ploop_Continue; + end if; + + P := P + 1; + end loop; + end if; + end; + + <<Ploop_Continue>> + null; + end loop Ploop; + + Set_Standard_Error; + Write_Line + ("fatal error: system.ads is incorrectly formatted"); + Write_Str ("unrecognized restrictions pragma: "); + + while System_Text (P) /= ')' + and then + System_Text (P) /= ASCII.LF + loop + Write_Char (System_Text (P)); + P := P + 1; + end loop; + + Write_Eol; + Fatal := True; + Set_Standard_Output; + + -- Discard_Names + + elsif System_Text (P .. P + 20) = "pragma Discard_Names;" then + P := P + 21; + Opt.Global_Discard_Names := True; + goto Line_Loop_Continue; + + -- Locking Policy + + elsif System_Text (P .. P + 22) = "pragma Locking_Policy (" then + P := P + 23; + Opt.Locking_Policy := System_Text (P); + Opt.Locking_Policy_Sloc := System_Location; + goto Line_Loop_Continue; + + -- Normalize_Scalars + + elsif System_Text (P .. P + 24) = "pragma Normalize_Scalars;" then + P := P + 25; + Opt.Normalize_Scalars := True; + Opt.Init_Or_Norm_Scalars := True; + goto Line_Loop_Continue; - P := Source_First (S); - Z := Source_Last (S); - T := Source_Text (S); + -- Polling (On) - while T (P .. P + 10) /= "end System;" loop + elsif System_Text (P .. P + 19) = "pragma Polling (On);" then + P := P + 20; + Opt.Polling_Required := True; + goto Line_Loop_Continue; - for K in Targparm_Tags loop - if T (P + 3 .. P + 2 + Targparm_Str (K)'Length) = - Targparm_Str (K).all + -- Ignore pragma Pure (System) + + elsif System_Text (P .. P + 20) = "pragma Pure (System);" then + P := P + 21; + goto Line_Loop_Continue; + + -- Queuing Policy + + elsif System_Text (P .. P + 22) = "pragma Queuing_Policy (" then + P := P + 23; + Opt.Queuing_Policy := System_Text (P); + Opt.Queuing_Policy_Sloc := System_Location; + goto Line_Loop_Continue; + + -- Suppress_Exception_Locations + + elsif System_Text (P .. P + 34) = + "pragma Suppress_Exception_Locations;" + then + P := P + 35; + Opt.Exception_Locations_Suppressed := True; + goto Line_Loop_Continue; + + -- Task_Dispatching Policy + + elsif System_Text (P .. P + 31) = + "pragma Task_Dispatching_Policy (" + then + P := P + 32; + Opt.Task_Dispatching_Policy := System_Text (P); + Opt.Task_Dispatching_Policy_Sloc := System_Location; + goto Line_Loop_Continue; + + -- No other pragmas are permitted + + elsif System_Text (P .. P + 6) = "pragma " then + Set_Standard_Error; + Write_Line ("unrecognized line in system.ads: "); + + while System_Text (P) /= ')' + and then System_Text (P) /= ASCII.LF + loop + Write_Char (System_Text (P)); + P := P + 1; + end loop; + + Write_Eol; + Set_Standard_Output; + Fatal := True; + + -- See if we have a Run_Time_Name + + elsif System_Text (P .. P + 38) = + " Run_Time_Name : constant String := """ + then + P := P + 39; + + Name_Len := 0; + while System_Text (P) in 'A' .. 'Z' + or else + System_Text (P) in 'a' .. 'z' + or else + System_Text (P) in '0' .. '9' + or else + System_Text (P) = ' ' + or else + System_Text (P) = '_' + loop + Add_Char_To_Name_Buffer (System_Text (P)); + P := P + 1; + end loop; + + if System_Text (P) /= '"' + or else System_Text (P + 1) /= ';' + or else (System_Text (P + 2) /= ASCII.LF + and then + System_Text (P + 2) /= ASCII.CR) then - P := P + 3 + Targparm_Str (K)'Length; + Set_Standard_Error; + Write_Line + ("incorrectly formatted Run_Time_Name in system.ads"); + Set_Standard_Output; + Fatal := True; + + else + Run_Time_Name_On_Target := Name_Enter; + end if; + + goto Line_Loop_Continue; + + -- Next See if we have a configuration parameter + + else + Config_Param_Loop : for K in Targparm_Tags loop + if System_Text (P + 3 .. P + 2 + Targparm_Str (K)'Length) = + Targparm_Str (K).all + then + P := P + 3 + Targparm_Str (K)'Length; + - if Targparm_Flags (K) then - Set_Standard_Error; - Write_Line - ("fatal error: system.ads is incorrectly formatted"); - Write_Str ("duplicate line for parameter: "); + if Targparm_Flags (K) then + Set_Standard_Error; + Write_Line + ("fatal error: system.ads is incorrectly formatted"); + Write_Str ("duplicate line for parameter: "); - for J in Targparm_Str (K)'Range loop - Write_Char (Targparm_Str (K).all (J)); + for J in Targparm_Str (K)'Range loop + Write_Char (Targparm_Str (K).all (J)); + end loop; + + Write_Eol; + Set_Standard_Output; + Fatal := True; + + else + Targparm_Flags (K) := True; + end if; + + while System_Text (P) /= ':' + or else System_Text (P + 1) /= '=' + loop + P := P + 1; end loop; - Write_Eol; - Set_Standard_Output; - Fatal := True; + P := P + 2; - else - Targparm_Flags (K) := True; + while System_Text (P) = ' ' loop + P := P + 1; + end loop; + + Result := (System_Text (P) = 'T'); + + case K is + when AAM => AAMP_On_Target := Result; + when BDC => Backend_Divide_Checks_On_Target := Result; + when BOC => Backend_Overflow_Checks_On_Target := Result; + when CLA => Command_Line_Args_On_Target := Result; + when CRT => Configurable_Run_Time_On_Target := Result; + when D32 => Duration_32_Bits_On_Target := Result; + when DEN => Denorm_On_Target := Result; + when DSP => Functions_Return_By_DSP_On_Target := Result; + when EXS => Exit_Status_Supported_On_Target := Result; + when FEL => Frontend_Layout_On_Target := Result; + when FFO => Fractional_Fixed_Ops_On_Target := Result; + when MOV => Machine_Overflows_On_Target := Result; + when MRN => Machine_Rounds_On_Target := Result; + when S64 => Support_64_Bit_Divides_On_Target := Result; + when SAG => Support_Aggregates_On_Target := Result; + when SCA => Support_Composite_Assign_On_Target := Result; + when SCC => Support_Composite_Compare_On_Target := Result; + when SCD => Stack_Check_Default_On_Target := Result; + when SCP => Stack_Check_Probes_On_Target := Result; + when SLS => Support_Long_Shifts_On_Target := Result; + when SSL => Suppress_Standard_Library_On_Target := Result; + when SNZ => Signed_Zeros_On_Target := Result; + when UAM => Use_Ada_Main_Program_Name_On_Target := Result; + when VMS => OpenVMS_On_Target := Result; + when ZCD => ZCX_By_Default_On_Target := Result; + when ZCG => GCC_ZCX_Support_On_Target := Result; + when ZCF => Front_End_ZCX_Support_On_Target := Result; + + -- Obsolete entries + + when HIM => null; + when LSI => null; + + goto Line_Loop_Continue; + end case; end if; + end loop Config_Param_Loop; + end if; - while T (P) /= ':' or else T (P + 1) /= '=' loop - P := P + 1; - end loop; - - P := P + 2; - - while T (P) = ' ' loop - P := P + 1; - end loop; - - Result := (T (P) = 'T'); - - case K is - when AAM => AAMP_On_Target := Result; - when BDC => Backend_Divide_Checks_On_Target := Result; - when BOC => Backend_Overflow_Checks_On_Target := Result; - when CLA => Command_Line_Args_On_Target := Result; - when DEN => Denorm_On_Target := Result; - when DSP => Functions_Return_By_DSP_On_Target := Result; - when FEL => Frontend_Layout_On_Target := Result; - when FFO => Fractional_Fixed_Ops_On_Target := Result; - when HIM => High_Integrity_Mode_On_Target := Result; - when LSI => Long_Shifts_Inlined_On_Target := Result; - when MOV => Machine_Overflows_On_Target := Result; - when MRN => Machine_Rounds_On_Target := Result; - when SCD => Stack_Check_Default_On_Target := Result; - when SCP => Stack_Check_Probes_On_Target := Result; - when SNZ => Signed_Zeros_On_Target := Result; - when UAM => Use_Ada_Main_Program_Name_On_Target := Result; - when VMS => OpenVMS_On_Target := Result; - when ZCD => ZCX_By_Default_On_Target := Result; - when ZCG => GCC_ZCX_Support_On_Target := Result; - when ZCF => Front_End_ZCX_Support_On_Target := Result; - end case; - - exit; - end if; - end loop; + -- Here after processing one line of System spec + + <<Line_Loop_Continue>> - while T (P) /= CR and then T (P) /= LF loop + while System_Text (P) /= CR and then System_Text (P) /= LF loop P := P + 1; - exit when P >= Z; + exit when P >= Source_Last; end loop; - while T (P) = CR or else T (P) = LF loop + while System_Text (P) = CR or else System_Text (P) = LF loop P := P + 1; - exit when P >= Z; + exit when P >= Source_Last; end loop; - if P >= Z then + if P >= Source_Last then Set_Standard_Error; Write_Line ("fatal error, system.ads not formatted correctly"); Set_Standard_Output; - raise Unrecoverable_Error; end if; - end loop; + end loop Line_Loop; + + -- Check no missing target parameter settings - for K in Targparm_Tags loop + for K in Targparm_Tags_OK loop if not Targparm_Flags (K) then Set_Standard_Error; Write_Line |