mirror of
https://github.com/YosysHQ/yosys
synced 2025-04-23 00:55:32 +00:00
Merge remote-tracking branch 'origin/master' into xc7mux
This commit is contained in:
commit
fb09c6219b
56 changed files with 1811 additions and 487 deletions
|
@ -40,3 +40,15 @@ module dff1a_test(n1, n1_inv, clk);
|
|||
n1 <= n1_inv;
|
||||
assign n1_inv = ~n1;
|
||||
endmodule
|
||||
|
||||
module dff_test_997 (y, clk, wire4);
|
||||
// https://github.com/YosysHQ/yosys/issues/997
|
||||
output wire [1:0] y;
|
||||
input clk;
|
||||
input signed wire4;
|
||||
reg [1:0] reg10 = 0;
|
||||
always @(posedge clk) begin
|
||||
reg10 <= wire4;
|
||||
end
|
||||
assign y = reg10;
|
||||
endmodule
|
||||
|
|
25
tests/simple/forloops.v
Normal file
25
tests/simple/forloops.v
Normal file
|
@ -0,0 +1,25 @@
|
|||
module forloops01 (input clk, a, b, output reg [3:0] p, q, x, y);
|
||||
integer k;
|
||||
always @(posedge clk) begin
|
||||
for (k=0; k<2; k=k+1)
|
||||
p[2*k +: 2] = {a, b} ^ {2{k}};
|
||||
x <= k + {a, b};
|
||||
end
|
||||
always @* begin
|
||||
for (k=0; k<4; k=k+1)
|
||||
q[k] = {~a, ~b, a, b} >> k[1:0];
|
||||
y = k - {a, b};
|
||||
end
|
||||
endmodule
|
||||
|
||||
module forloops02 (input clk, a, b, output reg [3:0] q, x, output [3:0] y);
|
||||
integer k;
|
||||
always @* begin
|
||||
for (k=0; k<4; k=k+1)
|
||||
q[k] = {~a, ~b, a, b} >> k[1:0];
|
||||
end
|
||||
always @* begin
|
||||
x = k + {a, b};
|
||||
end
|
||||
assign y = k - {a, b};
|
||||
endmodule
|
11
tests/simple/localparam_attr.v
Normal file
11
tests/simple/localparam_attr.v
Normal file
|
@ -0,0 +1,11 @@
|
|||
module uut_localparam_attr (I, O);
|
||||
|
||||
(* LOCALPARAM_ATTRIBUTE = "attribute_content" *)
|
||||
localparam WIDTH = 1;
|
||||
|
||||
input wire [WIDTH-1:0] I;
|
||||
output wire [WIDTH-1:0] O;
|
||||
|
||||
assign O = I;
|
||||
|
||||
endmodule
|
|
@ -92,3 +92,25 @@ module mem2reg_test5(input ctrl, output out);
|
|||
assign out = bar[foo[0]];
|
||||
endmodule
|
||||
|
||||
// ------------------------------------------------------
|
||||
|
||||
module mem2reg_test6 (din, dout);
|
||||
input wire [3:0] din;
|
||||
output reg [3:0] dout;
|
||||
|
||||
reg [1:0] din_array [1:0];
|
||||
reg [1:0] dout_array [1:0];
|
||||
|
||||
always @* begin
|
||||
din_array[0] = din[0 +: 2];
|
||||
din_array[1] = din[2 +: 2];
|
||||
|
||||
dout_array[0] = din_array[0];
|
||||
dout_array[1] = din_array[1];
|
||||
|
||||
{dout_array[0][1], dout_array[0][0]} = dout_array[0][0] + dout_array[1][0];
|
||||
|
||||
dout[0 +: 2] = dout_array[0];
|
||||
dout[2 +: 2] = dout_array[1];
|
||||
end
|
||||
endmodule
|
||||
|
|
11
tests/simple/param_attr.v
Normal file
11
tests/simple/param_attr.v
Normal file
|
@ -0,0 +1,11 @@
|
|||
module uut_param_attr (I, O);
|
||||
|
||||
(* PARAMETER_ATTRIBUTE = "attribute_content" *)
|
||||
parameter WIDTH = 1;
|
||||
|
||||
input wire [WIDTH-1:0] I;
|
||||
output wire [WIDTH-1:0] O;
|
||||
|
||||
assign O = I;
|
||||
|
||||
endmodule
|
|
@ -11,13 +11,13 @@ echo "" > $STDERRFILE
|
|||
|
||||
echo -n "Test: ${TESTNAME} -> "
|
||||
|
||||
$PWD/../../yosys -p "read_verilog -sv ${TESTNAME}.sv ; hierarchy -check -top TopModule ; synth ; write_verilog ${TESTNAME}_syn.v" >> $STDOUTFILE >> $STDERRFILE
|
||||
$PWD/../../yosys -p "read_verilog -sv ${TESTNAME}_ref.v ; hierarchy -check -top TopModule ; synth ; write_verilog ${TESTNAME}_ref_syn.v" >> $STDOUTFILE >> $STDERRFILE
|
||||
set -e
|
||||
|
||||
$PWD/../../yosys -p "read_verilog -sv ${TESTNAME}.sv ; hierarchy -check -top TopModule ; synth ; write_verilog ${TESTNAME}_syn.v" >> $STDOUTFILE 2>> $STDERRFILE
|
||||
$PWD/../../yosys -p "read_verilog -sv ${TESTNAME}_ref.v ; hierarchy -check -top TopModule ; synth ; write_verilog ${TESTNAME}_ref_syn.v" >> $STDOUTFILE 2>> $STDERRFILE
|
||||
|
||||
rm -f a.out reference_result.txt dut_result.txt
|
||||
|
||||
set -e
|
||||
|
||||
iverilog -g2012 ${TESTNAME}_syn.v
|
||||
iverilog -g2012 ${TESTNAME}_ref_syn.v
|
||||
|
||||
|
|
|
@ -147,7 +147,8 @@ do
|
|||
fi
|
||||
if $genvcd; then sed -i 's,// \$dump,$dump,g' ${bn}_tb.v; fi
|
||||
compile_and_run ${bn}_tb_ref ${bn}_out_ref ${bn}_tb.v ${bn}_ref.v $libs \
|
||||
"$toolsdir"/../../techlibs/common/simlib.v
|
||||
"$toolsdir"/../../techlibs/common/simlib.v \
|
||||
"$toolsdir"/../../techlibs/common/simcells.v
|
||||
if $genvcd; then mv testbench.vcd ${bn}_ref.vcd; fi
|
||||
|
||||
test_count=0
|
||||
|
|
52
tests/various/chparam.sh
Normal file
52
tests/various/chparam.sh
Normal file
|
@ -0,0 +1,52 @@
|
|||
#!/bin/bash
|
||||
|
||||
trap 'echo "ERROR in chparam.sh" >&2; exit 1' ERR
|
||||
|
||||
cat > chparam1.sv << "EOT"
|
||||
module top #(
|
||||
parameter [31:0] X = 0
|
||||
) (
|
||||
input [31:0] din,
|
||||
output [31:0] dout
|
||||
);
|
||||
assign dout = X-din;
|
||||
endmodule
|
||||
|
||||
module top_props #(
|
||||
parameter [31:0] X = 0
|
||||
) (
|
||||
input [31:0] dout
|
||||
);
|
||||
always @* assert (dout != X);
|
||||
endmodule
|
||||
|
||||
bind top top_props #(.X(123456789)) props (.*);
|
||||
EOT
|
||||
|
||||
cat > chparam2.sv << "EOT"
|
||||
module top #(
|
||||
parameter [31:0] X = 0
|
||||
) (
|
||||
input [31:0] din,
|
||||
output [31:0] dout
|
||||
);
|
||||
assign dout = X-din;
|
||||
always @* assert (dout != 123456789);
|
||||
endmodule
|
||||
EOT
|
||||
|
||||
if ../../yosys -q -p 'verific -sv chparam1.sv'; then
|
||||
../../yosys -q -p 'verific -sv chparam1.sv; hierarchy -chparam X 123123123 -top top; prep -flatten' \
|
||||
-p 'sat -verify -prove-asserts -show-ports -set din[0] 1' \
|
||||
-p 'sat -falsify -prove-asserts -show-ports -set din[0] 0'
|
||||
|
||||
../../yosys -q -p 'verific -sv chparam2.sv; hierarchy -chparam X 123123123 -top top; prep -flatten' \
|
||||
-p 'sat -verify -prove-asserts -show-ports -set din[0] 1' \
|
||||
-p 'sat -falsify -prove-asserts -show-ports -set din[0] 0'
|
||||
fi
|
||||
../../yosys -q -p 'read_verilog -sv chparam2.sv; hierarchy -chparam X 123123123 -top top; prep -flatten' \
|
||||
-p 'sat -verify -prove-asserts -show-ports -set din[0] 1' \
|
||||
-p 'sat -falsify -prove-asserts -show-ports -set din[0] 0'
|
||||
|
||||
rm chparam1.sv
|
||||
rm chparam2.sv
|
30
tests/various/specify.v
Normal file
30
tests/various/specify.v
Normal file
|
@ -0,0 +1,30 @@
|
|||
module test (
|
||||
input EN, CLK,
|
||||
input [3:0] D,
|
||||
output reg [3:0] Q
|
||||
);
|
||||
always @(posedge CLK)
|
||||
if (EN) Q <= D;
|
||||
|
||||
specify
|
||||
if (EN) (CLK *> (Q : D)) = (1, 2:3:4);
|
||||
$setup(D, posedge CLK &&& EN, 5);
|
||||
$hold(posedge CLK, D &&& EN, 6);
|
||||
endspecify
|
||||
endmodule
|
||||
|
||||
module test2 (
|
||||
input A, B,
|
||||
output Q
|
||||
);
|
||||
xor (Q, A, B);
|
||||
specify
|
||||
//specparam T_rise = 1;
|
||||
//specparam T_fall = 2;
|
||||
`define T_rise 1
|
||||
`define T_fall 2
|
||||
(A => Q) = (`T_rise,`T_fall);
|
||||
//(B => Q) = (`T_rise+`T_fall)/2.0;
|
||||
(B => Q) = 1.5;
|
||||
endspecify
|
||||
endmodule
|
56
tests/various/specify.ys
Normal file
56
tests/various/specify.ys
Normal file
|
@ -0,0 +1,56 @@
|
|||
read_verilog -specify specify.v
|
||||
prep
|
||||
cd test
|
||||
select t:$specify2 -assert-count 0
|
||||
select t:$specify3 -assert-count 1
|
||||
select t:$specrule -assert-count 2
|
||||
cd test2
|
||||
select t:$specify2 -assert-count 2
|
||||
select t:$specify3 -assert-count 0
|
||||
select t:$specrule -assert-count 0
|
||||
cd
|
||||
write_verilog specify.out
|
||||
design -stash gold
|
||||
|
||||
read_verilog -specify specify.out
|
||||
prep
|
||||
cd test
|
||||
select t:$specify2 -assert-count 0
|
||||
select t:$specify3 -assert-count 1
|
||||
select t:$specrule -assert-count 2
|
||||
cd test2
|
||||
select t:$specify2 -assert-count 2
|
||||
select t:$specify3 -assert-count 0
|
||||
select t:$specrule -assert-count 0
|
||||
cd
|
||||
design -stash gate
|
||||
|
||||
design -copy-from gold -as gold test
|
||||
design -copy-from gate -as gate test
|
||||
rename -hide
|
||||
rename -enumerate -pattern A_% t:$specify3
|
||||
rename -enumerate -pattern B_% t:$specrule r:TYPE=$setup %i
|
||||
rename -enumerate -pattern C_% t:$specrule r:TYPE=$hold %i
|
||||
select n:A_* -assert-count 2
|
||||
select n:B_* -assert-count 2
|
||||
select n:C_* -assert-count 2
|
||||
equiv_make gold gate equiv
|
||||
hierarchy -top equiv
|
||||
equiv_struct
|
||||
equiv_induct -seq 5
|
||||
equiv_status -assert
|
||||
design -reset
|
||||
|
||||
design -copy-from gold -as gold test2
|
||||
design -copy-from gate -as gate test2
|
||||
rename -hide
|
||||
rename -enumerate -pattern A_% t:$specify2 r:T_RISE_TYP=1 %i
|
||||
rename -enumerate -pattern B_% t:$specify2 n:A_* %d
|
||||
select n:A_* -assert-count 2
|
||||
select n:B_* -assert-count 2
|
||||
equiv_make gold gate equiv
|
||||
hierarchy -top equiv
|
||||
equiv_struct
|
||||
equiv_induct -seq 5
|
||||
equiv_status -assert
|
||||
design -reset
|
Loading…
Add table
Add a link
Reference in a new issue