aboutsummaryrefslogtreecommitdiffstats
path: root/passes
diff options
context:
space:
mode:
authorEddie Hung <eddie@fpgeh.com>2019-11-27 08:18:41 -0800
committerEddie Hung <eddie@fpgeh.com>2019-11-27 08:18:41 -0800
commit1c0ee4f786a77d8557c9dd462abc54982b7b639d (patch)
tree61685c0569b2d45e7919d5108521f89bd5b1c9d8 /passes
parentc7aa2c6b79243201d076b6e71a461865610c9e8b (diff)
downloadyosys-1c0ee4f786a77d8557c9dd462abc54982b7b639d.tar.gz
yosys-1c0ee4f786a77d8557c9dd462abc54982b7b639d.tar.bz2
yosys-1c0ee4f786a77d8557c9dd462abc54982b7b639d.zip
Do not replace constants with same wire
Diffstat (limited to 'passes')
-rw-r--r--passes/hierarchy/submod.cc10
1 files changed, 3 insertions, 7 deletions
diff --git a/passes/hierarchy/submod.cc b/passes/hierarchy/submod.cc
index cf27d2358..b21b0de01 100644
--- a/passes/hierarchy/submod.cc
+++ b/passes/hierarchy/submod.cc
@@ -34,7 +34,6 @@ struct SubmodWorker
RTLIL::Design *design;
RTLIL::Module *module;
SigMap sigmap;
- std::map<RTLIL::SigBit, RTLIL::SigBit> replace_const;
bool copy_mode;
bool hidden_mode;
@@ -231,7 +230,9 @@ struct SubmodWorker
if (new_wire->port_id > 0) {
// Prevents "ERROR: Mismatch in directionality ..." when flattening
if (new_wire->port_output)
- old_sig.replace(replace_const);
+ for (auto &b : old_sig)
+ if (!b.wire)
+ b = module->addWire(NEW_ID);
new_cell->setPort(new_wire->name, old_sig);
}
}
@@ -265,11 +266,6 @@ struct SubmodWorker
if (wire->port_output)
sigmap.add(wire);
}
- auto wire = module->addWire(NEW_ID);
- replace_const.emplace(State::S0, wire);
- replace_const.emplace(State::S1, wire);
- replace_const.emplace(State::Sx, wire);
- replace_const.emplace(State::Sz, wire);
if (opt_name.empty())
{