3
0
Fork 0
mirror of https://github.com/YosysHQ/sby.git synced 2025-04-05 22:14:08 +00:00

Merge pull request #186 from jix/ff_xinit_opt

tests: Test for invalid x-value FF init optimizations
This commit is contained in:
Jannis Harder 2022-07-04 14:03:06 +02:00 committed by GitHub
commit 9016031f32
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -0,0 +1,39 @@
[options]
mode bmc
[engines]
smtbmc boolector
[script]
read_verilog -formal ff_xinit_opt.sv
prep -flatten -top top
opt -fast -keepdc
[file ff_xinit_opt.sv]
module top(
input clk,
input [7:0] d
);
(* keep *)
wire [7:0] some_const = $anyconst;
wire [7:0] q1;
wire [7:0] q2;
ff ff1(.clk(clk), .d(q1), .q(q1));
ff ff2(.clk(1'b0), .d(d), .q(q2));
initial assume (some_const == q1);
initial assume (some_const == q2);
initial assume (q1 != 0);
initial assume (q2 != 0);
always @(posedge clk) assert(some_const == q1);
always @(posedge clk) assert(some_const == q2);
endmodule
module ff(input clk, input [7:0] d, (* keep *) output reg [7:0] q);
always @(posedge clk) q <= d;
endmodule