3
0
Fork 0
mirror of https://github.com/YosysHQ/sby.git synced 2025-10-26 18:49:23 +00:00

Test property statuses after timeout

This commit is contained in:
Krystine Sherwin 2025-07-08 15:47:34 +12:00
parent f399acc22d
commit 41bd894eff
No known key found for this signature in database
2 changed files with 133 additions and 0 deletions

111
tests/statusdb/timeout.sby Normal file
View file

@ -0,0 +1,111 @@
[tasks]
btor_bmc: btor bmc
pono_bmc: bmc
btor_cover: btor cover
smt_bmc: smt bmc
smt_cover: smt cover
smt_prove: smt prove
smt_fail: bmc fail
aig_bmc: bmc
aig_prove: prove
abc_bmc: bmc
abc_prove: prove
abc_fail: prove fail
[options]
bmc: mode bmc
cover: mode cover
prove: mode prove
expect TIMEOUT
depth 10000
timeout 1
vcd_sim off
[engines]
btor: btor btormc
pono_bmc: btor pono
smt: smtbmc bitwuzla
smt_fail: smtbmc --keep-going bitwuzla
aig_bmc: aiger aigbmc
aig_prove: aiger suprove
abc_bmc: abc bmc3
abc_prove: abc pdr
abc_fail: abc --keep-going pdr
[script]
fail: read -define FAIL=1
read -sv timeout.sv
prep -top top
[file timeout.sv]
module top #(
parameter WIDTH = 8
) (
input clk,
input load,
input [WIDTH-1:0] a,
input [WIDTH-1:0] b,
output reg [WIDTH-1:0] q,
output reg [WIDTH-1:0] r,
output reg done
);
reg [WIDTH-1:0] a_reg = 0;
reg [WIDTH-1:0] b_reg = 1;
initial begin
q <= 0;
r <= 0;
done <= 1;
end
reg [WIDTH-1:0] q_step = 1;
reg [WIDTH-1:0] r_step = 1;
// This is not how you design a good divider circuit!
always @(posedge clk) begin
if (load) begin
a_reg <= a;
b_reg <= b;
q <= 0;
r <= a;
q_step <= 1;
r_step <= b;
done <= b == 0;
end else begin
if (r_step <= r) begin
q <= q + q_step;
r <= r - r_step;
if (!r_step[WIDTH-1]) begin
r_step <= r_step << 1;
q_step <= q_step << 1;
end
end else begin
if (!q_step[0]) begin
r_step <= r_step >> 1;
q_step <= q_step >> 1;
end else begin
done <= 1;
end
end
end
end
always @(posedge clk) begin
assert (1); // trivial
`ifdef FAIL
assert (0);
`endif
assert (r_step == b_reg * q_step); // Helper invariant
assert (q * b_reg + r == a_reg); // Main invariant & correct output relationship
if (done) assert (r <= b_reg - 1); // Output range
cover (done);
cover (done && b_reg == 0);
cover (r != a_reg);
cover (r == a_reg);
cover (0); // unreachable
end
endmodule

22
tests/statusdb/timeout.sh Normal file
View file

@ -0,0 +1,22 @@
#!/bin/bash
set -e
python3 $SBY_MAIN -f $SBY_FILE $TASK
STATUS_CSV=${WORKDIR}/status.csv
python3 $SBY_MAIN -f $SBY_FILE $TASK --statuscsv | tee $STATUS_CSV
if [[ $TASK =~ "_cover" ]]; then
wc -l $STATUS_CSV | grep -q '6'
grep "COVER" $STATUS_CSV | wc -l | grep -q '5'
elif [[ $TASK =~ "_fail" ]]; then
wc -l $STATUS_CSV | grep -q '6'
grep "ASSERT" $STATUS_CSV | wc -l | grep -q '5'
grep "FAIL" $STATUS_CSV | wc -l | grep -q '1'
else
wc -l $STATUS_CSV | grep -q '5'
grep "ASSERT" $STATUS_CSV | wc -l | grep -q '4'
fi
if [[ $TASK == "smt_cover" ]]; then
grep "PASS" $STATUS_CSV | wc -l | grep -q '4'
fi