From f9f86fd7582e447e2118534d888190ba14e39803 Mon Sep 17 00:00:00 2001 From: Eddie Hung Date: Fri, 14 Feb 2020 16:08:04 -0800 Subject: Revert "abc9: fix abc9_arrival for flops" This reverts commit f7c0dbecee7ee8f2e3fc8bc8337e7045fd4aff15. --- passes/techmap/abc9_ops.cc | 33 ++------------------------------- 1 file changed, 2 insertions(+), 31 deletions(-) (limited to 'passes') diff --git a/passes/techmap/abc9_ops.cc b/passes/techmap/abc9_ops.cc index b26ea6720..8f5718411 100644 --- a/passes/techmap/abc9_ops.cc +++ b/passes/techmap/abc9_ops.cc @@ -254,19 +254,13 @@ void prep_xaiger(RTLIL::Module *module, bool dff) SigMap sigmap(module); - dict abc9_ff_d; dict> bit_drivers, bit_users; TopoSort toposort; dict> box_ports; for (auto cell : module->cells()) { - 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; + if (cell->type == "$__ABC9_FF_") continue; - } if (cell->has_keep_attr()) continue; @@ -363,7 +357,6 @@ 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; @@ -402,7 +395,7 @@ void prep_xaiger(RTLIL::Module *module, bool dff) // For flops only, create an extra 1-bit input that drives a new wire // called ".abc9_ff.Q" that is used below - if (abc9_flop) { + if (box_module->get_bool_attribute("\\abc9_flop")) { box_inputs++; Wire *holes_wire = holes_module->wire(stringf("\\i%d", box_inputs)); if (!holes_wire) { @@ -432,28 +425,6 @@ 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> 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; - } } } } -- cgit v1.2.3