Add error on zero width select (#5028).

This commit is contained in:
Wilson Snyder 2024-04-30 18:38:37 -04:00
parent 0da7ecf753
commit 71bc60fb91
7 changed files with 80 additions and 8 deletions

View File

@ -17,6 +17,7 @@ Verilator 5.025 devel
* Support empty queue as dynarray default value (#5055). [Arkadiusz Kozdra, Antmicro Ltd.] * Support empty queue as dynarray default value (#5055). [Arkadiusz Kozdra, Antmicro Ltd.]
* Add CITATION.cff (#5057) (#5058). [Gijs Burghoorn] * Add CITATION.cff (#5057) (#5058). [Gijs Burghoorn]
* Add VPI eval needed tracking (#5065). [Todd Strader] * Add VPI eval needed tracking (#5065). [Todd Strader]
* Add error on zero width select (#5028).
* Fix missing flex include path variable (#4970) (#4971). [Christopher Taylor] * Fix missing flex include path variable (#4970) (#4971). [Christopher Taylor]
* Fix missing parameters with comma to be errors (#4979) (#5012). [Paul Swirhun] * Fix missing parameters with comma to be errors (#4979) (#5012). [Paul Swirhun]
* Fix bound queue printing (#5032). [Aleksander Kiryk, Antmicro Ltd.] * Fix bound queue printing (#5032). [Aleksander Kiryk, Antmicro Ltd.]

View File

@ -913,6 +913,11 @@ class WidthVisitor final : public VNVisitor {
return; return;
} }
int width = nodep->widthConst(); int width = nodep->widthConst();
if (width <= 0) {
nodep->v3error("Width of bit extract must be positive (IEEE 1800-2023 11.5.1)");
nodep->dtypeSetBit();
return;
}
UASSERT_OBJ(nodep->dtypep(), nodep, "dtype wasn't set"); // by V3WidthSel UASSERT_OBJ(nodep->dtypep(), nodep, "dtype wasn't set"); // by V3WidthSel
if (VN_IS(nodep->lsbp(), Const) && nodep->msbConst() < nodep->lsbConst()) { if (VN_IS(nodep->lsbp(), Const) && nodep->msbConst() < nodep->lsbConst()) {
nodep->v3warn(E_UNSUPPORTED, "Unsupported: left < right of bit extract: " nodep->v3warn(E_UNSUPPORTED, "Unsupported: left < right of bit extract: "

View File

@ -1,7 +1,11 @@
%Warning-SELRANGE: t/t_bigmem_bad.v:14:19: Selection index out of range: (nodep->declElWidth() == 0) -1:0 outside 268435455:0 %Error: t/t_bigmem_bad.v:14:19: Width of bit extract must be positive (IEEE 1800-2023 11.5.1)
: ... note: In instance 't_bigmem' : ... note: In instance 't_bigmem'
14 | if (wen) mem[addr] <= data; 14 | if (wen) mem[addr] <= data;
| ^ | ^
... For warning description see https://verilator.org/warn/SELRANGE?v=latest %Warning-WIDTHTRUNC: t/t_bigmem_bad.v:14:26: Operator ASSIGNDLY expects 1 bits on the Assign RHS, but Assign RHS's VARREF 'data' generates 256 bits.
... Use "/* verilator lint_off SELRANGE */" and lint_on around source to disable this message. : ... note: In instance 't_bigmem'
14 | if (wen) mem[addr] <= data;
| ^~
... For warning description see https://verilator.org/warn/WIDTHTRUNC?v=latest
... Use "/* verilator lint_off WIDTHTRUNC */" and lint_on around source to disable this message.
%Error: Exiting due to %Error: Exiting due to

View File

@ -6,15 +6,15 @@
: ... note: In instance 't' : ... note: In instance 't'
20 | sel2 = mi[44 +: -1]; 20 | sel2 = mi[44 +: -1];
| ^ | ^
%Error-UNSUPPORTED: t/t_select_bad_range4.v:20:16: Unsupported: left < right of bit extract: 2<4 %Error: t/t_select_bad_range4.v:20:16: Width of bit extract must be positive (IEEE 1800-2023 11.5.1)
: ... note: In instance 't' : ... note: In instance 't'
20 | sel2 = mi[44 +: -1]; 20 | sel2 = mi[44 +: -1];
| ^ | ^
... For error description see https://verilator.org/warn/UNSUPPORTED?v=latest %Warning-WIDTHEXPAND: t/t_select_bad_range4.v:20:12: Operator ASSIGN expects 4 bits on the Assign RHS, but Assign RHS's SEL generates 1 bits.
%Warning-WIDTHEXPAND: t/t_select_bad_range4.v:20:12: Operator ASSIGN expects 4 bits on the Assign RHS, but Assign RHS's SEL generates 3 bits.
: ... note: In instance 't' : ... note: In instance 't'
20 | sel2 = mi[44 +: -1]; 20 | sel2 = mi[44 +: -1];
| ^ | ^
... For warning description see https://verilator.org/warn/WIDTHEXPAND?v=latest
... Use "/* verilator lint_off WIDTHEXPAND */" and lint_on around source to disable this message. ... Use "/* verilator lint_off WIDTHEXPAND */" and lint_on around source to disable this message.
%Error: t/t_select_bad_range4.v:21:16: Width of :+ or :- is huge; vector of over 1 billion bits: 32'h20000000 %Error: t/t_select_bad_range4.v:21:16: Width of :+ or :- is huge; vector of over 1 billion bits: 32'h20000000
: ... note: In instance 't' : ... note: In instance 't'

View File

@ -0,0 +1,19 @@
%Error: t/t_select_bad_width0.v:15:21: Width of bit extract must be positive (IEEE 1800-2023 11.5.1)
: ... note: In instance 't'
15 | int part = val[left +: ZERO];
| ^
%Warning-WIDTHEXPAND: t/t_select_bad_width0.v:15:21: Operator ASSIGN expects 32 bits on the Assign RHS, but Assign RHS's SEL generates 1 bits.
: ... note: In instance 't'
15 | int part = val[left +: ZERO];
| ^
... For warning description see https://verilator.org/warn/WIDTHEXPAND?v=latest
... Use "/* verilator lint_off WIDTHEXPAND */" and lint_on around source to disable this message.
%Error: t/t_select_bad_width0.v:17:17: Width of bit extract must be positive (IEEE 1800-2023 11.5.1)
: ... note: In instance 't'
17 | part = val[left -: ZERO];
| ^
%Warning-WIDTHEXPAND: t/t_select_bad_width0.v:17:12: Operator ASSIGN expects 32 bits on the Assign RHS, but Assign RHS's SEL generates 1 bits.
: ... note: In instance 't'
17 | part = val[left -: ZERO];
| ^
%Error: Exiting due to

View File

@ -0,0 +1,19 @@
#!/usr/bin/env perl
if (!$::Driver) { use FindBin; exec("$FindBin::Bin/bootstrap.pl", @ARGV, $0); die; }
# DESCRIPTION: Verilator: Verilog Test driver/expect definition
#
# Copyright 2003 by Wilson Snyder. This program is free software; you
# can redistribute it and/or modify it under the terms of either the GNU
# Lesser General Public License Version 3 or the Perl Artistic License
# Version 2.0.
# SPDX-License-Identifier: LGPL-3.0-only OR Artistic-2.0
scenarios(linter => 1);
lint(
fails => $Self->{vlt_all},
expect_filename => $Self->{golden_filename},
);
ok(1);
1;

View File

@ -0,0 +1,24 @@
// DESCRIPTION: Verilator: Verilog Test module
//
// This file ONLY is placed under the Creative Commons Public Domain, for
// any use, without warranty, 2024 by Wilson Snyder.
// SPDX-License-Identifier: CC0-1.0
module t(/*AUTOARG*/);
parameter int ZERO = 0;
initial begin
bit [31:0] val = '1;
int left = 4;
int part = val[left +: ZERO];
$display(part);
part = val[left -: ZERO];
$display(part);
$write("*-* All Finished *-*\n");
$finish;
end
endmodule