aboutsummaryrefslogtreecommitdiffstats
path: root/passes
diff options
context:
space:
mode:
authorwhitequark <whitequark@whitequark.org>2020-04-17 02:21:23 +0000
committerGitHub <noreply@github.com>2020-04-17 02:21:23 +0000
commitf2064c813150f67436a8947fc61644f5e0fb01c0 (patch)
tree3491cd1096135710f2ec01fad218ce10077a8ece /passes
parent5c428996a99311343ed6691fc5c49bea9342a32c (diff)
parentff8be2364e9d9aecb084f7fff07a2538b5e6d02e (diff)
downloadyosys-f2064c813150f67436a8947fc61644f5e0fb01c0.tar.gz
yosys-f2064c813150f67436a8947fc61644f5e0fb01c0.tar.bz2
yosys-f2064c813150f67436a8947fc61644f5e0fb01c0.zip
Merge pull request #1888 from boqwxp/cleanup_scatter
Clean up `passes/cmds/scatter.cc`.
Diffstat (limited to 'passes')
-rw-r--r--passes/cmds/scatter.cc28
1 files changed, 11 insertions, 17 deletions
diff --git a/passes/cmds/scatter.cc b/passes/cmds/scatter.cc
index 7123ba9fb..a5ef95f02 100644
--- a/passes/cmds/scatter.cc
+++ b/passes/cmds/scatter.cc
@@ -46,25 +46,19 @@ struct ScatterPass : public Pass {
CellTypes ct(design);
extra_args(args, 1, design);
- for (auto &mod_it : design->modules_)
+ for (auto module : design->selected_modules())
{
- if (!design->selected(mod_it.second))
- continue;
-
- for (auto &c : mod_it.second->cells_)
- for (auto &p : c.second->connections_)
- {
- RTLIL::Wire *wire = mod_it.second->addWire(NEW_ID, p.second.size());
-
- if (ct.cell_output(c.second->type, p.first)) {
- RTLIL::SigSig sigsig(p.second, wire);
- mod_it.second->connect(sigsig);
- } else {
- RTLIL::SigSig sigsig(wire, p.second);
- mod_it.second->connect(sigsig);
+ for (auto cell : module->cells()) {
+ dict<RTLIL::IdString, RTLIL::SigSig> new_connections;
+ for (auto conn : cell->connections())
+ new_connections.emplace(conn.first, RTLIL::SigSig(conn.second, module->addWire(NEW_ID, GetSize(conn.second))));
+ for (auto &it : new_connections) {
+ if (ct.cell_output(cell->type, it.first))
+ module->connect(RTLIL::SigSig(it.second.first, it.second.second));
+ else
+ module->connect(RTLIL::SigSig(it.second.second, it.second.first));
+ cell->setPort(it.first, it.second.second);
}
-
- p.second = wire;
}
}
}