diff options
author | Tristan Gingold <tgingold@free.fr> | 2023-02-08 11:58:11 +0100 |
---|---|---|
committer | Tristan Gingold <tgingold@free.fr> | 2023-02-08 16:04:35 +0100 |
commit | 9dd6b779c2431ad1be462b19474ac351a3501a6d (patch) | |
tree | 80d6acf7eb042ca5ede1e89292fcba879ed6f02a | |
parent | a465d8c37ea9edda5528bf9f9f160826552eac36 (diff) | |
download | ghdl-9dd6b779c2431ad1be462b19474ac351a3501a6d.tar.gz ghdl-9dd6b779c2431ad1be462b19474ac351a3501a6d.tar.bz2 ghdl-9dd6b779c2431ad1be462b19474ac351a3501a6d.zip |
simul: handle signal assignment to procedure individual associations
-rw-r--r-- | src/simul/simul-vhdl_simul.adb | 27 |
1 files changed, 19 insertions, 8 deletions
diff --git a/src/simul/simul-vhdl_simul.adb b/src/simul/simul-vhdl_simul.adb index 5626813a2..d93d13869 100644 --- a/src/simul/simul-vhdl_simul.adb +++ b/src/simul/simul-vhdl_simul.adb @@ -997,6 +997,22 @@ package body Simul.Vhdl_Simul is procedure Execute_Aggregate_Signal_Assignment is new Assign_Aggregate (Execute_Signal_Assignment); + function Value_To_Sig (Val : Value_Acc) return Memory_Ptr is + begin + case Val.Kind is + when Value_Signal => + declare + E : Signal_Entry renames Signals_Table.Table (Val.S); + begin + return E.Sig; + end; + when Value_Sig_Val => + return Val.I_Sigs; + when others => + raise Internal_Error; + end case; + end Value_To_Sig; + procedure Execute_Signal_Assignment (Inst : Synth_Instance_Acc; Target : Target_Info; Val : Valtyp; @@ -1011,14 +1027,9 @@ package body Simul.Vhdl_Simul is (Inst, Target.Aggr, Target.Targ_Type, Val, Loc); when Target_Simple => - declare - E : Signal_Entry renames - Signals_Table.Table (Target.Obj.Val.S); - begin - Sig := (Target.Targ_Type, - Sig_Index (E.Sig, Target.Off.Net_Off)); - end; - + Sig := (Target.Targ_Type, + Sig_Index (Value_To_Sig (Target.Obj.Val), + Target.Off.Net_Off)); if Val /= No_Valtyp then Mem := Get_Value_Memtyp (Val); else |