mirror of
https://github.com/YosysHQ/yosys
synced 2025-04-06 17:44:09 +00:00
share: fix infinite loop in find_terminal_bits on $mux loop
This commit is contained in:
parent
f445479374
commit
01d2bfcf00
|
@ -87,7 +87,7 @@ struct ShareWorker
|
||||||
queue_bits.clear();
|
queue_bits.clear();
|
||||||
|
|
||||||
for (auto &pbit : portbits) {
|
for (auto &pbit : portbits) {
|
||||||
if (pbit.cell->type == ID($mux) || pbit.cell->type == ID($pmux)) {
|
if ((pbit.cell->type == ID($mux) || pbit.cell->type == ID($pmux)) && visited_cells.count(pbit.cell) == 0) {
|
||||||
pool<RTLIL::SigBit> bits = modwalker.sigmap(pbit.cell->getPort(ID::S)).to_sigbit_pool();
|
pool<RTLIL::SigBit> bits = modwalker.sigmap(pbit.cell->getPort(ID::S)).to_sigbit_pool();
|
||||||
terminal_bits.insert(bits.begin(), bits.end());
|
terminal_bits.insert(bits.begin(), bits.end());
|
||||||
queue_bits.insert(bits.begin(), bits.end());
|
queue_bits.insert(bits.begin(), bits.end());
|
||||||
|
|
Loading…
Reference in a new issue