summaryrefslogtreecommitdiff
path: root/gcc/ada/targparm.adb
diff options
context:
space:
mode:
Diffstat (limited to 'gcc/ada/targparm.adb')
-rw-r--r--gcc/ada/targparm.adb533
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