Skip to content

Commit 2f044c3

Browse files
committed
Verilog: KNOWNBUG test for case expression and case item expression type checking
1 parent 5f8de8c commit 2f044c3

File tree

2 files changed

+40
-0
lines changed

2 files changed

+40
-0
lines changed

regression/verilog/case/case5.desc

Lines changed: 10 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,10 @@
1+
KNOWNBUG
2+
case5.sv
3+
--module main --bound 0
4+
^EXIT=0$
5+
^SIGNAL=0$
6+
--
7+
^warning: ignoring
8+
--
9+
This gives the wrong result.
10+

regression/verilog/case/case5.sv

Lines changed: 30 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,30 @@
1+
module main;
2+
3+
reg [31:0] resultA, resultB;
4+
5+
// All case expressions are extended to the longest case
6+
// or case item expression.
7+
8+
initial begin
9+
resultA = 10;
10+
11+
case(1'b1 << 8)
12+
0: resultA = 0; // 32 bits!
13+
1'b1: resultA = 1;
14+
endcase
15+
16+
assert(resultA == 10);
17+
end
18+
19+
initial begin
20+
resultB = 10;
21+
22+
case(1'b1 << 8)
23+
1'b0: resultB = 0; // just 1 bit!
24+
1'b1: resultB = 1;
25+
endcase
26+
27+
assert(resultB == 0);
28+
end
29+
30+
endmodule

0 commit comments

Comments
 (0)