FSF GCC merge 02/23/03
[official-gcc.git] / gcc / ada / 5vsystem.ads
blob6c62a0756895b7b65452f235270003552bb29323
1 ------------------------------------------------------------------------------
2 -- --
3 -- GNAT RUN-TIME COMPONENTS --
4 -- --
5 -- S Y S T E M --
6 -- --
7 -- S p e c --
8 -- (OpenVMS DEC Threads Version) --
9 -- --
10 -- --
11 -- Copyright (C) 1992-2002 Free Software Foundation, Inc. --
12 -- --
13 -- This specification is derived from the Ada Reference Manual for use with --
14 -- GNAT. The copyright notice above, and the license provisions that follow --
15 -- apply solely to the contents of the part following the private keyword. --
16 -- --
17 -- GNAT is free software; you can redistribute it and/or modify it under --
18 -- terms of the GNU General Public License as published by the Free Soft- --
19 -- ware Foundation; either version 2, or (at your option) any later ver- --
20 -- sion. GNAT is distributed in the hope that it will be useful, but WITH- --
21 -- OUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY --
22 -- or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License --
23 -- for more details. You should have received a copy of the GNU General --
24 -- Public License distributed with GNAT; see file COPYING. If not, write --
25 -- to the Free Software Foundation, 59 Temple Place - Suite 330, Boston, --
26 -- MA 02111-1307, USA. --
27 -- --
28 -- As a special exception, if other files instantiate generics from this --
29 -- unit, or you link this unit with other files to produce an executable, --
30 -- this unit does not by itself cause the resulting executable to be --
31 -- covered by the GNU General Public License. This exception does not --
32 -- however invalidate any other reasons why the executable file might be --
33 -- covered by the GNU Public License. --
34 -- --
35 -- GNAT was originally developed by the GNAT team at New York University. --
36 -- Extensive contributions were provided by Ada Core Technologies Inc. --
37 -- --
38 ------------------------------------------------------------------------------
40 package System is
41 pragma Pure (System);
42 -- Note that we take advantage of the implementation permission to
43 -- make this unit Pure instead of Preelaborable, see RM 13.7(36)
45 type Name is (SYSTEM_NAME_GNAT);
46 System_Name : constant Name := SYSTEM_NAME_GNAT;
48 -- System-Dependent Named Numbers
50 Min_Int : constant := Long_Long_Integer'First;
51 Max_Int : constant := Long_Long_Integer'Last;
53 Max_Binary_Modulus : constant := 2 ** Long_Long_Integer'Size;
54 Max_Nonbinary_Modulus : constant := Integer'Last;
56 Max_Base_Digits : constant := Long_Long_Float'Digits;
57 Max_Digits : constant := Long_Long_Float'Digits;
59 Max_Mantissa : constant := 63;
60 Fine_Delta : constant := 2.0 ** (-Max_Mantissa);
62 Tick : constant := 1.0;
64 -- Storage-related Declarations
66 type Address is private;
67 Null_Address : constant Address;
69 Storage_Unit : constant := 8;
70 Word_Size : constant := 32;
71 Memory_Size : constant := 2 ** 32;
73 -- Address comparison
75 function "<" (Left, Right : Address) return Boolean;
76 function "<=" (Left, Right : Address) return Boolean;
77 function ">" (Left, Right : Address) return Boolean;
78 function ">=" (Left, Right : Address) return Boolean;
79 function "=" (Left, Right : Address) return Boolean;
81 pragma Import (Intrinsic, "<");
82 pragma Import (Intrinsic, "<=");
83 pragma Import (Intrinsic, ">");
84 pragma Import (Intrinsic, ">=");
85 pragma Import (Intrinsic, "=");
87 -- Other System-Dependent Declarations
89 type Bit_Order is (High_Order_First, Low_Order_First);
90 Default_Bit_Order : constant Bit_Order := Low_Order_First;
92 -- Priority-related Declarations (RM D.1)
94 Max_Priority : constant Positive := 30;
95 Max_Interrupt_Priority : constant Positive := 31;
97 subtype Any_Priority is Integer range 0 .. 31;
98 subtype Priority is Any_Priority range 0 .. 30;
99 subtype Interrupt_Priority is Any_Priority range 31 .. 31;
101 Default_Priority : constant Priority := 15;
103 private
105 type Address is mod Memory_Size;
106 Null_Address : constant Address := 0;
108 --------------------------------------
109 -- System Implementation Parameters --
110 --------------------------------------
112 -- These parameters provide information about the target that is used
113 -- by the compiler. They are in the private part of System, where they
114 -- can be accessed using the special circuitry in the Targparm unit
115 -- whose source should be consulted for more detailed descriptions
116 -- of the individual switch values.
118 AAMP : constant Boolean := False;
119 Backend_Divide_Checks : constant Boolean := False;
120 Backend_Overflow_Checks : constant Boolean := False;
121 Command_Line_Args : constant Boolean := True;
122 Denorm : constant Boolean := False;
123 Fractional_Fixed_Ops : constant Boolean := False;
124 Frontend_Layout : constant Boolean := False;
125 Functions_Return_By_DSP : constant Boolean := False;
126 Long_Shifts_Inlined : constant Boolean := True;
127 High_Integrity_Mode : constant Boolean := False;
128 Machine_Overflows : constant Boolean := False;
129 Machine_Rounds : constant Boolean := True;
130 OpenVMS : constant Boolean := True;
131 Signed_Zeros : constant Boolean := True;
132 Stack_Check_Default : constant Boolean := True;
133 Stack_Check_Probes : constant Boolean := True;
134 Use_Ada_Main_Program_Name : constant Boolean := False;
135 ZCX_By_Default : constant Boolean := True;
136 GCC_ZCX_Support : constant Boolean := False;
137 Front_End_ZCX_Support : constant Boolean := True;
139 --------------------------
140 -- Underlying Priorities --
141 ---------------------------
143 -- Important note: this section of the file must come AFTER the
144 -- definition of the system implementation parameters to ensure
145 -- that the value of these parameters is available for analysis
146 -- of the declarations here (using Rtsfind at compile time).
148 -- The underlying priorities table provides a generalized mechanism
149 -- for mapping from Ada priorities to system priorities. In some
150 -- cases a 1-1 mapping is not the convenient or optimal choice.
152 -- For DEC Threads OpenVMS, we use the full range of 31 priorities
153 -- in the Ada model, but map them by compression onto the more limited
154 -- range of priorities available in OpenVMS.
156 -- To replace the default values of the Underlying_Priorities mapping,
157 -- copy this source file into your build directory, edit the file to
158 -- reflect your desired behavior, and recompile with the command:
160 -- $ gcc -c -O3 -gnatpgn system.ads
162 -- then recompile the run-time parts that depend on this package:
164 -- $ gnatmake -a -gnatn -O3 <your application>
166 -- then force rebuilding your application if you need different options:
168 -- $ gnatmake -f <your options> <your application>
170 type Priorities_Mapping is array (Any_Priority) of Integer;
171 pragma Suppress_Initialization (Priorities_Mapping);
172 -- Suppress initialization in case gnat.adc specifies Normalize_Scalars
174 Underlying_Priorities : constant Priorities_Mapping :=
176 (Priority'First => 16,
178 1 => 17,
179 2 => 18,
180 3 => 18,
181 4 => 18,
182 5 => 18,
183 6 => 19,
184 7 => 19,
185 8 => 19,
186 9 => 20,
187 10 => 20,
188 11 => 21,
189 12 => 21,
190 13 => 22,
191 14 => 23,
193 Default_Priority => 24,
195 16 => 25,
196 17 => 25,
197 18 => 25,
198 19 => 26,
199 20 => 26,
200 21 => 26,
201 22 => 27,
202 23 => 27,
203 24 => 27,
204 25 => 28,
205 26 => 28,
206 27 => 29,
207 28 => 29,
208 29 => 30,
210 Priority'Last => 30,
212 Interrupt_Priority => 31);
214 ----------------------------
215 -- Special VMS Interfaces --
216 ----------------------------
218 procedure Lib_Stop (I : in Integer);
219 pragma Interface (C, Lib_Stop);
220 pragma Import_Procedure (Lib_Stop, "LIB$STOP", Mechanism => (Value));
221 -- Interface to VMS condition handling. Used by RTSfind and pragma
222 -- {Import,Export}_Exception. Put here because this is the only
223 -- VMS specific package that doesn't drag in tasking.
225 end System;