summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--gcc/ada/debug.adb20
-rw-r--r--gcc/ada/switch-b.adb185
-rw-r--r--gcc/ada/switch-m.adb29
-rw-r--r--gcc/ada/switch.adb6
-rw-r--r--gcc/ada/switch.ads1
5 files changed, 152 insertions, 89 deletions
diff --git a/gcc/ada/debug.adb b/gcc/ada/debug.adb
index 96e9ca74e7b..8fe80da32cb 100644
--- a/gcc/ada/debug.adb
+++ b/gcc/ada/debug.adb
@@ -159,16 +159,6 @@ package body Debug is
-- dy
-- dz
- -- d1
- -- d2
- -- d3
- -- d4
- -- d5
- -- d6
- -- d7
- -- d8
- -- d9
-
-- Debug flags used in package Make and its clients (e.g. GNATMAKE)
-- da
@@ -198,16 +188,6 @@ package body Debug is
-- dy
-- dz
- -- d1
- -- d2
- -- d3
- -- d4
- -- d5
- -- d6
- -- d7
- -- d8
- -- d9
-
--------------------------------------------
-- Documentation for Compiler Debug Flags --
--------------------------------------------
diff --git a/gcc/ada/switch-b.adb b/gcc/ada/switch-b.adb
index 43be4d0b337..ee8ac6a2512 100644
--- a/gcc/ada/switch-b.adb
+++ b/gcc/ada/switch-b.adb
@@ -41,11 +41,60 @@ package body Switch.B is
Ptr : Integer := Switch_Chars'First;
C : Character := ' ';
+ function Get_Stack_Size (S : Character) return Int;
+ -- Used for -d and -D to scan stack size including handling k/m.
+ -- S is set to 'd' or 'D' to indicate the switch being scanned.
+
+ --------------------
+ -- Get_Stack_Size --
+ --------------------
+
+ function Get_Stack_Size (S : Character) return Int is
+ Result : Int;
+
+ begin
+ Scan_Pos (Switch_Chars, Max, Ptr, Result, S);
+
+ -- In the following code, we enable overflow checking since the
+ -- multiplication by K or M may cause overflow, which is an error.
+
+ declare
+ pragma Unsuppress (Overflow_Check);
+
+ begin
+ -- Check for additional character 'k' (for kilobytes) or 'm'
+ -- (for Megabytes), but only if we have not reached the end
+ -- of the switch string. Note that if this appears before the
+ -- end of the string we will get an error when we test to make
+ -- sure that the string is exhausted (at the end of the case).
+
+ if Ptr <= Max then
+ if Switch_Chars (Ptr) = 'k' then
+ Result := Result * 1024;
+ Ptr := Ptr + 1;
+
+ elsif Switch_Chars (Ptr) = 'm' then
+ Result := Result * (1024 * 1024);
+ Ptr := Ptr + 1;
+ end if;
+ end if;
+
+ exception
+ when Constraint_Error =>
+ Osint.Fail
+ ("numeric value out of range for switch: ", (1 => S));
+ end;
+
+ return Result;
+ end Get_Stack_Size;
+
+ -- Start of processing for Scan_Binder_Switches
+
begin
-- Skip past the initial character (must be the switch character)
if Ptr = Max then
- Bad_Switch (C);
+ Bad_Switch (Switch_Chars);
else
Ptr := Ptr + 1;
end if;
@@ -62,7 +111,7 @@ package body Switch.B is
-- Loop to scan through switches given in switch string
- while Ptr <= Max loop
+ Check_Switch : begin
C := Switch_Chars (Ptr);
case C is
@@ -103,37 +152,55 @@ package body Switch.B is
when 'd' =>
- -- Note: for the debug switch, the remaining characters in this
- -- switch field must all be debug flags, since all valid switch
- -- characters are also valid debug characters. This switch is not
- -- documented on purpose because it is only used by the
- -- implementors.
+ if Ptr = Max then
+ Bad_Switch (Switch_Chars);
+ end if;
- -- Loop to scan out debug flags
+ Ptr := Ptr + 1;
+ C := Switch_Chars (Ptr);
- while Ptr < Max loop
- Ptr := Ptr + 1;
- C := Switch_Chars (Ptr);
- exit when C = ASCII.NUL or else C = '/' or else C = '-';
+ -- Case where character after -d is a digit (default stack size)
- if C in '1' .. '9' or else
- C in 'a' .. 'z' or else
- C in 'A' .. 'Z'
- then
- Set_Debug_Flag (C);
- else
- Bad_Switch (C);
- end if;
- end loop;
+ if C in '0' .. '9' then
+
+ -- In this case, we process the default primary stack size
+
+ Default_Stack_Size := Get_Stack_Size ('d');
+
+ -- Case where character after -d is not digit (debug flags)
+
+ else
+ -- Note: for the debug switch, the remaining characters in this
+ -- switch field must all be debug flags, since all valid switch
+ -- characters are also valid debug characters. This switch is
+ -- not documented on purpose because it is only used by the
+ -- implementors.
+
+ -- Loop to scan out debug flags
+
+ loop
+ C := Switch_Chars (Ptr);
- return;
+ if C in 'a' .. 'z' or else C in 'A' .. 'Z' then
+ Set_Debug_Flag (C);
+ else
+ Bad_Switch (Switch_Chars);
+ end if;
+
+ Ptr := Ptr + 1;
+ exit when Ptr > Max;
+ end loop;
+ end if;
-- Processing for D switch
when 'D' =>
+ if Ptr = Max then
+ Bad_Switch (Switch_Chars);
+ end if;
+
Ptr := Ptr + 1;
- Scan_Pos
- (Switch_Chars, Max, Ptr, Default_Sec_Stack_Size, C);
+ Default_Sec_Stack_Size := Get_Stack_Size ('D');
-- Processing for e switch
@@ -182,7 +249,7 @@ package body Switch.B is
when 'i' =>
if Ptr = Max then
- Bad_Switch (C);
+ Bad_Switch (Switch_Chars);
end if;
Ptr := Ptr + 1;
@@ -198,7 +265,7 @@ package body Switch.B is
Identifier_Character_Set := C;
Ptr := Ptr + 1;
else
- Bad_Switch (C);
+ Bad_Switch (Switch_Chars);
end if;
-- Processing for K switch
@@ -216,6 +283,10 @@ package body Switch.B is
-- Processing for m switch
when 'm' =>
+ if Ptr = Max then
+ Bad_Switch (Switch_Chars);
+ end if;
+
Ptr := Ptr + 1;
Scan_Pos (Switch_Chars, Max, Ptr, Maximum_Errors, C);
@@ -281,6 +352,10 @@ package body Switch.B is
-- Processing for T switch
when 'T' =>
+ if Ptr = Max then
+ Bad_Switch (Switch_Chars);
+ end if;
+
Ptr := Ptr + 1;
Time_Slice_Set := True;
Scan_Nat (Switch_Chars, Max, Ptr, Time_Slice_Value, C);
@@ -289,6 +364,10 @@ package body Switch.B is
-- Processing for u switch
when 'u' =>
+ if Ptr = Max then
+ Bad_Switch (Switch_Chars);
+ end if;
+
Ptr := Ptr + 1;
Dynamic_Stack_Measurement := True;
Scan_Nat
@@ -307,6 +386,9 @@ package body Switch.B is
-- Processing for w switch
when 'w' =>
+ if Ptr = Max then
+ Bad_Switch (Switch_Chars);
+ end if;
-- For the binder we only allow suppress/error cases
@@ -321,7 +403,7 @@ package body Switch.B is
Warning_Mode := Suppress;
when others =>
- Bad_Switch (C);
+ Bad_Switch (Switch_Chars);
end case;
Ptr := Ptr + 1;
@@ -329,6 +411,10 @@ package body Switch.B is
-- Processing for W switch
when 'W' =>
+ if Ptr = Max then
+ Bad_Switch (Switch_Chars);
+ end if;
+
Ptr := Ptr + 1;
for J in WC_Encoding_Method loop
@@ -337,7 +423,7 @@ package body Switch.B is
exit;
elsif J = WC_Encoding_Method'Last then
- Bad_Switch (C);
+ Bad_Switch (Switch_Chars);
end if;
end loop;
@@ -357,6 +443,10 @@ package body Switch.B is
-- Processing for X switch
when 'X' =>
+ if Ptr = Max then
+ Bad_Switch (Switch_Chars);
+ end if;
+
Ptr := Ptr + 1;
Scan_Pos (Switch_Chars, Max, Ptr, Default_Exit_Status, C);
@@ -366,29 +456,21 @@ package body Switch.B is
Ptr := Ptr + 1;
No_Main_Subprogram := True;
- -- Ignore extra switch character
-
- when '/' =>
- Ptr := Ptr + 1;
-
- -- Ignore '-' extra switch caracter, only if it isn't followed by
- -- 'RTS'. If it is, then we must process the 'RTS' switch
+ -- Processing for --RTS
when '-' =>
- if Ptr + 3 <= Max and then
+ if Ptr + 4 <= Max and then
Switch_Chars (Ptr + 1 .. Ptr + 3) = "RTS"
then
- Ptr := Ptr + 1;
+ Ptr := Ptr + 4;
- if Switch_Chars (Ptr + 3) /= '=' or else
- (Switch_Chars (Ptr + 3) = '='
- and then Ptr + 4 > Max)
- then
+ if Switch_Chars (Ptr) /= '=' or else Ptr = Max then
Osint.Fail ("missing path for --RTS");
- else
+ else
-- valid --RTS switch
+
Opt.No_Stdinc := True;
Opt.RTS_Switch := True;
@@ -396,12 +478,12 @@ package body Switch.B is
Src_Path_Name : constant String_Ptr :=
Get_RTS_Search_Dir
(Switch_Chars
- (Ptr + 4 .. Switch_Chars'Last),
+ (Ptr + 1 .. Switch_Chars'Last),
Include);
Lib_Path_Name : constant String_Ptr :=
Get_RTS_Search_Dir
(Switch_Chars
- (Ptr + 4 .. Switch_Chars'Last),
+ (Ptr + 1 .. Switch_Chars'Last),
Objects);
begin
@@ -415,10 +497,7 @@ package body Switch.B is
RTS_Src_Path_Name := Src_Path_Name;
RTS_Lib_Path_Name := Lib_Path_Name;
- -- We can exit as there cannot be another switch
- -- after --RTS
-
- exit;
+ Ptr := Max + 1;
elsif Src_Path_Name = null
and then Lib_Path_Name = null
@@ -436,15 +515,19 @@ package body Switch.B is
end if;
else
- Ptr := Ptr + 1;
+ Bad_Switch (Switch_Chars);
end if;
-- Anything else is an error (illegal switch character)
when others =>
- Bad_Switch (C);
+ Bad_Switch (Switch_Chars);
end case;
- end loop;
+
+ if Ptr <= Max then
+ Bad_Switch (Switch_Chars);
+ end if;
+ end Check_Switch;
end Scan_Binder_Switches;
end Switch.B;
diff --git a/gcc/ada/switch-m.adb b/gcc/ada/switch-m.adb
index bad932a01a6..b193a112fa8 100644
--- a/gcc/ada/switch-m.adb
+++ b/gcc/ada/switch-m.adb
@@ -491,7 +491,7 @@ package body Switch.M is
-- Skip past the initial character (must be the switch character)
if Ptr = Max then
- Bad_Switch (C);
+ Bad_Switch (Switch_Chars);
else
Ptr := Ptr + 1;
@@ -573,15 +573,11 @@ package body Switch.M is
while Ptr < Max loop
Ptr := Ptr + 1;
C := Switch_Chars (Ptr);
- exit when C = ASCII.NUL or else C = '/' or else C = '-';
- if C in '1' .. '9' or else
- C in 'a' .. 'z' or else
- C in 'A' .. 'Z'
- then
+ if C in 'a' .. 'z' or else C in 'A' .. 'Z' then
Set_Debug_Flag (C);
else
- Bad_Switch (C);
+ Bad_Switch (Switch_Chars);
end if;
end loop;
@@ -593,7 +589,7 @@ package body Switch.M is
Ptr := Ptr + 1;
if Ptr > Max then
- Bad_Switch (C);
+ Bad_Switch (Switch_Chars);
end if;
case Switch_Chars (Ptr) is
@@ -611,7 +607,7 @@ package body Switch.M is
Follow_Links := True;
when others =>
- Bad_Switch (C);
+ Bad_Switch (Switch_Chars);
end case;
-- Processing for f switch
@@ -641,6 +637,10 @@ package body Switch.M is
-- Processing for j switch
when 'j' =>
+ if Ptr = Max then
+ Bad_Switch (Switch_Chars);
+ end if;
+
Ptr := Ptr + 1;
declare
@@ -721,7 +721,7 @@ package body Switch.M is
Verbosity_Level := Opt.High;
when others =>
- Osint.Fail ("invalid switch: ", Switch_Chars);
+ Bad_Switch (Switch_Chars);
end case;
Ptr := Ptr + 1;
@@ -739,20 +739,15 @@ package body Switch.M is
Ptr := Ptr + 1;
No_Main_Subprogram := True;
- -- Ignore extra switch character
-
- when '/' | '-' =>
- Ptr := Ptr + 1;
-
-- Anything else is an error (illegal switch character)
when others =>
- Bad_Switch (C);
+ Bad_Switch (Switch_Chars);
end case;
if Ptr <= Max then
- Osint.Fail ("invalid switch: ", Switch_Chars);
+ Bad_Switch (Switch_Chars);
end if;
end Check_Switch;
diff --git a/gcc/ada/switch.adb b/gcc/ada/switch.adb
index 048678bd19f..7692f589f98 100644
--- a/gcc/ada/switch.adb
+++ b/gcc/ada/switch.adb
@@ -37,6 +37,11 @@ package body Switch is
Osint.Fail ("invalid switch: ", (1 => Switch));
end Bad_Switch;
+ procedure Bad_Switch (Switch : String) is
+ begin
+ Osint.Fail ("invalid switch: ", Switch);
+ end Bad_Switch;
+
-------------------------
-- Is_Front_End_Switch --
-------------------------
@@ -63,7 +68,6 @@ package body Switch is
and then Switch_Chars (Switch_Chars'First) = '-';
end Is_Switch;
- ------------------------
--------------
-- Scan_Nat --
--------------
diff --git a/gcc/ada/switch.ads b/gcc/ada/switch.ads
index 15c273f829c..dce2f12d8f8 100644
--- a/gcc/ada/switch.ads
+++ b/gcc/ada/switch.ads
@@ -86,6 +86,7 @@ private
-- digit of the integer value.
procedure Bad_Switch (Switch : Character);
+ procedure Bad_Switch (Switch : String);
-- Fail with an appropriate message when a switch is not recognized
end Switch;