3
0
Fork 0
mirror of https://github.com/YosysHQ/yosys synced 2025-04-23 00:55:32 +00:00

Merge pull request #3674 from YosysHQ/fix_wide_case

This commit is contained in:
N. Engelhardt 2023-02-27 16:04:11 +01:00 committed by GitHub
commit 842cdad575
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
8 changed files with 121 additions and 12 deletions

3
tests/verific/.gitignore vendored Normal file
View file

@ -0,0 +1,3 @@
/*.log
/*.out
/run-test.mk

28
tests/verific/case.sv Normal file
View file

@ -0,0 +1,28 @@
module top (
input clk,
input [5:0] currentstate,
output reg [1:0] o
);
always @ (posedge clk)
begin
case (currentstate)
5'd1,5'd2, 5'd3:
begin
o <= 2'b01;
end
5'd4:
begin
o <= 2'b10;
end
5'd5,5'd6,5'd7:
begin
o <= 2'b11;
end
default :
begin
o <= 2'b00;
end
endcase
end
endmodule

16
tests/verific/case.ys Normal file
View file

@ -0,0 +1,16 @@
verific -cfg db_abstract_case_statement_synthesis 0
read -sv case.sv
verific -import top
prep
rename top gold
verific -cfg db_abstract_case_statement_synthesis 1
read -sv case.sv
verific -import top
prep
rename top gate
miter -equiv -flatten -make_assert gold gate miter
prep -top miter
clk2fflogic
sat -set-init-zero -tempinduct -prove-asserts -verify

View file

@ -0,0 +1,11 @@
module top(input clk, input signed [3:0] sel_w , output reg out);
always @ (posedge clk)
begin
case (sel_w) inside
[-4:3] : out <= 1'b1;
[4:5] : out <= 1'b0;
endcase
end
endmodule

View file

@ -0,0 +1,16 @@
verific -cfg db_abstract_case_statement_synthesis 0
read -sv range_case.sv
verific -import top
proc
rename top gold
verific -cfg db_abstract_case_statement_synthesis 1
read -sv range_case.sv
verific -import top
proc
rename top gate
miter -equiv -flatten -make_assert gold gate miter
prep -top miter
clk2fflogic
sat -set-init-zero -tempinduct -prove-asserts -verify

4
tests/verific/run-test.sh Executable file
View file

@ -0,0 +1,4 @@
#!/usr/bin/env bash
set -eu
source ../gen-tests-makefile.sh
run_tests --yosys-scripts --bash