aboutsummaryrefslogtreecommitdiffstats
path: root/techlibs/common/simlib.v
diff options
context:
space:
mode:
authorJannis Harder <me@jix.one>2022-07-21 14:22:15 +0200
committerJannis Harder <me@jix.one>2022-08-16 13:37:30 +0200
commitc0063288d699f4f3edf5e0ff6ee1bd5cfa9ac884 (patch)
tree56dede2b6f394bdd4cf662ae8f8a9c1f67e8f54f /techlibs/common/simlib.v
parentc26b2bf543a226e65a3fb07040bb278d668accf2 (diff)
downloadyosys-c0063288d699f4f3edf5e0ff6ee1bd5cfa9ac884.tar.gz
yosys-c0063288d699f4f3edf5e0ff6ee1bd5cfa9ac884.tar.bz2
yosys-c0063288d699f4f3edf5e0ff6ee1bd5cfa9ac884.zip
Add the $anyinit cell and the formalff pass
These can be used to protect undefined flip-flop initialization values from optimizations that are not sound for formal verification and can help mapping all solver-provided values in witness traces for flows that use different backends simultaneously.
Diffstat (limited to 'techlibs/common/simlib.v')
-rw-r--r--techlibs/common/simlib.v17
1 files changed, 17 insertions, 0 deletions
diff --git a/techlibs/common/simlib.v b/techlibs/common/simlib.v
index b14488ff4..ab9bd7e1d 100644
--- a/techlibs/common/simlib.v
+++ b/techlibs/common/simlib.v
@@ -1697,6 +1697,23 @@ assign Y = 'bx;
endmodule
// --------------------------------------------------------
+`ifdef SIMLIB_FF
+module \$anyinit (D, Q);
+
+parameter WIDTH = 0;
+
+input [WIDTH-1:0] D;
+output reg [WIDTH-1:0] Q;
+
+initial Q <= 'bx;
+
+always @($global_clk) begin
+ Q <= D;
+end
+
+endmodule
+`endif
+// --------------------------------------------------------
module \$allconst (Y);