diff options
author | Tristan Gingold <tgingold@free.fr> | 2022-06-27 07:49:31 +0200 |
---|---|---|
committer | Tristan Gingold <tgingold@free.fr> | 2022-06-27 07:49:31 +0200 |
commit | 928588eca00ad47ce0eee614c4f655ed109bf964 (patch) | |
tree | 2c82c0bfa8cc08dd09acbf5d02aafada9024bf0a /src | |
parent | 622e5acfa3269e8001cbd01d3a1345ac199753c3 (diff) | |
download | ghdl-928588eca00ad47ce0eee614c4f655ed109bf964.tar.gz ghdl-928588eca00ad47ce0eee614c4f655ed109bf964.tar.bz2 ghdl-928588eca00ad47ce0eee614c4f655ed109bf964.zip |
netlists-disp_verilog: do not display ports of width 0. Fix #2109
Diffstat (limited to 'src')
-rw-r--r-- | src/synth/netlists-disp_verilog.adb | 24 |
1 files changed, 19 insertions, 5 deletions
diff --git a/src/synth/netlists-disp_verilog.adb b/src/synth/netlists-disp_verilog.adb index 848adc05b..8eb76d332 100644 --- a/src/synth/netlists-disp_verilog.adb +++ b/src/synth/netlists-disp_verilog.adb @@ -31,6 +31,10 @@ package body Netlists.Disp_Verilog is Flag_Merge_Lit : constant Boolean := True; Flag_Merge_Edge : constant Boolean := True; + -- Wires/regs/parameters of size 0 are not possible in verilog. + -- Do not display them. + Flag_Null_Wires : constant Boolean := False; + procedure Put_Type (W : Width) is begin if W > 1 then @@ -1145,6 +1149,8 @@ package body Netlists.Disp_Verilog is or else (Flag_Merge_Edge and then Id in Edge_Module_Id and then not Need_Edge (Inst)) + or else (not Flag_Null_Wires + or else Get_Width (Get_Output (Inst, 0)) = 0) then -- Not displayed. null; @@ -1212,14 +1218,18 @@ package body Netlists.Disp_Verilog is -- Output assignments. declare Idx : Port_Idx; + Desc : Port_Desc; begin Idx := 0; for I of Inputs (Self_Inst) loop - Put (" assign "); - Put_Name (Get_Output_Desc (M, Idx).Name); - Put (" = "); - Disp_Net_Name (Get_Driver (I)); - Put_Line (";"); + Desc := Get_Output_Desc (M, Idx); + if Desc.W /= 0 or Flag_Null_Wires then + Put (" assign "); + Put_Name (Desc.Name); + Put (" = "); + Disp_Net_Name (Get_Driver (I)); + Put_Line (";"); + end if; Idx := Idx + 1; end loop; end; @@ -1246,6 +1256,10 @@ package body Netlists.Disp_Verilog is is Attr : Attribute; begin + if not (Desc.W /= 0 or Flag_Null_Wires) then + return; + end if; + if First then Put (" ("); First := False; |