aboutsummaryrefslogtreecommitdiffstats
path: root/passes
diff options
context:
space:
mode:
authorEddie Hung <eddie@fpgeh.com>2020-02-12 16:04:19 -0800
committerEddie Hung <eddie@fpgeh.com>2020-02-13 12:34:09 -0800
commitf7c0dbecee7ee8f2e3fc8bc8337e7045fd4aff15 (patch)
treebfb9641ea7b4a3b6fbfb9c3d06ad2facc958acc4 /passes
parent00d41905df74fd8bbfc5950c4c1ecf2d38394eaf (diff)
downloadyosys-f7c0dbecee7ee8f2e3fc8bc8337e7045fd4aff15.tar.gz
yosys-f7c0dbecee7ee8f2e3fc8bc8337e7045fd4aff15.tar.bz2
yosys-f7c0dbecee7ee8f2e3fc8bc8337e7045fd4aff15.zip
abc9: fix abc9_arrival for flops
Diffstat (limited to 'passes')
-rw-r--r--passes/techmap/abc9_ops.cc33
1 files changed, 31 insertions, 2 deletions
diff --git a/passes/techmap/abc9_ops.cc b/passes/techmap/abc9_ops.cc
index 8f5718411..b26ea6720 100644
--- a/passes/techmap/abc9_ops.cc
+++ b/passes/techmap/abc9_ops.cc
@@ -254,13 +254,19 @@ void prep_xaiger(RTLIL::Module *module, bool dff)
SigMap sigmap(module);
+ dict<SigBit, Cell*> abc9_ff_d;
dict<SigBit, pool<IdString>> bit_drivers, bit_users;
TopoSort<IdString, RTLIL::sort_by_id_str> toposort;
dict<IdString, std::vector<IdString>> box_ports;
for (auto cell : module->cells()) {
- if (cell->type == "$__ABC9_FF_")
+ if (cell->type == "$__ABC9_FF_") {
+ auto d = sigmap(cell->getPort(ID(D)));
+ auto r = abc9_ff_d.insert(d);
+ log_assert(r.second);
+ r.first->second = cell;
continue;
+ }
if (cell->has_keep_attr())
continue;
@@ -357,6 +363,7 @@ void prep_xaiger(RTLIL::Module *module, bool dff)
IdString derived_type = box_module->derive(design, cell->parameters);
box_module = design->module(derived_type);
+ auto abc9_flop = box_module->get_bool_attribute("\\abc9_flop");
auto r = cell_cache.insert(derived_type);
auto &holes_cell = r.first->second;
@@ -395,7 +402,7 @@ void prep_xaiger(RTLIL::Module *module, bool dff)
// For flops only, create an extra 1-bit input that drives a new wire
// called "<cell>.abc9_ff.Q" that is used below
- if (box_module->get_bool_attribute("\\abc9_flop")) {
+ if (abc9_flop) {
box_inputs++;
Wire *holes_wire = holes_module->wire(stringf("\\i%d", box_inputs));
if (!holes_wire) {
@@ -425,6 +432,28 @@ void prep_xaiger(RTLIL::Module *module, bool dff)
holes_module->connect(holes_wire, holes_cell->getPort(port_name));
else // blackbox
holes_module->connect(holes_wire, Const(State::S0, GetSize(w)));
+
+ // Transfer abc9_arrival value from flop box output to $__ABC9_FF_ cell
+ if (abc9_flop) {
+ auto it = w->attributes.find(ID(abc9_arrival));
+ if (it == w->attributes.end())
+ continue;
+ auto jt = cell->connections_.find(port_name);
+ if (jt == cell->connections_.end())
+ continue;
+ auto kt = abc9_ff_d.find(jt->second);
+ if (kt == abc9_ff_d.end())
+ continue;
+#ifndef NDEBUG
+ if (ys_debug(1)) {
+ static std::set<std::pair<IdString,IdString>> seen;
+ if (seen.emplace(cell->type, port_name).second) log("%s.%s abc9_arrival = %d\n", log_id(cell->type), log_id(port_name), it->second.as_int());
+ }
+#endif
+ auto r = kt->second->attributes.insert(ID(abc9_arrival));
+ log_assert(r.second);
+ r.first->second = it->second;
+ }
}
}
}