diff options
Diffstat (limited to 'tests/various')
| -rw-r--r-- | tests/various/const_arg_loop.v | 64 | ||||
| -rw-r--r-- | tests/various/const_arg_loop.ys | 1 | ||||
| -rw-r--r-- | tests/various/const_func.v | 12 | ||||
| -rw-r--r-- | tests/various/const_func_block_var.v | 26 | ||||
| -rw-r--r-- | tests/various/const_func_block_var.ys | 1 | ||||
| -rw-r--r-- | tests/various/equiv_opt_undef.ys | 35 | ||||
| -rw-r--r-- | tests/various/peepopt.ys | 143 | ||||
| -rwxr-xr-x | tests/various/run-test.sh | 22 | 
8 files changed, 142 insertions, 162 deletions
| diff --git a/tests/various/const_arg_loop.v b/tests/various/const_arg_loop.v new file mode 100644 index 000000000..3bfff4acd --- /dev/null +++ b/tests/various/const_arg_loop.v @@ -0,0 +1,64 @@ +module top; +	function automatic [31:0] operation1; +		input [4:0] rounds; +		input integer num; +		integer i; +		begin +			begin : shadow +				integer rounds; +				rounds = 0; +			end +			for (i = 0; i < rounds; i = i + 1) +				num = num * 2; +			operation1 = num; +		end +	endfunction + +	function automatic [31:0] operation2; +		input [4:0] var; +		input integer num; +		begin +			var[0] = var[0] ^ 1; +			operation2 = num * var; +		end +	endfunction + +	function automatic [31:0] operation3; +		input [4:0] rounds; +		input integer num; +		reg [4:0] rounds; +		integer i; +		begin +			begin : shadow +				integer rounds; +				rounds = 0; +			end +			for (i = 0; i < rounds; i = i + 1) +				num = num * 2; +			operation3 = num; +		end +	endfunction + +	wire [31:0] a; +	assign a = 2; + +	parameter A = 3; + +	wire [31:0] x1; +	assign x1 = operation1(A, a); + +	wire [31:0] x2; +	assign x2 = operation2(A, a); + +	wire [31:0] x3; +	assign x3 = operation3(A, a); + +// `define VERIFY +`ifdef VERIFY +    assert property (a == 2); +    assert property (A == 3); +    assert property (x1 == 16); +    assert property (x2 == 4); +    assert property (x3 == 16); +`endif +endmodule diff --git a/tests/various/const_arg_loop.ys b/tests/various/const_arg_loop.ys new file mode 100644 index 000000000..b039bda10 --- /dev/null +++ b/tests/various/const_arg_loop.ys @@ -0,0 +1 @@ +read_verilog const_arg_loop.v diff --git a/tests/various/const_func.v b/tests/various/const_func.v index 76cdc385d..541e63b19 100644 --- a/tests/various/const_func.v +++ b/tests/various/const_func.v @@ -53,6 +53,15 @@ module top(out);          c1, c2, c3, c4,          d1, d2, d3, d4}; +    function signed [31:0] negate; +        input integer inp; +        negate = ~inp; +    endfunction +    parameter W = 10; +    parameter X = 3; +    localparam signed Y = $floor(W / X); +    localparam signed Z = negate($floor(W / X)); +  // `define VERIFY  `ifdef VERIFY      assert property (a1 == 0); @@ -71,5 +80,8 @@ module top(out);      assert property (d2 == 0);      assert property (d3 == 1);      assert property (d4 == 1); + +    assert property (Y == 3); +    assert property (Z == ~3);  `endif  endmodule diff --git a/tests/various/const_func_block_var.v b/tests/various/const_func_block_var.v new file mode 100644 index 000000000..cb60844ab --- /dev/null +++ b/tests/various/const_func_block_var.v @@ -0,0 +1,26 @@ +module top(out); +	function integer operation; +		input integer num; +		localparam incr = 1; +		localparam mult = 1; +		begin +			operation = 0; +			begin : op_i +				integer i; +				for (i = 0; i * mult < 2; i = i + incr) +				begin : op_j +					integer j; +					localparam other_mult = 2; +					for (j = i; j < i * other_mult; j = j + incr) +						num = num + incr; +				end +				num = num * 2; +			end +			operation = num; +		end +	endfunction + +	localparam res = operation(4); +	output wire [31:0] out; +	assign out = res; +endmodule diff --git a/tests/various/const_func_block_var.ys b/tests/various/const_func_block_var.ys new file mode 100644 index 000000000..7c2e85c64 --- /dev/null +++ b/tests/various/const_func_block_var.ys @@ -0,0 +1 @@ +read_verilog const_func_block_var.v diff --git a/tests/various/equiv_opt_undef.ys b/tests/various/equiv_opt_undef.ys new file mode 100644 index 000000000..5d2c60d0a --- /dev/null +++ b/tests/various/equiv_opt_undef.ys @@ -0,0 +1,35 @@ +read_ilang << EOT + +module \top +  wire $a +  wire $b +  wire input 1 \D +  wire input 2 \EN +  wire output 3 \Q +  cell $mux $x +    parameter \WIDTH 1 +    connect \A \Q +    connect \B \D +    connect \S \EN +    connect \Y $a +  end +  cell $ff $y +    parameter \WIDTH 1 +    connect \D $a +    connect \Q $b +  end +  cell $and $z +    parameter \A_SIGNED 0 +    parameter \A_WIDTH 1 +    parameter \B_SIGNED 0 +    parameter \B_WIDTH 1 +    parameter \Y_WIDTH 1 +    connect \A $b  +    connect \B 1'x +    connect \Y \Q +  end +end + +EOT + +equiv_opt -assert -undef ls diff --git a/tests/various/peepopt.ys b/tests/various/peepopt.ys index ee5ad8a1a..45e936a21 100644 --- a/tests/various/peepopt.ys +++ b/tests/various/peepopt.ys @@ -68,146 +68,3 @@ equiv_opt -assert peepopt  design -load postopt  clean  select -assert-count 0 t:* - -#################### - -design -reset -read_verilog <<EOT -module peepopt_dffmuxext_unsigned(input clk, ce, input [1:0] i, output reg [3:0] o); -    always @(posedge clk) if (ce) o <= i; -endmodule -EOT - -proc -equiv_opt -assert peepopt -design -load postopt -clean -select -assert-count 1 t:$dff r:WIDTH=2 %i -select -assert-count 1 t:$mux r:WIDTH=2 %i -select -assert-count 0 t:$dff t:$mux %% t:* %D - -#################### - -design -reset -read_verilog <<EOT -module peepopt_dffmuxext_signed(input clk, ce, input signed [1:0] i, output reg signed [3:0] o); -    always @(posedge clk) if (ce) o <= i; -endmodule -EOT - -proc -equiv_opt -assert peepopt -design -load postopt -clean -select -assert-count 1 t:$dff r:WIDTH=2 %i -select -assert-count 1 t:$mux r:WIDTH=2 %i -select -assert-count 0 t:$dff t:$mux %% t:* %D - -################### - -design -reset -read_verilog <<EOT -module peepopt_dffmuxext_const(input clk, ce, input [1:0] i, output reg [5:0] o); -    always @(posedge clk) if (ce) o <= {1'b0, i[1], 2'b1x, i[0], 1'bz}; -endmodule -EOT - -proc -equiv_opt -assert peepopt -design -load postopt -select -assert-count 1 t:$dff r:WIDTH=2 %i -select -assert-count 1 t:$mux r:WIDTH=2 %i -select -assert-count 0 t:$dff t:$mux %% t:* %D - -################### - -design -reset -read_verilog <<EOT -module peepopt_dffmuxext_const_init(input clk, ce, input [1:0] i, (* init=6'b0x00x1 *) output reg [5:0] o); -    always @(posedge clk) if (ce) o <= {1'b0, i[1], 2'b1x, i[0], 1'bz}; -endmodule -EOT - -proc -equiv_opt -assert peepopt -design -load postopt -select -assert-count 1 t:$dff r:WIDTH=4 %i -select -assert-count 1 t:$mux r:WIDTH=4 %i -select -assert-count 0 t:$dff t:$mux %% t:* %D - -#################### - -design -reset -read_verilog <<EOT -module peepopt_dffmuxext_unsigned_rst(input clk, ce, rst, input [1:0] i, output reg [3:0] o); -    always @(posedge clk) if (rst) o <= 0; else if (ce) o <= i; -endmodule -EOT - -proc -equiv_opt -assert peepopt -design -load postopt -wreduce -select -assert-count 1 t:$dff r:WIDTH=2 %i -select -assert-count 2 t:$mux -select -assert-count 2 t:$mux r:WIDTH=2 %i -select -assert-count 0 t:$dff t:$mux %% t:* %D - -#################### - -design -reset -read_verilog <<EOT -module peepopt_dffmuxext_signed_rst(input clk, ce, rstn, input signed [1:0] i, output reg signed [3:0] o); -    always @(posedge clk) begin -        if (ce) o <= i; -        if (!rstn) o <= 4'b1111; -    end -endmodule -EOT - -proc -equiv_opt -assert peepopt -design -load postopt -wreduce -select -assert-count 1 t:$dff r:WIDTH=2 %i -select -assert-count 2 t:$mux -select -assert-count 2 t:$mux r:WIDTH=2 %i -select -assert-count 0 t:$logic_not t:$dff t:$mux %% t:* %D - -#################### - -design -reset -read_verilog <<EOT -module peepopt_dffmuxext_signed_rst_init(input clk, ce, rstn, input signed [1:0] i, output reg signed [3:0] o); -    initial o <= 4'b0010; -    always @(posedge clk) begin -        if (ce) o <= i; -        if (!rstn) o <= 4'b1111; -    end -endmodule -EOT - -proc -# NB: equiv_opt uses equiv_induct which covers -#     only the induction half of temporal induction -#     --- missing the base-case half -#     This makes it akin to `sat -tempinduct-inductonly` -#     instead of `sat -tempinduct-baseonly` or -#     `sat -tempinduct` which is necessary for this -#     testcase -#equiv_opt -assert peepopt - -design -save gold -peepopt -wreduce -design -stash gate -design -import gold -as gold -design -import gate -as gate -miter -equiv -flatten -make_assert -make_outputs gold gate miter -sat -tempinduct -verify -prove-asserts -show-ports miter - -design -load gate -select -assert-count 1 t:$dff r:WIDTH=4 %i -select -assert-count 2 t:$mux -select -assert-count 2 t:$mux r:WIDTH=4 %i -select -assert-count 0 t:$logic_not t:$dff t:$mux %% t:* %D diff --git a/tests/various/run-test.sh b/tests/various/run-test.sh index ea56b70f0..2f91cf0fd 100755 --- a/tests/various/run-test.sh +++ b/tests/various/run-test.sh @@ -1,20 +1,4 @@  #!/usr/bin/env bash -set -e -{ -echo "all::" -for x in *.ys; do -	echo "all:: run-$x" -	echo "run-$x:" -	echo "	@echo 'Running $x..'" -	echo "	@../../yosys -ql ${x%.ys}.log $x" -done -for s in *.sh; do -	if [ "$s" != "run-test.sh" ]; then -		echo "all:: run-$s" -		echo "run-$s:" -		echo "	@echo 'Running $s..'" -		echo "	@bash $s" -	fi -done -} > run-test.mk -exec ${MAKE:-make} -f run-test.mk +set -eu +source ../gen-tests-makefile.sh +run_tests --yosys-scripts --bash | 
