diff options
author | Bogdan Vukobratovic <bogdan.vukobratovic@gmail.com> | 2019-05-28 08:48:21 +0200 |
---|---|---|
committer | Bogdan Vukobratovic <bogdan.vukobratovic@gmail.com> | 2019-05-28 08:48:21 +0200 |
commit | 9a468f81c412f8b63d25e739f28932815c6882fb (patch) | |
tree | d49e79388b32a59c24d40b600f551fc682648d82 /tests | |
parent | 92dde319fc603223304a64a5a49bbbe6c1ec3045 (diff) | |
download | yosys-9a468f81c412f8b63d25e739f28932815c6882fb.tar.gz yosys-9a468f81c412f8b63d25e739f28932815c6882fb.tar.bz2 yosys-9a468f81c412f8b63d25e739f28932815c6882fb.zip |
Optimizing DFFs whose initial value prevents their value from changing
This is a proof of concept implementation that invokes SAT solver via Pass::call
method.
Diffstat (limited to 'tests')
-rw-r--r-- | tests/opt/opt_ff_sat.v | 15 | ||||
-rw-r--r-- | tests/opt/opt_ff_sat.ys | 4 |
2 files changed, 19 insertions, 0 deletions
diff --git a/tests/opt/opt_ff_sat.v b/tests/opt/opt_ff_sat.v new file mode 100644 index 000000000..fc1e61980 --- /dev/null +++ b/tests/opt/opt_ff_sat.v @@ -0,0 +1,15 @@ +module top( + input clk, + input a, + output b + ); + reg b_reg; + initial begin + b_reg <= 0; + end + + assign b = b_reg; + always @(posedge clk) begin + b_reg <= a && b_reg; + end +endmodule diff --git a/tests/opt/opt_ff_sat.ys b/tests/opt/opt_ff_sat.ys new file mode 100644 index 000000000..13e4ad29b --- /dev/null +++ b/tests/opt/opt_ff_sat.ys @@ -0,0 +1,4 @@ +read_verilog opt_ff_sat.v +prep -flatten +opt_rmdff -sat +synth |