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/opt | |
| 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/opt')
| -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 | 
