|
|
DataMuseum.dkPresents historical artifacts from the history of: Rational R1000/400 |
This is an automatic "excavation" of a thematic subset of
See our Wiki for more about Rational R1000/400 Excavated with: AutoArchaeologist - Free & Open Source Software. |
top - metrics - download
Length: 9216 (0x2400)
Types: Ada Source
Notes: 03_class, FILE, R1k_Segment, e3_tag, package V_I_Types, seg_03bda1
└─⟦8527c1e9b⟧ Bits:30000544 8mm tape, Rational 1000, Arrival backup of disks in PAM's R1000
└─⟦cfc2e13cd⟧ »Space Info Vol 2«
└─⟦this⟧
-- Copyright 1987, 1988 Verdix Corporation
------------------------------------------------------------------------------
-- Standard interface types for the M68000 processor family version of
-- the RTS.
------------------------------------------------------------------------------
with System;
with Unchecked_Conversion;
package V_I_Types is
pragma Suppress (All_Checks);
pragma Suppress (Exception_Tables);
pragma Not_Elaborated;
--------------------------------------------------------------------------
-- TIME type
--------------------------------------------------------------------------
-- Internal RTS representation for day. If the calendar package is used,
-- then, this is the julian day.
subtype Day_T is Integer;
-- Internal representation for current or absolute time. The current time
-- is normalized so that sec is less than a day (86400.0 seconds)
type Time_T is
record
Day : Day_T;
Sec : Duration;
end record;
--------------------------------------------------------------------------
-- Interrupt types
--------------------------------------------------------------------------
-- Exception vector table ID's
subtype Intr_Vector_Id_T is Natural;
-- Interrupt enable/disable status: Interrupt Priority Level (IPL)
-- mask stored in Status Register
subtype Intr_Status_T is Integer;
Disable_Intr_Status : constant := 16#0700#;
Enable_Intr_Status : constant := 16#0000#;
Level_0_Intr_Status : constant := 16#0000#;
Level_1_Intr_Status : constant := 16#0100#;
Level_2_Intr_Status : constant := 16#0200#;
Level_3_Intr_Status : constant := 16#0300#;
Level_4_Intr_Status : constant := 16#0400#;
Level_5_Intr_Status : constant := 16#0500#;
Level_6_Intr_Status : constant := 16#0600#;
Level_7_Intr_Status : constant := 16#0700#;
--------------------------------------------------------------------------
-- The following types define the structure of the fpcr register
-- on the MC68881. A configuration parameter of this type allows
-- the user to control the operating characteristics of the co-
-- processor by providing the value to which the fpcr should be
-- initialized.
--------------------------------------------------------------------------
type Exception_Bit is range 0 .. 1;
type Rounding_Modes is (To_Nearest, Toward_Zero,
Toward_Minus_Infinity, Toward_Plus_Infinity);
for Rounding_Modes use (To_Nearest => 2#00#,
Toward_Zero => 2#01#,
Toward_Minus_Infinity => 2#10#,
Toward_Plus_Infinity => 2#11#);
type Rounding_Precision is (Extended, Single, Double);
for Rounding_Precision use
(Extended => 2#00#, Single => 2#01#, Double => 2#10#);
type Mode_Control_Byte is
record
Prec : Rounding_Precision;
Rnd : Rounding_Modes;
end record;
for Mode_Control_Byte use
record
Prec at 0 range 0 .. 1;
Rnd at 0 range 2 .. 3;
end record;
for Mode_Control_Byte'Size use 8;
type Exception_Byte is
record
Bsun : Exception_Bit;
Snan : Exception_Bit;
Operr : Exception_Bit;
Ovfl : Exception_Bit;
Unfl : Exception_Bit;
Dz : Exception_Bit;
Inex2 : Exception_Bit;
Inex1 : Exception_Bit;
end record;
for Exception_Byte use
record
Bsun at 0 range 0 .. 0;
Snan at 0 range 1 .. 1;
Operr at 0 range 2 .. 2;
Ovfl at 0 range 3 .. 3;
Unfl at 0 range 4 .. 4;
Dz at 0 range 5 .. 5;
Inex2 at 0 range 6 .. 6;
Inex1 at 0 range 7 .. 7;
end record;
for Exception_Byte'Size use 8;
type Floating_Point_Control_T is
record
Exceptions : Exception_Byte;
Modes : Mode_Control_Byte;
end record;
for Floating_Point_Control_T use
record
Exceptions at 2 range 00 .. 07;
Modes at 3 range 00 .. 07;
end record;
for Floating_Point_Control_T'Size use 32;
--------------------------------------------------------------------------
-- Space needed at bottom of user stack for exception handling
--------------------------------------------------------------------------
Exception_Stack_Size : constant := 1000;
--------------------------------------------------------------------------
-- User interface to RTS data structures
--------------------------------------------------------------------------
-- Program control block
type A_Program_T is new System.Address;
-- Task control block
type A_Task_T is new System.Address;
Null_Task : -- constant KLUDGE: was not being initialized statically
-- now initiallized dynamically in boot_conf.v_boot.
A_Task_T := A_Task_T (System.No_Addr);
-- Type of user_field in task control record
subtype User_Field_T is Integer;
-- Signal structure
type A_Signal_T is new System.Address;
--------------------------------------------------------------------------
-- User memory types, constants, conversion functions
--------------------------------------------------------------------------
type User_Address_T is new System.Address;
type Short_Address_T is new System.Address;
type A_Memory_Map_T is new System.Address;
Null_User_Address : -- constant KLUDGE: was not being initialized statically
-- now initiallized dynamically in boot_conf.v_boot.
User_Address_T := User_Address_T (System.No_Addr);
function Make_Address is new Unchecked_Conversion
(System.Address, User_Address_T);
function I_To_A is new Unchecked_Conversion (Integer, System.Address);
function Ua_To_A is new Unchecked_Conversion
(User_Address_T, System.Address);
--------------------------------------------------------------------------
-- Misc type definitions
--------------------------------------------------------------------------
-- Type of value returned by v_i_taskop.ts_entry_count
subtype Universal_Integer_T is Integer;
type Long_Integer is new Integer;
subtype Alloc_T is Integer; -- allocate length type
subtype Physical_Adr_As_Int is Integer;
-- Values corresponding to a zero/non-zero for the machine test-and-set
type Test_And_Set_T is new Integer range 0 .. 255;
for Test_And_Set_T'Size use 8;
Test_And_Set_False : constant Test_And_Set_T := 0;
Test_And_Set_True : constant Test_And_Set_T := 16#80#; -- bit 7 of byte
end V_I_Types;
nblk1=8
nid=0
hdr6=10
[0x00] rec0=1d rec1=00 rec2=01 rec3=00c
[0x01] rec0=1b rec1=00 rec2=02 rec3=00e
[0x02] rec0=13 rec1=00 rec2=03 rec3=06c
[0x03] rec0=23 rec1=00 rec2=04 rec3=03e
[0x04] rec0=1d rec1=00 rec2=05 rec3=038
[0x05] rec0=19 rec1=00 rec2=06 rec3=02a
[0x06] rec0=16 rec1=00 rec2=07 rec3=020
[0x07] rec0=03 rec1=00 rec2=08 rec3=001
tail 0x21739b7148565742b3cfa 0x42a00088462060003