aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTristan Gingold <tgingold@free.fr>2023-02-08 11:58:11 +0100
committerTristan Gingold <tgingold@free.fr>2023-02-08 16:04:35 +0100
commit9dd6b779c2431ad1be462b19474ac351a3501a6d (patch)
tree80d6acf7eb042ca5ede1e89292fcba879ed6f02a
parenta465d8c37ea9edda5528bf9f9f160826552eac36 (diff)
downloadghdl-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.adb27
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