diff options
| author | Tristan Gingold <tgingold@free.fr> | 2021-05-07 20:46:14 +0200 | 
|---|---|---|
| committer | Tristan Gingold <tgingold@free.fr> | 2021-05-07 20:46:14 +0200 | 
| commit | 82665d421e193998b576ea5b3cb992bf84596850 (patch) | |
| tree | 0b6cf5118f1cbb02deaafae7b10c6e8aa4806b10 /src | |
| parent | 9ae58374ecc8960bb0c2cf2320474f9a115c48eb (diff) | |
| download | ghdl-82665d421e193998b576ea5b3cb992bf84596850.tar.gz ghdl-82665d421e193998b576ea5b3cb992bf84596850.tar.bz2 ghdl-82665d421e193998b576ea5b3cb992bf84596850.zip | |
netlists-disp_verilog: fix display of constants
Diffstat (limited to 'src')
| -rw-r--r-- | src/synth/netlists-disp_verilog.adb | 30 | 
1 files changed, 20 insertions, 10 deletions
| diff --git a/src/synth/netlists-disp_verilog.adb b/src/synth/netlists-disp_verilog.adb index 287f82bef..c0c6f0c0a 100644 --- a/src/synth/netlists-disp_verilog.adb +++ b/src/synth/netlists-disp_verilog.adb @@ -1088,8 +1088,6 @@ package body Netlists.Disp_Verilog is     is        Id : Module_Id;     begin -      --  Display signal declarations. -      --  There are as many signals as gate outputs.        for Inst of Instances (M) loop           Id := Get_Id (Inst);           case Id is @@ -1116,15 +1114,19 @@ package body Netlists.Disp_Verilog is                    Put_Line ("; // mem_rd");                 end;              when others => -               if not Is_Self_Instance (Inst) -                 and then not (Flag_Merge_Lit -                                 and then Id in Constant_Module_Id -                                 and then Id < Id_User_None -                                 and then not Need_Signal (Inst)) -                 and then not (Flag_Merge_Edge -                                 and then Id in Edge_Module_Id -                                 and then not Need_Edge (Inst)) +               if Is_Self_Instance (Inst) +                 or else (Flag_Merge_Lit +                            and then Id in Constant_Module_Id +                            and then Id < Id_User_None +                            and then not Need_Signal (Inst)) +                 or else (Flag_Merge_Edge +                            and then Id in Edge_Module_Id +                            and then not Need_Edge (Inst))                 then +                  --  Not displayed. +                  null; +               else +                  --  Check location is present.                    if Locations.Get_Location (Inst) = No_Location then                       case Id is                          when Id_Const_UB32 @@ -1145,6 +1147,8 @@ package body Netlists.Disp_Verilog is                             raise Internal_Error;                       end case;                    end if; + +                  --  Display reg/wire for each output.                    for N of Outputs (Inst) loop                       case Id is                          when Id_Dff @@ -1159,11 +1163,17 @@ package body Netlists.Disp_Verilog is                             | Id_Dyn_Insert_En =>                             --  Implemented by a process                             Put ("  reg "); +                        when Constant_Module_Id => +                           Put ("  localparam ");                          when others =>                             Put ("  wire ");                       end case;                       Put_Type (Get_Width (N));                       Disp_Net_Name (N); +                     if Id in Constant_Module_Id then +                        Put (" = "); +                        Disp_Constant_Inline (Inst); +                     end if;                       Put_Line (";");                    end loop;                 end if; | 
