diff options
author | Clifford Wolf <clifford@clifford.at> | 2017-12-12 23:43:55 +0100 |
---|---|---|
committer | Clifford Wolf <clifford@clifford.at> | 2017-12-12 23:44:08 +0100 |
commit | 0881bbf2e711a23137e860bf1dfc2c6130d3d07b (patch) | |
tree | e0fbff01424e396b9c6bf5f9fad78745e85bfa84 /backends/btor/btor.cc | |
parent | f697282246862d99ae5c1798456c9082c615cea2 (diff) | |
download | yosys-0881bbf2e711a23137e860bf1dfc2c6130d3d07b.tar.gz yosys-0881bbf2e711a23137e860bf1dfc2c6130d3d07b.tar.bz2 yosys-0881bbf2e711a23137e860bf1dfc2c6130d3d07b.zip |
Add state initval handling to btor back-end
Diffstat (limited to 'backends/btor/btor.cc')
-rw-r--r-- | backends/btor/btor.cc | 25 |
1 files changed, 25 insertions, 0 deletions
diff --git a/backends/btor/btor.cc b/backends/btor/btor.cc index d2deb50b8..56d17c6e9 100644 --- a/backends/btor/btor.cc +++ b/backends/btor/btor.cc @@ -63,6 +63,7 @@ struct BtorWorker pool<Cell*> cell_recursion_guard; pool<string> output_symbols; + dict<SigBit, bool> initbits; string indent; void btorf(const char *fmt, ...) @@ -101,6 +102,9 @@ struct BtorWorker void add_nid_sig(int nid, const SigSpec &sig) { + if (verbose) + f << indent << stringf("; %d %s\n", nid, log_signal(sig)); + for (int i = 0; i < GetSize(sig); i++) bit_nid[sig[i]] = make_pair(nid, i); @@ -492,6 +496,20 @@ struct BtorWorker else btorf("%d state %d %s\n", nid, sid, symbol.c_str()); + Const initval; + for (int i = 0; i < GetSize(sig_q); i++) + if (initbits.count(sig_q[i])) + initval.bits.push_back(initbits.at(sig_q[i]) ? State::S1 : State::S0); + else + initval.bits.push_back(State::Sx); + + if (!initval.is_fully_undef()) { + int nid_init_val = get_sig_nid(initval); + int nid_init = next_nid++; + btorf("; initval = %s\n", log_signal(initval)); + btorf("%d init %d %d %d\n", nid_init, sid, nid, nid_init_val); + } + ff_todo.push_back(make_pair(nid, cell)); add_nid_sig(nid, sig_q); goto okay; @@ -694,6 +712,13 @@ struct BtorWorker for (auto wire : module->wires()) { + if (wire->attributes.count("\\init")) { + Const attrval = wire->attributes.at("\\init"); + for (int i = 0; i < GetSize(wire) && i < GetSize(attrval); i++) + if (attrval[i] == State::S0 || attrval[i] == State::S1) + initbits[sigmap(SigBit(wire, i))] = (attrval[i] == State::S1); + } + if (!wire->port_id || !wire->port_input) continue; |