aboutsummaryrefslogtreecommitdiffstats
path: root/src/synth/synthesis.adb
diff options
context:
space:
mode:
Diffstat (limited to 'src/synth/synthesis.adb')
-rw-r--r--src/synth/synthesis.adb192
1 files changed, 1 insertions, 191 deletions
diff --git a/src/synth/synthesis.adb b/src/synth/synthesis.adb
index 222d8a0fe..d3aba58fc 100644
--- a/src/synth/synthesis.adb
+++ b/src/synth/synthesis.adb
@@ -18,22 +18,16 @@
-- Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
-- MA 02110-1301, USA.
-with Types; use Types;
with Name_Table; use Name_Table;
with Netlists.Builders; use Netlists.Builders;
-with Netlists.Utils;
with Vhdl.Utils; use Vhdl.Utils;
with Vhdl.Annotations; use Vhdl.Annotations;
-with Synth.Environment; use Synth.Environment;
with Synth.Values; use Synth.Values;
with Synth.Context; use Synth.Context;
-with Synth.Types; use Synth.Types;
with Synth.Decls; use Synth.Decls;
-with Synth.Stmts; use Synth.Stmts;
-with Synth.Expr; use Synth.Expr;
with Synth.Insts; use Synth.Insts;
with Synth.Environment.Debug;
@@ -43,189 +37,6 @@ with Errorout; use Errorout;
with Vhdl.Errors; use Vhdl.Errors;
package body Synthesis is
- procedure Make_Port_Desc (Val : Value_Acc;
- Name : Sname;
- Wd : Width;
- Ports : in out Port_Desc_Array;
- Idx : in out Port_Nbr;
- Dir : Port_Kind)
- is
- begin
- case Val.Kind is
- when Value_Wire =>
- Idx := Idx + 1;
- Ports (Idx) := (Name => Name,
- W => Wd,
- Dir => Dir,
- Left | Right => 0);
- when others =>
- raise Internal_Error; -- TODO
- end case;
- end Make_Port_Desc;
-
- procedure Make_Port_Desc (Syn_Inst : Synth_Instance_Acc;
- Inter : Node;
- Ports : in out Port_Desc_Array;
- Idx : in out Port_Nbr;
- Dir : Port_Kind)
- is
- Val : constant Value_Acc := Get_Value (Syn_Inst, Inter);
- Wd : constant Width := Get_Width (Syn_Inst, Get_Type (Inter));
- Name : Sname;
- begin
- Name := New_Sname_User (Get_Identifier (Inter));
- Make_Port_Desc (Val, Name, Wd, Ports, Idx, Dir);
- end Make_Port_Desc;
-
- procedure Create_Input_Wire
- (Self_Inst : Instance; Idx : in out Port_Idx; Val : Value_Acc) is
- begin
- case Val.Kind is
- when Value_Wire =>
- Wire_Id_Table.Table (Val.W).Gate := Get_Output (Self_Inst, Idx);
- Idx := Idx + 1;
- when others =>
- raise Internal_Error;
- end case;
- end Create_Input_Wire;
-
- procedure Create_Output_Wire
- (Self_Inst : Instance; Idx : in out Port_Idx; Val : Value_Acc)
- is
- Value : Net;
- Inp : Input;
- W : Width;
- begin
- case Val.Kind is
- when Value_Wire =>
- -- Create a gate for the output, so that it could be read.
- W := Get_Output_Desc (Get_Module (Self_Inst), Idx).W;
- Value := Build_Output (Build_Context, W);
- Inp := Get_Input (Self_Inst, Idx);
- Connect (Inp, Value);
- Wire_Id_Table.Table (Val.W).Gate := Value;
- Idx := Idx + 1;
- when others =>
- raise Internal_Error;
- end case;
- end Create_Output_Wire;
-
- function Synth_Entity
- (Parent_Module : Module; Parent_Inst : Synth_Instance_Acc; Arch : Node)
- return Synth_Instance_Acc
- is
- Entity : constant Node := Get_Entity (Arch);
- Syn_Inst : Synth_Instance_Acc;
- Self_Inst : Instance;
- Inter : Node;
- Nbr_Inputs : Port_Nbr;
- Nbr_Outputs : Port_Nbr;
- Num : Uns32;
- begin
- Syn_Inst := Make_Instance (Parent_Inst, Get_Info (Arch));
- Syn_Inst.Block_Scope := Get_Info (Entity);
- Syn_Inst.Name := New_Sname_User (Get_Identifier (Entity));
-
- -- Compute generics.
- Inter := Get_Generic_Chain (Entity);
- while Is_Valid (Inter) loop
- Synth_Declaration_Type (Syn_Inst, Inter);
- declare
- Val : Value_Acc;
- begin
- Val := Synth_Expression_With_Type
- (Syn_Inst, Get_Default_Value (Inter), Get_Type (Inter));
- Create_Object (Syn_Inst, Inter, Val);
- end;
- Inter := Get_Chain (Inter);
- end loop;
-
- -- Allocate values and count inputs and outputs
- Inter := Get_Port_Chain (Entity);
- Nbr_Inputs := 0;
- Nbr_Outputs := 0;
- while Is_Valid (Inter) loop
- Synth_Declaration_Type (Syn_Inst, Inter);
- case Mode_To_Port_Kind (Get_Mode (Inter)) is
- when Port_In =>
- Make_Object (Syn_Inst, Wire_Input, Inter);
- Num := Get_Nbr_Wire (Get_Value (Syn_Inst, Inter));
- Nbr_Inputs := Nbr_Inputs + Port_Nbr (Num);
- when Port_Out
- | Port_Inout =>
- Make_Object (Syn_Inst, Wire_Output, Inter);
- Num := Get_Nbr_Wire (Get_Value (Syn_Inst, Inter));
- Nbr_Outputs := Nbr_Outputs + Port_Nbr (Num);
- end case;
- Inter := Get_Chain (Inter);
- end loop;
-
- -- Declare module.
- Syn_Inst.M := New_User_Module
- (Parent_Module, New_Sname_User (Get_Identifier (Entity)),
- Id_User_None, Nbr_Inputs, Nbr_Outputs, 0);
-
- -- Add ports to module.
- declare
- Inports : Port_Desc_Array (1 .. Nbr_Inputs);
- Outports : Port_Desc_Array (1 .. Nbr_Outputs);
- begin
- Inter := Get_Port_Chain (Entity);
- Nbr_Inputs := 0;
- Nbr_Outputs := 0;
- while Is_Valid (Inter) loop
- case Mode_To_Port_Kind (Get_Mode (Inter)) is
- when Port_In =>
- Make_Port_Desc
- (Syn_Inst, Inter, Inports, Nbr_Inputs, Port_In);
- when Port_Out
- | Port_Inout =>
- Make_Port_Desc
- (Syn_Inst, Inter, Outports, Nbr_Outputs, Port_Out);
- end case;
- Inter := Get_Chain (Inter);
- end loop;
- pragma Assert (Nbr_Inputs = Inports'Last);
- pragma Assert (Nbr_Outputs = Outports'Last);
- Set_Port_Desc (Syn_Inst.M, Inports, Outports);
- end;
-
- Self_Inst := Create_Self_Instance (Syn_Inst.M);
- Set_Parent (Build_Context, Syn_Inst.M);
-
- -- Create wires for inputs and outputs.
- Inter := Get_Port_Chain (Entity);
- Nbr_Inputs := 0;
- Nbr_Outputs := 0;
- while Is_Valid (Inter) loop
- case Mode_To_Port_Kind (Get_Mode (Inter)) is
- when Port_In =>
- Create_Input_Wire
- (Self_Inst, Nbr_Inputs, Get_Value (Syn_Inst, Inter));
- when Port_Out
- | Port_Inout =>
- Create_Output_Wire
- (Self_Inst, Nbr_Outputs, Get_Value (Syn_Inst, Inter));
- end case;
- Inter := Get_Chain (Inter);
- end loop;
-
- Synth_Declarations (Syn_Inst, Get_Declaration_Chain (Entity));
- Synth_Concurrent_Statements
- (Syn_Inst, Get_Concurrent_Statement_Chain (Entity));
-
- Synth_Declarations (Syn_Inst, Get_Declaration_Chain (Arch));
- Synth_Concurrent_Statements
- (Syn_Inst, Get_Concurrent_Statement_Chain (Arch));
-
- -- Remove unused gates. This is not only an optimization but also
- -- a correctness point: there might be some unsynthesizable gates, like
- -- the one created for 'rising_egde (clk) and not rst'.
- Netlists.Utils.Remove_Unused_Instances (Syn_Inst.M);
-
- return Syn_Inst;
- end Synth_Entity;
-
procedure Synth_Dependencies (Parent_Inst : Synth_Instance_Acc; Unit : Node)
is
Dep_List : constant Node_List := Get_Dependence_List (Unit);
@@ -308,8 +119,7 @@ package body Synthesis is
Synth_Dependencies
(Global_Instance, Get_Design_Unit (Arch));
- Syn_Inst := Synth_Entity (Global_Module, Global_Instance, Arch);
-
+ Synth_Top_Entity (Arch);
Synth_All_Instances;
if Errorout.Nbr_Errors > 0 then
raise Compilation_Error;