File : system-xi-e500v2-sfp.ads


   1 ------------------------------------------------------------------------------
   2 --                                                                          --
   3 --                        GNAT RUN-TIME COMPONENTS                          --
   4 --                                                                          --
   5 --                               S Y S T E M                                --
   6 --                                                                          --
   7 --                                 S p e c                                  --
   8 --                            (PPC e500v2 Version)                          --
   9 --                                                                          --
  10 --          Copyright (C) 1992-2016, Free Software Foundation, Inc.         --
  11 --                                                                          --
  12 -- This specification is derived from the Ada Reference Manual for use with --
  13 -- GNAT. The copyright notice above, and the license provisions that follow --
  14 -- apply solely to the  contents of the part following the private keyword. --
  15 --                                                                          --
  16 -- GNAT is free software;  you can  redistribute it  and/or modify it under --
  17 -- terms of the  GNU General Public License as published  by the Free Soft- --
  18 -- ware  Foundation;  either version 3,  or (at your option) any later ver- --
  19 -- sion.  GNAT is distributed in the hope that it will be useful, but WITH- --
  20 -- OUT ANY WARRANTY;  without even the  implied warranty of MERCHANTABILITY --
  21 -- or FITNESS FOR A PARTICULAR PURPOSE.                                     --
  22 --                                                                          --
  23 --                                                                          --
  24 --                                                                          --
  25 --                                                                          --
  26 --                                                                          --
  27 -- You should have received a copy of the GNU General Public License and    --
  28 -- a copy of the GCC Runtime Library Exception along with this program;     --
  29 -- see the files COPYING3 and COPYING.RUNTIME respectively.  If not, see    --
  30 -- <http://www.gnu.org/licenses/>.                                          --
  31 --                                                                          --
  32 -- GNAT was originally developed  by the GNAT team at  New York University. --
  33 -- Extensive contributions were provided by Ada Core Technologies Inc.      --
  34 --                                                                          --
  35 ------------------------------------------------------------------------------
  36 
  37 pragma Restrictions (No_Exception_Propagation);
  38 --  Only local exception handling is supported in this profile
  39 
  40 pragma Restrictions (No_Exception_Registration);
  41 --  Disable exception name registration. This capability is not used because
  42 --  it is only required by exception stream attributes which are not supported
  43 --  in this run time.
  44 
  45 pragma Restrictions (No_Implicit_Dynamic_Code);
  46 --  Pointers to nested subprograms are not allowed in this run time, in order
  47 --  to prevent the compiler from building "trampolines".
  48 
  49 pragma Restrictions (No_Finalization);
  50 --  Controlled types are not supported in this run time
  51 
  52 pragma Profile (Ravenscar);
  53 --  This is a Ravenscar run time
  54 
  55 pragma Discard_Names;
  56 --  Disable explicitly the generation of names associated with entities in
  57 --  order to reduce the amount of storage used. These names are not used anyway
  58 --  (attributes such as 'Image and 'Value are not supported in this run time).
  59 
  60 package System is
  61    pragma Pure;
  62    --  Note that we take advantage of the implementation permission to make
  63    --  this unit Pure instead of Preelaborable; see RM 13.7.1(15). In Ada
  64    --  2005, this is Pure in any case (AI-362).
  65 
  66    pragma No_Elaboration_Code_All;
  67    --  Allow the use of that restriction in units that WITH this unit
  68 
  69    type Name is (SYSTEM_NAME_GNAT);
  70    System_Name : constant Name := SYSTEM_NAME_GNAT;
  71 
  72    --  System-Dependent Named Numbers
  73 
  74    Min_Int               : constant := Long_Long_Integer'First;
  75    Max_Int               : constant := Long_Long_Integer'Last;
  76 
  77    Max_Binary_Modulus    : constant := 2 ** Long_Long_Integer'Size;
  78    Max_Nonbinary_Modulus : constant := 2 ** Integer'Size - 1;
  79 
  80    Max_Base_Digits       : constant := Long_Long_Float'Digits;
  81    Max_Digits            : constant := Long_Long_Float'Digits;
  82 
  83    Max_Mantissa          : constant := 63;
  84    Fine_Delta            : constant := 2.0 ** (-Max_Mantissa);
  85 
  86    Tick                  : constant := 0.000_001;
  87 
  88    --  Storage-related Declarations
  89 
  90    type Address is private;
  91    pragma Preelaborable_Initialization (Address);
  92    Null_Address : constant Address;
  93 
  94    Storage_Unit : constant := 8;
  95    Word_Size    : constant := 32;
  96    Memory_Size  : constant := 2 ** 32;
  97 
  98    --  Address comparison
  99 
 100    function "<"  (Left, Right : Address) return Boolean;
 101    function "<=" (Left, Right : Address) return Boolean;
 102    function ">"  (Left, Right : Address) return Boolean;
 103    function ">=" (Left, Right : Address) return Boolean;
 104    function "="  (Left, Right : Address) return Boolean;
 105 
 106    pragma Import (Intrinsic, "<");
 107    pragma Import (Intrinsic, "<=");
 108    pragma Import (Intrinsic, ">");
 109    pragma Import (Intrinsic, ">=");
 110    pragma Import (Intrinsic, "=");
 111 
 112    --  Other System-Dependent Declarations
 113 
 114    type Bit_Order is (High_Order_First, Low_Order_First);
 115    Default_Bit_Order : constant Bit_Order := High_Order_First;
 116    pragma Warnings (Off, Default_Bit_Order); -- kill constant condition warning
 117 
 118    --  Priority-related Declarations (RM D.1)
 119 
 120    --  The OpenPIC has 16 interrupt priority levels, plus 1 for the decrementer
 121    Nbr_Interrupt_Priorities : constant Positive := 17;
 122    Max_Interrupt_Priority   : constant Positive := 255;
 123    Max_Priority             : constant Positive :=
 124      Max_Interrupt_Priority - Nbr_Interrupt_Priorities;
 125 
 126    subtype Any_Priority       is Integer
 127      range   0 .. Max_Interrupt_Priority;
 128    subtype Priority           is Any_Priority
 129      range   0 .. Max_Priority;
 130    subtype Interrupt_Priority is Any_Priority
 131      range Priority'Last + 1 .. Any_Priority'Last;
 132 
 133    Default_Priority : constant Priority :=
 134      (Priority'Last - Priority'First) / 2;
 135 
 136 private
 137 
 138    type Address is mod Memory_Size;
 139    Null_Address : constant Address := 0;
 140 
 141    --------------------------------------
 142    -- System Implementation Parameters --
 143    --------------------------------------
 144 
 145    --  These parameters provide information about the target that is used
 146    --  by the compiler. They are in the private part of System, where they
 147    --  can be accessed using the special circuitry in the Targparm unit
 148    --  whose source should be consulted for more detailed descriptions
 149    --  of the individual switch values.
 150 
 151    Atomic_Sync_Default       : constant Boolean := False;
 152    Backend_Divide_Checks     : constant Boolean := False;
 153    Backend_Overflow_Checks   : constant Boolean := True;
 154    Command_Line_Args         : constant Boolean := False;
 155    Configurable_Run_Time     : constant Boolean := True;
 156    Denorm                    : constant Boolean := True;
 157    Duration_32_Bits          : constant Boolean := False;
 158    Exit_Status_Supported     : constant Boolean := False;
 159    Fractional_Fixed_Ops      : constant Boolean := False;
 160    Frontend_Layout           : constant Boolean := False;
 161    Machine_Overflows         : constant Boolean := True;
 162    Machine_Rounds            : constant Boolean := True;
 163    Preallocated_Stacks       : constant Boolean := True;
 164    --  MPC8548ECE Chip Errata Rev 8: signed zero not reliable
 165    Signed_Zeros              : constant Boolean := False;
 166    Stack_Check_Default       : constant Boolean := False;
 167    Stack_Check_Probes        : constant Boolean := False;
 168    Stack_Check_Limits        : constant Boolean := False;
 169    Support_Aggregates        : constant Boolean := True;
 170    Support_Composite_Assign  : constant Boolean := True;
 171    Support_Composite_Compare : constant Boolean := True;
 172    Support_Long_Shifts       : constant Boolean := True;
 173    Always_Compatible_Rep     : constant Boolean := True;
 174    Suppress_Standard_Library : constant Boolean := True;
 175    Use_Ada_Main_Program_Name : constant Boolean := False;
 176    Frontend_Exceptions       : constant Boolean := False;
 177    ZCX_By_Default            : constant Boolean := True;
 178 
 179 end System;