aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorTristan Gingold <tgingold@free.fr>2023-04-18 21:15:10 +0200
committerTristan Gingold <tgingold@free.fr>2023-04-18 21:15:10 +0200
commit6544b839fe6dceb56cb544bc4f69f0ab28100172 (patch)
treec03fc8975f5d4ff750de3d1f513f02092d54fc3f /src
parentaaeeda7eb30b827c7fb690550d85ab6a915ef7f8 (diff)
downloadghdl-6544b839fe6dceb56cb544bc4f69f0ab28100172.tar.gz
ghdl-6544b839fe6dceb56cb544bc4f69f0ab28100172.tar.bz2
ghdl-6544b839fe6dceb56cb544bc4f69f0ab28100172.zip
synth: very early support of external names
Diffstat (limited to 'src')
-rw-r--r--src/synth/synth-vhdl_decls.adb10
-rw-r--r--src/synth/synth-vhdl_expr.adb115
2 files changed, 120 insertions, 5 deletions
diff --git a/src/synth/synth-vhdl_decls.adb b/src/synth/synth-vhdl_decls.adb
index 90c5de474..f1e42c97b 100644
--- a/src/synth/synth-vhdl_decls.adb
+++ b/src/synth/synth-vhdl_decls.adb
@@ -844,6 +844,14 @@ package body Synth.Vhdl_Decls is
Finalize_Assignment (Get_Build (Syn_Inst), W);
Gate_Net := Get_Wire_Gate (W);
+
+ Free_Wire (W);
+
+ -- Replace the wire with a net so that external names can refer to it.
+ Mutate_Object
+ (Syn_Inst, Decl,
+ (Vt.Typ, Create_Value_Net (Gate_Net, Process_Pool'Access)));
+
Gate := Get_Net_Parent (Gate_Net);
case Get_Id (Gate) is
when Id_Signal
@@ -883,8 +891,6 @@ package body Synth.Vhdl_Decls is
-- The value of an undriven signal is its initial value.
Connect (Get_Input (Gate, 0), Def_Val);
end if;
-
- Free_Wire (W);
end Finalize_Signal;
procedure Finalize_Declaration
diff --git a/src/synth/synth-vhdl_expr.adb b/src/synth/synth-vhdl_expr.adb
index b5093cb02..c73b2133e 100644
--- a/src/synth/synth-vhdl_expr.adb
+++ b/src/synth/synth-vhdl_expr.adb
@@ -41,6 +41,7 @@ with Elab.Vhdl_Annotations;
with Elab.Vhdl_Heap; use Elab.Vhdl_Heap;
with Elab.Vhdl_Types; use Elab.Vhdl_Types;
with Elab.Vhdl_Expr;
+with Elab.Vhdl_Insts;
with Synth.Errors; use Synth.Errors;
with Synth.Vhdl_Environment;
@@ -830,6 +831,114 @@ package body Synth.Vhdl_Expr is
end case;
end Synth_Subtype_Conversion;
+ function Synth_Pathname (Loc_Inst : Synth_Instance_Acc;
+ Name : Node;
+ Cur_Inst : Synth_Instance_Acc;
+ Path : Node) return Valtyp
+ is
+ Suffix : constant Node := Get_Pathname_Suffix (Path);
+ Id : constant Name_Id := Get_Identifier (Path);
+ Scope : constant Node := Get_Source_Scope (Cur_Inst);
+ Res : Node;
+ begin
+ if Suffix = Null_Node then
+ -- Object simple name.
+ case Get_Kind (Scope) is
+ when Iir_Kind_Architecture_Body =>
+ Res := Find_Name_In_Chain (Get_Declaration_Chain (Scope), Id);
+ when others =>
+ Error_Kind ("synth_pathname(obj)", Scope);
+ end case;
+ if Res = Null_Node then
+ Error_Msg_Synth
+ (Loc_Inst, Path, "cannot find object %i in %i", (+Id, +Scope));
+ return No_Valtyp;
+ end if;
+ case Get_Kind (Res) is
+ when Iir_Kind_Signal_Declaration =>
+ case Iir_Kinds_External_Name (Get_Kind (Name)) is
+ when Iir_Kind_External_Signal_Name =>
+ return Get_Value (Cur_Inst, Res);
+ when Iir_Kind_External_Constant_Name
+ | Iir_Kind_External_Variable_Name =>
+ Error_Msg_Synth
+ (Loc_Inst, Path, "object name %i is a signal", +Res);
+ return No_Valtyp;
+ end case;
+ when others =>
+ Error_Kind ("synth_pathname(1)", Res);
+ end case;
+ else
+ -- Find name in concurrent statements.
+ case Get_Kind (Scope) is
+ when Iir_Kind_Architecture_Body =>
+ Res := Find_Name_In_Chain
+ (Get_Concurrent_Statement_Chain (Scope), Id);
+ when others =>
+ Error_Kind ("synth_pathname(scope)", Scope);
+ end case;
+ if Res = Null_Node then
+ Error_Msg_Synth
+ (Loc_Inst, Path,
+ "cannot find path element %i in %i", (+Id, +Scope));
+ return No_Valtyp;
+ end if;
+ case Get_Kind (Res) is
+ when Iir_Kind_Component_Instantiation_Statement =>
+ if Is_Entity_Instantiation (Res) then
+ return Synth_Pathname
+ (Loc_Inst, Name, Get_Sub_Instance (Cur_Inst, Res), Suffix);
+ else
+ -- TODO: skip component.
+ raise Internal_Error;
+ end if;
+ when others =>
+ Error_Kind ("synth_pathname(2)", Res);
+ end case;
+ end if;
+ end Synth_Pathname;
+
+ function Synth_Absolute_Pathname
+ (Syn_Inst : Synth_Instance_Acc; Name : Node; Path : Node) return Valtyp
+ is
+ Path_Inst : constant Synth_Instance_Acc := Elab.Vhdl_Insts.Top_Instance;
+ Top_Arch : constant Node := Get_Source_Scope (Path_Inst);
+ Top_Ent : constant Node := Get_Entity (Top_Arch);
+ Suffix : constant Node := Get_Pathname_Suffix (Path);
+ begin
+ if Get_Identifier (Top_Ent) /= Get_Identifier (Suffix) then
+ Error_Msg_Synth
+ (Syn_Inst, Path,
+ "root %i of absolute pathname is not the top entity %i",
+ (+Top_Ent, +Suffix));
+ return No_Valtyp;
+ end if;
+
+ return Synth_Pathname
+ (Syn_Inst, Name, Path_Inst, Get_Pathname_Suffix (Suffix));
+ end Synth_Absolute_Pathname;
+
+ function Synth_External_Name (Syn_Inst : Synth_Instance_Acc; Name : Node)
+ return Valtyp
+ is
+ Path : Node;
+ Res : Valtyp;
+ begin
+ Path := Get_External_Pathname (Name);
+ case Get_Kind (Path) is
+ when Iir_Kind_Absolute_Pathname =>
+ Res := Synth_Absolute_Pathname (Syn_Inst, Name, Path);
+ when others =>
+ Error_Kind ("synth_external_name", Path);
+ end case;
+ if Res = No_Valtyp then
+ return No_Valtyp;
+ end if;
+
+ -- TODO: type.
+ return Res;
+ end Synth_External_Name;
+
function Synth_Name (Syn_Inst : Synth_Instance_Acc; Name : Node)
return Valtyp is
begin
@@ -854,6 +963,8 @@ package body Synth.Vhdl_Expr is
| Iir_Kind_File_Declaration
| Iir_Kind_Interface_File_Declaration =>
return Get_Value (Syn_Inst, Name);
+ when Iir_Kind_External_Signal_Name =>
+ return Synth_External_Name (Syn_Inst, Name);
when Iir_Kind_Attribute_Value =>
-- It's a little bit complex for attribute of an entity or
-- of an architecture as there might be no instances for them.
@@ -2041,7 +2152,6 @@ package body Synth.Vhdl_Expr is
Set_Location (Res, Call);
return Create_Value_Net (Res, Boolean_Type);
-
end Synth_Psl_Stable;
function Synth_Psl_Rose (Syn_Inst : Synth_Instance_Acc; Call : Node)
@@ -2072,7 +2182,6 @@ package body Synth.Vhdl_Expr is
Set_Location (Res, Call);
return Create_Value_Net (Res, Boolean_Type);
-
end Synth_Psl_Rose;
function Synth_Psl_Fell (Syn_Inst : Synth_Instance_Acc; Call : Node)
@@ -2102,7 +2211,6 @@ package body Synth.Vhdl_Expr is
Set_Location (Res, Call);
return Create_Value_Net (Res, Boolean_Type);
-
end Synth_Psl_Fell;
function Synth_Onehot0 (Ctxt : Context_Acc; DffCurr : Net; Call : Node;
@@ -2358,6 +2466,7 @@ package body Synth.Vhdl_Expr is
| Iir_Kind_Guard_Signal_Declaration
| Iir_Kind_Object_Alias_Declaration -- For PSL
| Iir_Kind_Non_Object_Alias_Declaration -- For PSL
+ | Iir_Kind_External_Signal_Name
| Iir_Kind_Implicit_Dereference
| Iir_Kind_Dereference =>
declare