diff options
author | Tristan Gingold <tgingold@free.fr> | 2018-03-03 08:04:08 +0100 |
---|---|---|
committer | Tristan Gingold <tgingold@free.fr> | 2018-03-03 08:04:08 +0100 |
commit | cb682caa8f6d4432ec67ff90fddb625d395c3d9a (patch) | |
tree | 965842ee9fd2daa8a1c12b7e15abc4fc373c4888 /src/grt | |
parent | 6a4d14a8afd34c3935cd165db30c249e19b6751b (diff) | |
download | ghdl-cb682caa8f6d4432ec67ff90fddb625d395c3d9a.tar.gz ghdl-cb682caa8f6d4432ec67ff90fddb625d395c3d9a.tar.bz2 ghdl-cb682caa8f6d4432ec67ff90fddb625d395c3d9a.zip |
grt-signals: simplify code.
Diffstat (limited to 'src/grt')
-rw-r--r-- | src/grt/grt-signals.adb | 79 | ||||
-rw-r--r-- | src/grt/grt-signals.ads | 7 |
2 files changed, 33 insertions, 53 deletions
diff --git a/src/grt/grt-signals.adb b/src/grt/grt-signals.adb index 6c2dd4898..68544f233 100644 --- a/src/grt/grt-signals.adb +++ b/src/grt/grt-signals.adb @@ -254,6 +254,7 @@ package body Grt.Signals is Is_Direct_Active => False, Is_Dumped => False, RO_Event => False, + Implicit_Active_Next => False, Seen => False), Net => No_Signal_Net, @@ -619,6 +620,7 @@ package body Grt.Signals is Is_Direct_Active => False, Is_Dumped => False, RO_Event => False, + Implicit_Active_Next => False, Seen => False), Net => No_Signal_Net, @@ -643,14 +645,11 @@ package body Grt.Signals is Signal_End : constant Ghdl_Signal_Ptr := Signal_End_Decl'Unrestricted_access; - -- List of signals that will be active in the next delta cycle. + -- List of signals that will be active in the next delta cycle. Signals + -- are inserted on this chain while processes are scheduling a transaction + -- with a delay of 0. Signal_Active_Chain : Ghdl_Signal_Ptr; - -- List of implicit signals that will be active in the next cycle. - -- They are put in a different chain (other than signal_active_chain), - -- because their handling is different. FIXME: try to merge them ? - Implicit_Signal_Active_Chain : Ghdl_Signal_Ptr; - -- List of signals whose 'Active flag must be cleared. A signal is added -- to this list by Mark_Active and removed by Reset_Active_Flag at the -- beginning of the next cycle. This list is null-terminated, as it uses @@ -1981,9 +1980,6 @@ package body Grt.Signals is if Force_Value_First /= null then return Current_Time; end if; - if Implicit_Signal_Active_Chain.Link /= null then - return Current_Time; - end if; Res := Tn; Sig := Future_List; @@ -2978,7 +2974,8 @@ package body Grt.Signals is end if; if Sig.S.Time = 0 then - Insert_Update_Clear_Chain (Sig); + -- FIXME: the signal should also be active this cycle ?? + Sig.Flags.Implicit_Active_Next := True; end if; end if; end Delayed_Implicit_Process; @@ -3145,10 +3142,7 @@ package body Grt.Signals is null; when Imp_Forward => Sig := Propagation.Table (I).Sig; - if Sig.Link = null then - Sig.Link := Implicit_Signal_Active_Chain; - Implicit_Signal_Active_Chain := Sig; - end if; + Insert_Active_Chain (Sig); when Imp_Delayed => Sig := Propagation.Table (I).Sig; Trans := Sig.S.Attr_Trans.Next; @@ -3249,7 +3243,7 @@ package body Grt.Signals is if Sig.S.Time = 0 then -- Signal is active in the next cycle. If Time > 0, it -- has been put in Future_List during creation. - Insert_Update_Clear_Chain (Sig); + Sig.Flags.Implicit_Active_Next := True; end if; else -- LRM02 12.6.3 @@ -3388,13 +3382,17 @@ package body Grt.Signals is end; end if; - -- Extract and reset the chain of active signals. - Sig := Signal_Active_Chain; - Signal_Active_Chain := Signal_End; - - -- For each active signals. - while Sig.S.Mode_Sig /= Mode_End loop + -- For each active signal. + loop + -- Extract an active signal. + Sig := Signal_Active_Chain; Next_Sig := Sig.Link; + + -- Leave Signal_End. + exit when Next_Sig = null; + + -- (Remove it from the chain). + Signal_Active_Chain := Next_Sig; Sig.Link := null; case Sig.Net is @@ -3460,21 +3458,7 @@ package body Grt.Signals is Sig := Next_Sig; end loop; - -- Implicit signals (forwarded). - -- The list may not be initially empty: signals were appended (by - -- forwarder) during propagation just above (because a signal is - -- active), and signals may have been appended during the previous - -- cycle (because a signal is not anymore active). - loop - Sig := Implicit_Signal_Active_Chain; - exit when Sig.Link = null; - Implicit_Signal_Active_Chain := Sig.Link; - Sig.Link := null; - - Run_Propagation (Sig); - end loop; - - -- Un-mark updated. + -- Un-mark updated nets. Sig := Update_Clear_Chain; Update_Clear_Chain := Signal_End; while Sig.Link /= null loop @@ -3485,22 +3469,12 @@ package body Grt.Signals is -- Maybe put SIG in the active list, if it will be active during -- the next cycle. -- This can happen only for 'quiet, 'stable or 'delayed. - case Sig.S.Mode_Sig is - when Mode_Stable - | Mode_Quiet - | Mode_Delayed => - declare - Trans : Transaction_Acc; - begin - Trans := Sig.S.Attr_Trans.Next; - if Trans /= null and then Trans.Time = Current_Time then - Sig.Link := Implicit_Signal_Active_Chain; - Implicit_Signal_Active_Chain := Sig; - end if; - end; - when others => - null; - end case; + -- FIXME: not the case for 'Delayed. + if Sig.Flags.Implicit_Active_Next then + pragma Assert (Sig.S.Mode_Sig in Mode_Signal_Forward); + Sig.Flags.Implicit_Active_Next := False; + Insert_Active_Chain (Sig); + end if; Sig := Next_Sig; end loop; @@ -3658,7 +3632,6 @@ package body Grt.Signals is procedure Init is begin Signal_Active_Chain := Signal_End; - Implicit_Signal_Active_Chain := Signal_End; Future_List := Signal_End; Update_Clear_Chain := Signal_End; end Init; diff --git a/src/grt/grt-signals.ads b/src/grt/grt-signals.ads index 522521a37..faaede9b6 100644 --- a/src/grt/grt-signals.ads +++ b/src/grt/grt-signals.ads @@ -286,6 +286,11 @@ package Grt.Signals is -- Only reset by GHW file dumper. RO_Event : Boolean; + -- Set only on an implicit signal when the signal will stay active on + -- the next cycle. For example, 'Quiet(0ns) or 'Stable(0ns) are + -- generally active for 2 cycles, as they are first False and then True. + Implicit_Active_Next : Boolean; + -- Set if the signal has already been visited. When outside of the -- algorithm that use it, it must be cleared. Seen : Boolean; @@ -395,6 +400,8 @@ package Grt.Signals is Eff_Actual, -- Sig must be updated but does not belong to the same net. + -- Forward is needed because an implicit signal may be active or not + -- if one of its source is. Imp_Forward, Imp_Forward_Build, |