diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/ghdldrv/ghdlsimul.adb | 1 | ||||
| -rw-r--r-- | src/simul/simul-vhdl_elab.adb | 34 | ||||
| -rw-r--r-- | src/simul/simul-vhdl_elab.ads | 11 | 
3 files changed, 25 insertions, 21 deletions
| diff --git a/src/ghdldrv/ghdlsimul.adb b/src/ghdldrv/ghdlsimul.adb index fd260b5ec..05dd4f705 100644 --- a/src/ghdldrv/ghdlsimul.adb +++ b/src/ghdldrv/ghdlsimul.adb @@ -146,6 +146,7 @@ package body Ghdlsimul is        Simul.Vhdl_Elab.Gather_Processes (Inst);        Simul.Vhdl_Elab.Elab_Processes; +      Simul.Vhdl_Elab.Compute_Sources;        if Errorout.Nbr_Errors > 0 then           raise Errorout.Compilation_Error; diff --git a/src/simul/simul-vhdl_elab.adb b/src/simul/simul-vhdl_elab.adb index 3e5acc3d8..03bd3f863 100644 --- a/src/simul/simul-vhdl_elab.adb +++ b/src/simul/simul-vhdl_elab.adb @@ -516,6 +516,7 @@ package body Simul.Vhdl_Elab is     procedure Gather_Process_Drivers       (Inst : Synth_Instance_Acc; Proc : Node; Proc_Idx : Process_Index_Type)     is +      Prev_Instance_Pool : constant Areapools.Areapool_Acc := Instance_Pool;        Driver_List: Iir_List;        It : List_Iterator;        El : Node; @@ -534,7 +535,7 @@ package body Simul.Vhdl_Elab is           Next (It);        end loop; -      Instance_Pool := null; +      Instance_Pool := Prev_Instance_Pool;        Trans_Analyzes.Free_Drivers_List (Driver_List);     end Gather_Process_Drivers; @@ -542,6 +543,7 @@ package body Simul.Vhdl_Elab is                                   Proc_Idx : Process_Index_Type;                                   List : Iir_List)     is +      Prev_Instance_Pool : constant Areapools.Areapool_Acc := Instance_Pool;        It : List_Iterator;        El : Node;        Sig : Sub_Signal_Type; @@ -573,7 +575,7 @@ package body Simul.Vhdl_Elab is           Next (It);        end loop; -      Instance_Pool := null; +      Instance_Pool := Prev_Instance_Pool;     end Gather_Sensitivity;     procedure Gather_Process_Sensitivity @@ -890,9 +892,8 @@ package body Simul.Vhdl_Elab is                 end if;              end;           when Iir_Kinds_Concurrent_Signal_Assignment -           | Iir_Kind_Concurrent_Assertion_Statement -           | Iir_Kind_Concurrent_Procedure_Call_Statement -           | Iir_Kinds_Process_Statement => +            | Iir_Kind_Concurrent_Assertion_Statement +            | Iir_Kind_Concurrent_Procedure_Call_Statement =>              Processes_Table.Append ((Proc => Stmt,                                       Inst => Inst,                                       Drivers => No_Driver_Index, @@ -901,6 +902,13 @@ package body Simul.Vhdl_Elab is              Gather_Process_Drivers (Inst, Stmt, Processes_Table.Last);              pragma Assert (Is_Expr_Pool_Empty);              Gather_Process_Sensitivity (Inst, Stmt, Processes_Table.Last); +         when Iir_Kinds_Process_Statement => +            Processes_Table.Append ((Proc => Stmt, +                                     Inst => Inst, +                                     Drivers => No_Driver_Index, +                                     Sensitivity => No_Sensitivity_Index)); +            --  Do not yet compute drivers or sensitivity as it may depends +            --  on declarations within the process.           when Iir_Kind_Psl_Default_Clock             | Iir_Kind_Psl_Declaration             | Iir_Kind_Psl_Endpoint_Declaration => @@ -1036,7 +1044,10 @@ package body Simul.Vhdl_Elab is        --  For the debugger.        Top_Instance := Top; +   end Gather_Processes; +   procedure Compute_Sources is +   begin        --  Compute total number of sources.        for I in Signals_Table.First .. Signals_Table.Last loop           declare @@ -1073,7 +1084,7 @@ package body Simul.Vhdl_Elab is              end if;           end;        end loop; -   end Gather_Processes; +   end Compute_Sources;     procedure Elab_Processes     is @@ -1093,13 +1104,14 @@ package body Simul.Vhdl_Elab is              Synth.Vhdl_Decls.Synth_Declarations                (Proc_Inst, Get_Declaration_Chain (Proc), True);              exit when Is_Error (Proc_Inst); + +            pragma Assert (Is_Expr_Pool_Empty); +            Gather_Process_Drivers (Proc_Inst, Proc, I); +            pragma Assert (Is_Expr_Pool_Empty); +            Gather_Process_Sensitivity (Proc_Inst, Proc, I); +           end if;        end loop;        Instance_Pool := null;     end Elab_Processes; - -   procedure Elab_Drivers is -   begin -      null; -   end Elab_Drivers;  end Simul.Vhdl_Elab; diff --git a/src/simul/simul-vhdl_elab.ads b/src/simul/simul-vhdl_elab.ads index 9a0554a00..32ded4a8d 100644 --- a/src/simul/simul-vhdl_elab.ads +++ b/src/simul/simul-vhdl_elab.ads @@ -31,21 +31,12 @@ with Elab.Vhdl_Context; use Elab.Vhdl_Context;  package Simul.Vhdl_Elab is     procedure Gather_Processes (Top : Synth_Instance_Acc); +   procedure Compute_Sources;     procedure Elab_Processes;     --  For the debugger.     Top_Instance : Synth_Instance_Acc; -   --  For each signals: -   --  * drivers (process + area), sources -   --  * sensitivity -   --  * waveform assignments -   --  * decomposition level: none, vectors, full. -   --  * force/release -   --  * need to track activity -   --  * need to track events -   procedure Elab_Drivers; -     --  Change the meaning of W (width) in T for simulation.     procedure Convert_Type_Width (T : Type_Acc); | 
