From: Clifford Wolf Date: Tue, 22 Dec 2015 12:25:00 +0000 (+0100) Subject: Fixed "splitnets -ports" for hierarchical designs X-Git-Tag: yosys-0.6~41 X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=1d62f8710f04fec405ef79b9e9a4a031afcf7d42;p=yosys.git Fixed "splitnets -ports" for hierarchical designs --- diff --git a/passes/cmds/splitnets.cc b/passes/cmds/splitnets.cc index a64c48791..0d7892d71 100644 --- a/passes/cmds/splitnets.cc +++ b/passes/cmds/splitnets.cc @@ -130,6 +130,9 @@ struct SplitnetsPass : public Pass { } extra_args(args, argidx, design); + // module_ports_db[module_name][old_port_name] = new_port_name_list + dict>> module_ports_db; + for (auto module : design->selected_modules()) { SplitnetsWorker worker; @@ -199,6 +202,26 @@ struct SplitnetsPass : public Pass { module->rewrite_sigspecs(worker); + if (flag_ports) + { + for (auto wire : module->wires()) + { + if (wire->port_id == 0) + continue; + + SigSpec sig(wire); + worker(sig); + + if (sig == wire) + continue; + + vector &new_ports = module_ports_db[module->name][wire->name]; + + for (SigSpec c : sig.chunks()) + new_ports.push_back(c.as_wire()->name); + } + } + pool delete_wires; for (auto &it : worker.splitmap) delete_wires.insert(it.first); @@ -207,6 +230,40 @@ struct SplitnetsPass : public Pass { if (flag_ports) module->fixup_ports(); } + + if (!module_ports_db.empty()) + { + for (auto module : design->modules()) + for (auto cell : module->cells()) + { + if (module_ports_db.count(cell->type) == 0) + continue; + + for (auto &it : module_ports_db.at(cell->type)) + { + IdString port_id = it.first; + const auto &new_port_ids = it.second; + + if (!cell->hasPort(port_id)) + continue; + + int offset = 0; + SigSpec sig = cell->getPort(port_id); + + for (auto nid : new_port_ids) + { + int nlen = GetSize(design->module(cell->type)->wire(nid)); + if (offset + nlen > GetSize(sig)) + nlen = GetSize(sig) - offset; + if (nlen > 0) + cell->setPort(nid, sig.extract(offset, nlen)); + offset += nlen; + } + + cell->unsetPort(port_id); + } + } + } } } SplitnetsPass;