diff options
Diffstat (limited to 'src/simulate/elaboration.ads')
-rw-r--r-- | src/simulate/elaboration.ads | 209 |
1 files changed, 0 insertions, 209 deletions
diff --git a/src/simulate/elaboration.ads b/src/simulate/elaboration.ads deleted file mode 100644 index 5a9ea8d..0000000 --- a/src/simulate/elaboration.ads +++ /dev/null @@ -1,209 +0,0 @@ --- Elaboration for interpretation --- Copyright (C) 2014 Tristan Gingold --- --- GHDL is free software; you can redistribute it and/or modify it under --- the terms of the GNU General Public License as published by the Free --- Software Foundation; either version 2, or (at your option) any later --- version. --- --- GHDL is distributed in the hope that it will be useful, but WITHOUT ANY --- WARRANTY; without even the implied warranty of MERCHANTABILITY or --- FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License --- for more details. --- --- You should have received a copy of the GNU General Public License --- along with GHDL; see the file COPYING. If not, write to the Free --- Software Foundation, 59 Temple Place - Suite 330, Boston, MA --- 02111-1307, USA. - -with Ada.Unchecked_Deallocation; -with GNAT.Table; -with Iirs; use Iirs; -with Iir_Values; use Iir_Values; -with Grt.Types; -with Annotations; use Annotations; -with Areapools; - --- This package elaborates design hierarchy. - -package Elaboration is - Trace_Elaboration : Boolean := False; - Trace_Drivers : Boolean := False; - - -- A block instance with its architecture/entity declaration is an - -- instancied entity. - type Block_Instance_Type; - type Block_Instance_Acc is access Block_Instance_Type; - - type Objects_Array is array (Object_Slot_Type range <>) of - Iir_Value_Literal_Acc; - - -- A block instance with its architecture/entity declaration is an - -- instancied entity. - - type Block_Instance_Type (Max_Objs : Object_Slot_Type) is record - -- Flag for wait statement: true if not yet executed. - In_Wait_Flag : Boolean; - - -- Useful informations for a dynamic block (ie, a frame). - -- The scope level and an access to the block of upper scope level. - Scope_Level: Scope_Level_Type; - Up_Block: Block_Instance_Acc; - - -- Block, architecture, package, process, component instantiation for - -- this instance. - Label : Iir; - - -- For blocks: corresponding block (different from label for direct - -- component instantiation statement and generate iterator). - -- For packages: Null_Iir - -- For subprograms and processes: statement being executed. - Stmt : Iir; - - -- Instanciation tree. - -- Parent is always set (but null for top-level block and packages) - Parent: Block_Instance_Acc; - -- Not null only for blocks and processes. - Children: Block_Instance_Acc; - Brother: Block_Instance_Acc; - - -- Pool marker for the child (only for subprograms and processes). - Marker : Areapools.Mark_Type; - - -- Reference to the actuals, for copy-out when returning from a - -- procedure. - Actuals_Ref : Value_Array_Acc; - - -- Only for function frame; contains the result. - Result: Iir_Value_Literal_Acc; - - -- Last object elaborated (or number of objects elaborated). - -- Note: this is generally the slot index of the next object to be - -- elaborated (this may be wrong for dynamic objects due to execution - -- branches). - Elab_Objects : Object_Slot_Type := 0; - - -- Values of the objects in that frame. - Objects : Objects_Array (1 .. Max_Objs); - end record; - - procedure Free is new Ada.Unchecked_Deallocation - (Object => Block_Instance_Type, Name => Block_Instance_Acc); - - procedure Elaborate_Design (Design: Iir_Design_Unit); - - procedure Elaborate_Declarative_Part - (Instance : Block_Instance_Acc; Decl_Chain : Iir); - - -- Reverse operation of Elaborate_Declarative_Part. - -- At least, finalize files. - procedure Finalize_Declarative_Part - (Instance : Block_Instance_Acc; Decl_Chain : Iir); - - procedure Elaborate_Declaration (Instance : Block_Instance_Acc; Decl : Iir); - - procedure Destroy_Iterator_Declaration - (Instance : Block_Instance_Acc; Decl : Iir); - - -- Create a value for type DECL. Initialize it if DEFAULT is true. - function Create_Value_For_Type - (Block: Block_Instance_Acc; Decl: Iir; Default : Boolean) - return Iir_Value_Literal_Acc; - - -- LRM93 §12.3.1.3 Subtype Declarations - -- The elaboration of a subtype indication creates a subtype. - -- Used for allocator. - procedure Elaborate_Subtype_Indication - (Instance : Block_Instance_Acc; Ind : Iir); - - -- Create object DECL. - -- This does nothing except marking DECL as elaborated. - -- Used by simulation to dynamically create subprograms interfaces. - procedure Create_Object (Instance : Block_Instance_Acc; Decl : Iir); - procedure Create_Signal (Instance : Block_Instance_Acc; Decl : Iir); - - Top_Instance: Block_Instance_Acc; - - type Block_Instance_Acc_Array is array (Instance_Slot_Type range <>) of - Block_Instance_Acc; - type Block_Instance_Acc_Array_Acc is access Block_Instance_Acc_Array; - - Package_Instances : Block_Instance_Acc_Array_Acc; - - -- Disconnections. For each disconnection specification, the elaborator - -- adds an entry in the table. - type Disconnection_Entry is record - Sig : Iir_Value_Literal_Acc; - Time : Iir_Value_Time; - end record; - - package Disconnection_Table is new GNAT.Table - (Table_Component_Type => Disconnection_Entry, - Table_Index_Type => Integer, - Table_Low_Bound => 0, - Table_Initial => 16, - Table_Increment => 100); - - -- Connections. For each associations (block/component/entry), the - -- elaborator adds an entry in that table. - type Connect_Entry is record - Formal : Iir_Value_Literal_Acc; - Formal_Instance : Block_Instance_Acc; - Actual : Iir_Value_Literal_Acc; - Actual_Instance : Block_Instance_Acc; - Assoc : Iir; - end record; - - package Connect_Table is new GNAT.Table - (Table_Component_Type => Connect_Entry, - Table_Index_Type => Integer, - Table_Low_Bound => 0, - Table_Initial => 32, - Table_Increment => 100); - - -- Signals. - type Signal_Type_Kind is - (User_Signal, - Implicit_Quiet, Implicit_Stable, Implicit_Delayed, - Implicit_Transaction, - Guard_Signal); - - type Signal_Entry (Kind : Signal_Type_Kind := User_Signal) is record - Decl : Iir; - Sig : Iir_Value_Literal_Acc; - Instance : Block_Instance_Acc; - case Kind is - when User_Signal => - Init : Iir_Value_Literal_Acc; - when Implicit_Quiet | Implicit_Stable | Implicit_Delayed - | Implicit_Transaction => - Time : Grt.Types.Ghdl_I64; - Prefix : Iir_Value_Literal_Acc; - when Guard_Signal => - null; - end case; - end record; - - package Signals_Table is new GNAT.Table - (Table_Component_Type => Signal_Entry, - Table_Index_Type => Integer, - Table_Low_Bound => 0, - Table_Initial => 128, - Table_Increment => 100); - - type Process_Index_Type is new Natural; - - package Processes_Table is new GNAT.Table - (Table_Component_Type => Block_Instance_Acc, - Table_Index_Type => Process_Index_Type, - Table_Low_Bound => 1, - Table_Initial => 128, - Table_Increment => 100); - - package Protected_Table is new GNAT.Table - (Table_Component_Type => Block_Instance_Acc, - Table_Index_Type => Protected_Index_Type, - Table_Low_Bound => 1, - Table_Initial => 2, - Table_Increment => 100); -end Elaboration; |