mirror of
https://github.com/YosysHQ/yosys
synced 2025-04-07 09:55:20 +00:00
Right now neither `sat` nor `sim` have support for the `$check` cell. For formal verification it is a good idea to always run either async2sync or clk2fflogic which will (in a future commit) lower `$check` to `$assert`, etc. While `sim` should eventually support `$check` directly, using `async2sync` is ok for the current tests that use `sim`, so this commit also runs `async2sync` before running sim on designs containing assertions.
28 lines
467 B
Plaintext
28 lines
467 B
Plaintext
read_verilog -formal <<EOT
|
|
module top(input a, b, c, d);
|
|
|
|
always @* begin
|
|
if (a) assert (b == c);
|
|
if (!a) assert (b != c);
|
|
if (b) assume (c);
|
|
if (c) cover (d);
|
|
end
|
|
|
|
endmodule
|
|
EOT
|
|
|
|
prep -top top
|
|
|
|
async2sync
|
|
|
|
select -assert-count 1 t:$cover
|
|
|
|
chformal -cover -coverenable
|
|
select -assert-count 2 t:$cover
|
|
|
|
chformal -assert -coverenable
|
|
select -assert-count 4 t:$cover
|
|
|
|
chformal -assume -coverenable
|
|
select -assert-count 5 t:$cover
|