mirror of
https://github.com/YosysHQ/yosys
synced 2025-04-06 01:24:10 +00:00
For SVAs that have an explicit clock and are contained in a procedure which conditionally executes the assertion, verific expresses this using a mux with one input connected to constant 1 and the other output connected to an SVA_AT. The existing code only handled the case where the first input is connected to 1. This patch also handles the other case.
12 lines
241 B
Systemverilog
12 lines
241 B
Systemverilog
module top (input clk, a, b);
|
|
always @(posedge clk) begin
|
|
if (a);
|
|
else assume property (@(posedge clk) b);
|
|
end
|
|
|
|
`ifndef FAIL
|
|
assume property (@(posedge clk) !a);
|
|
`endif
|
|
assert property (@(posedge clk) b);
|
|
endmodule
|