diff options
author | Clifford Wolf <clifford@clifford.at> | 2014-02-02 21:09:08 +0100 |
---|---|---|
committer | Clifford Wolf <clifford@clifford.at> | 2014-02-02 21:09:08 +0100 |
commit | 83fa65282017cb39a31c6c4c878b9960d8097b66 (patch) | |
tree | 246d4cc1af6cefb893ff3780c475531cc742ecc1 | |
parent | 6983d3f10bc526c51803107efa98e6d16353b414 (diff) | |
download | yosys-83fa65282017cb39a31c6c4c878b9960d8097b66.tar.gz yosys-83fa65282017cb39a31c6c4c878b9960d8097b66.tar.bz2 yosys-83fa65282017cb39a31c6c4c878b9960d8097b66.zip |
Added constant-clock case to opt_rmdff
-rw-r--r-- | passes/opt/opt_rmdff.cc | 8 |
1 files changed, 8 insertions, 0 deletions
diff --git a/passes/opt/opt_rmdff.cc b/passes/opt/opt_rmdff.cc index 9ce98004e..a8e2c4121 100644 --- a/passes/opt/opt_rmdff.cc +++ b/passes/opt/opt_rmdff.cc @@ -92,6 +92,14 @@ static bool handle_dff(RTLIL::Module *mod, RTLIL::Cell *dff) } } + if (sig_c.is_fully_const()) { + if (val_rv.bits.size() == 0) + val_rv = RTLIL::Const(RTLIL::State::Sx, sig_q.width); + RTLIL::SigSig conn(sig_q, val_rv); + mod->connections.push_back(conn); + goto delete_dff; + } + if (sig_d.is_fully_undef() && sig_d.width == int(val_rv.bits.size())) { RTLIL::SigSig conn(sig_q, val_rv); mod->connections.push_back(conn); |