aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTristan Gingold <tgingold@free.fr>2021-11-28 12:01:33 +0100
committerTristan Gingold <tgingold@free.fr>2021-11-28 12:13:25 +0100
commit71f1686047bf4e05988396d4051ec4871d19ebc2 (patch)
treede61820b7e970b3f38a0a41309a2cc29d1de7fab
parentd4c36d398f9ca32e5fad23298bcef1ed9473e7f9 (diff)
downloadghdl-71f1686047bf4e05988396d4051ec4871d19ebc2.tar.gz
ghdl-71f1686047bf4e05988396d4051ec4871d19ebc2.tar.bz2
ghdl-71f1686047bf4e05988396d4051ec4871d19ebc2.zip
synth-vhdl_insts.adb: split synth_Instantiate_Module
-rw-r--r--src/synth/synth-vhdl_insts.adb40
1 files changed, 26 insertions, 14 deletions
diff --git a/src/synth/synth-vhdl_insts.adb b/src/synth/synth-vhdl_insts.adb
index 7545dc9d1..dfb42b532 100644
--- a/src/synth/synth-vhdl_insts.adb
+++ b/src/synth/synth-vhdl_insts.adb
@@ -925,10 +925,11 @@ package body Synth.Vhdl_Insts is
-- Subprogram used for instantiation (direct or by component).
-- PORTS_ASSOC belong to SYN_INST.
- procedure Synth_Instantiate_Module (Syn_Inst : Synth_Instance_Acc;
- Inst : Instance;
- Inst_Obj : Inst_Object;
- Ports_Assoc : Node)
+ procedure Synth_Instantiate_Module_Ports (Syn_Inst : Synth_Instance_Acc;
+ Inst : Instance;
+ Ent_Inst : Synth_Instance_Acc;
+ Ent : Node;
+ Ports_Assoc : Node)
is
-- Instantiate the module
-- Elaborate ports + map aspect for the inputs (component then entity)
@@ -943,20 +944,19 @@ package body Synth.Vhdl_Insts is
N : Net;
begin
Assoc := Ports_Assoc;
- Assoc_Inter := Get_Port_Chain (Inst_Obj.Decl);
+ Assoc_Inter := Get_Port_Chain (Ent);
Nbr_Inputs := 0;
Nbr_Outputs := 0;
while Is_Valid (Assoc) loop
if Get_Whole_Association_Flag (Assoc) then
Inter := Get_Association_Interface (Assoc, Assoc_Inter);
- Inter_Typ := Get_Subtype_Object
- (Inst_Obj.Syn_Inst, Get_Type (Inter));
+ Inter_Typ := Get_Subtype_Object (Ent_Inst, Get_Type (Inter));
case Mode_To_Port_Kind (Get_Mode (Inter)) is
when Port_In =>
-- Connect the net to the input.
N := Synth_Input_Assoc
- (Syn_Inst, Assoc, Inst_Obj.Syn_Inst, Inter, Inter_Typ);
+ (Syn_Inst, Assoc, Ent_Inst, Inter, Inter_Typ);
Inst_Input_Connect
(Syn_Inst, Inst, Nbr_Inputs, Inter_Typ, N);
when Port_Out
@@ -964,12 +964,16 @@ package body Synth.Vhdl_Insts is
Inst_Output_Connect
(Syn_Inst, Inst, Nbr_Outputs, Inter_Typ, N);
Synth_Output_Assoc
- (N, Syn_Inst, Assoc, Inst_Obj.Syn_Inst, Inter);
+ (N, Syn_Inst, Assoc, Ent_Inst, Inter);
end case;
end if;
Next_Association_Interface (Assoc, Assoc_Inter);
end loop;
+ end Synth_Instantiate_Module_Ports;
+ procedure Synth_Instantiate_Module_Generics (Inst : Instance;
+ Inst_Obj : Inst_Object) is
+ begin
if Inst_Obj.Encoding = Name_Parameters then
-- Copy values of the generics to module parameters.
declare
@@ -992,7 +996,7 @@ package body Synth.Vhdl_Insts is
end loop;
end;
end if;
- end Synth_Instantiate_Module;
+ end Synth_Instantiate_Module_Generics;
procedure Synth_Direct_Instantiation_Statement
(Syn_Inst : Synth_Instance_Acc;
@@ -1035,8 +1039,10 @@ package body Synth.Vhdl_Insts is
Push_Phi;
- Synth_Instantiate_Module
- (Syn_Inst, Inst, Inst_Obj, Get_Port_Map_Aspect_Chain (Stmt));
+ Synth_Instantiate_Module_Ports
+ (Syn_Inst, Inst, Inst_Obj.Syn_Inst, Inst_Obj.Decl,
+ Get_Port_Map_Aspect_Chain (Stmt));
+ Synth_Instantiate_Module_Generics (Inst, Inst_Obj);
Pop_And_Merge_Phi (Get_Build (Syn_Inst), Get_Location (Stmt));
end Synth_Direct_Instantiation_Statement;
@@ -1167,6 +1173,10 @@ package body Synth.Vhdl_Insts is
Inst := New_Instance (Get_Instance_Module (Syn_Inst), M, Inst_Name);
Set_Location (Inst, Stmt);
+
+ Synth_Instantiate_Module_Ports
+ (Comp_Inst, Inst, Sub_Inst, Arch,
+ Get_Port_Map_Aspect_Chain (Bind));
else
Ent := Get_Entity (Arch);
@@ -1191,8 +1201,10 @@ package body Synth.Vhdl_Insts is
Inst_Obj.M, Inst_Name);
Set_Location (Inst, Stmt);
- Synth_Instantiate_Module
- (Comp_Inst, Inst, Inst_Obj, Get_Port_Map_Aspect_Chain (Bind));
+ Synth_Instantiate_Module_Ports
+ (Comp_Inst, Inst, Inst_Obj.Syn_Inst, Inst_Obj.Decl,
+ Get_Port_Map_Aspect_Chain (Bind));
+ Synth_Instantiate_Module_Generics (Inst, Inst_Obj);
end if;
pragma Unreferenced (M);