mirror of
https://github.com/YosysHQ/yosys
synced 2025-04-06 01:24:10 +00:00
If width of a case expression was large, explicit patterns could cause the existing logic to take an extremely long time, or exhaust the maximum size of the underlying set. For cases where all of the patterns are fully defined and there are no constants in the case expression, this change uses a simple set to track which patterns have been seen.
47 lines
948 B
Verilog
47 lines
948 B
Verilog
module top (
|
|
input wire signed x,
|
|
output reg [31:0] y
|
|
);
|
|
wire signed fail = ~x;
|
|
|
|
always @*
|
|
case (x)
|
|
1'b0: y = 0;
|
|
1'b1: y = 1;
|
|
default: y = fail;
|
|
endcase
|
|
|
|
always @*
|
|
case (x)
|
|
2'sb00: y = 0;
|
|
2'sb00: y = fail;
|
|
endcase
|
|
|
|
always @*
|
|
case (x)
|
|
2'sb00: y = 0;
|
|
default: y = fail;
|
|
2'sb01: y = 1;
|
|
2'sb10: y = 2;
|
|
2'sb11: y = 3;
|
|
2'sb00: y = fail;
|
|
2'sb01: y = fail;
|
|
2'sb10: y = fail;
|
|
2'sb11: y = fail;
|
|
endcase
|
|
|
|
|
|
always @*
|
|
case ({x, x})
|
|
2'b00: y = 0;
|
|
2'b01: y = 1;
|
|
2'b10: y = 2;
|
|
2'b11: y = 3;
|
|
default: y = fail;
|
|
2'b00: y = fail;
|
|
2'b01: y = fail;
|
|
2'b10: y = fail;
|
|
2'b11: y = fail;
|
|
endcase
|
|
endmodule
|