3
0
Fork 0
mirror of https://github.com/YosysHQ/yosys synced 2025-04-13 04:28:18 +00:00

sat encoding for exclusive $pmux ctrl inputs in "share" pass

This commit is contained in:
Clifford Wolf 2014-10-03 19:01:24 +02:00
parent 56c1d43408
commit c5c7066ea6

View file

@ -55,6 +55,8 @@ struct ShareWorker
std::map<RTLIL::Cell*, std::set<RTLIL::Cell*>> topo_cell_drivers; std::map<RTLIL::Cell*, std::set<RTLIL::Cell*>> topo_cell_drivers;
std::map<RTLIL::SigBit, std::set<RTLIL::Cell*>> topo_bit_drivers; std::map<RTLIL::SigBit, std::set<RTLIL::Cell*>> topo_bit_drivers;
std::vector<std::pair<RTLIL::SigBit, RTLIL::SigBit>> exclusive_ctrls;
// ------------------------------------------------------------------------------ // ------------------------------------------------------------------------------
// Find terminal bits -- i.e. bits that do not (exclusively) feed into a mux tree // Find terminal bits -- i.e. bits that do not (exclusively) feed into a mux tree
@ -261,7 +263,6 @@ struct ShareWorker
for (int i : m1_unmapped) for (int i : m1_unmapped)
for (int j : m2_unmapped) { for (int j : m2_unmapped) {
int score = share_macc_ports(m1.ports[i], m2.ports[j], w1, w2); int score = share_macc_ports(m1.ports[i], m2.ports[j], w1, w2);
log("[%s, %s] vs [%s, %s] -> %d\n", log_signal(m1.ports[i].in_a), log_signal(m1.ports[i].in_b), log_signal(m2.ports[j].in_a), log_signal(m2.ports[j].in_b), score);
if (score >= 0 && (best_i < 0 || best_score > score)) if (score >= 0 && (best_i < 0 || best_score > score))
best_i = i, best_j = j, best_score = score; best_i = i, best_j = j, best_score = score;
} }
@ -346,10 +347,8 @@ struct ShareWorker
void find_shareable_cells() void find_shareable_cells()
{ {
for (auto &it : module->cells_) for (auto cell : module->cells())
{ {
RTLIL::Cell *cell = it.second;
if (!design->selected(module, cell) || !modwalker.ct.cell_known(cell->type)) if (!design->selected(module, cell) || !modwalker.ct.cell_known(cell->type))
continue; continue;
@ -1081,6 +1080,13 @@ struct ShareWorker
log("Found %d cells in module %s that may be considered for resource sharing.\n", log("Found %d cells in module %s that may be considered for resource sharing.\n",
SIZE(shareable_cells), log_id(module)); SIZE(shareable_cells), log_id(module));
for (auto cell : module->cells())
if (cell->type == "$pmux")
for (auto bit : cell->getPort("\\S"))
for (auto other_bit : cell->getPort("\\S"))
if (bit < other_bit)
exclusive_ctrls.push_back(std::pair<RTLIL::SigBit, RTLIL::SigBit>(bit, other_bit));
while (!shareable_cells.empty() && config.limit != 0) while (!shareable_cells.empty() && config.limit != 0)
{ {
RTLIL::Cell *cell = *shareable_cells.begin(); RTLIL::Cell *cell = *shareable_cells.begin();
@ -1206,6 +1212,12 @@ struct ShareWorker
break; break;
} }
for (auto it : exclusive_ctrls)
if (satgen.importedSigBit(it.first) && satgen.importedSigBit(it.second)) {
log(" Adding exclusive control bits: %s vs. %s\n", log_signal(it.first), log_signal(it.second));
ez.assume(ez.NOT(ez.AND(satgen.importSigBit(it.first), satgen.importSigBit(it.second))));
}
if (!ez.solve(ez.expression(ez.OpOr, cell_active))) { if (!ez.solve(ez.expression(ez.OpOr, cell_active))) {
log(" According to the SAT solver the cell %s is never active. Sharing is pointless, we simply remove it.\n", log_id(cell)); log(" According to the SAT solver the cell %s is never active. Sharing is pointless, we simply remove it.\n", log_id(cell));
cells_to_remove.insert(cell); cells_to_remove.insert(cell);