From 08c43f27afbef7161766a88a79d5d1f92e458a1e Mon Sep 17 00:00:00 2001 From: Clifford Wolf Date: Wed, 27 Feb 2013 23:39:10 +0100 Subject: [PATCH] Added "extract -constports" feature --- passes/extract/extract.cc | 40 ++++++++++++++++++++++++++++++++++----- 1 file changed, 35 insertions(+), 5 deletions(-) diff --git a/passes/extract/extract.cc b/passes/extract/extract.cc index 9b5991bfe..9439b6b11 100644 --- a/passes/extract/extract.cc +++ b/passes/extract/extract.cc @@ -33,7 +33,7 @@ namespace int bit; }; - bool module2graph(SubCircuit::Graph &graph, RTLIL::Module *mod, RTLIL::Design *sel = NULL) + bool module2graph(SubCircuit::Graph &graph, RTLIL::Module *mod, bool constports, RTLIL::Design *sel = NULL) { SigMap sigmap(mod); std::map sig_bit_ref; @@ -48,6 +48,21 @@ namespace return false; } + if (constports) { + graph.createNode("$const$0", "$const$0"); + graph.createNode("$const$1", "$const$1"); + graph.createNode("$const$x", "$const$x"); + graph.createNode("$const$z", "$const$z"); + graph.createPort("$const$0", "Y", 1); + graph.createPort("$const$1", "Y", 1); + graph.createPort("$const$x", "Y", 1); + graph.createPort("$const$z", "Y", 1); + graph.markExtern("$const$0", "Y", 0); + graph.markExtern("$const$1", "Y", 0); + graph.markExtern("$const$x", "Y", 0); + graph.markExtern("$const$z", "Y", 0); + } + // create graph nodes from cells for (auto &cell_it : mod->cells) { @@ -73,7 +88,14 @@ namespace assert(chunk.width == 1); if (chunk.wire == NULL) { - graph.createConstant(cell->name, conn.first, i, int(chunk.data.bits[0])); + if (constports) { + std::string node = "$const$x"; + if (chunk.data.bits[0] == RTLIL::State::S0) node = "$const$0"; + if (chunk.data.bits[0] == RTLIL::State::S1) node = "$const$1"; + if (chunk.data.bits[0] == RTLIL::State::Sz) node = "$const$z"; + graph.createConnection(cell->name, conn.first, i, node, "Y", 0); + } else + graph.createConstant(cell->name, conn.first, i, int(chunk.data.bits[0])); continue; } @@ -158,6 +180,9 @@ namespace RTLIL::Cell *needle_cell = (RTLIL::Cell*)mapping.needleUserData; RTLIL::Cell *haystack_cell = (RTLIL::Cell*)mapping.haystackUserData; + if (needle_cell == NULL) + continue; + for (auto &conn : needle_cell->connections) { RTLIL::SigSpec sig = sigmap(conn.second); if (mapping.portMapping.count(conn.first) > 0 && sig2port.has(sigmap(sig))) { @@ -184,7 +209,8 @@ struct ExtractPass : public Pass { log_push(); std::string filename; - bool verbose; + bool verbose = false; + bool constports = false; size_t argidx; for (argidx = 1; argidx < args.size(); argidx++) { @@ -196,6 +222,10 @@ struct ExtractPass : public Pass { verbose = true; continue; } + if (args[argidx] == "-constports") { + constports = true; + continue; + } break; } extra_args(args, argidx, design); @@ -227,7 +257,7 @@ struct ExtractPass : public Pass { SubCircuit::Graph mod_graph; std::string graph_name = "needle_" + mod_it.first.substr(mod_it.first[0] == '\\' ? 1 : 0); log("Creating needle graph %s.\n", graph_name.c_str()); - if (module2graph(mod_graph, mod_it.second)) { + if (module2graph(mod_graph, mod_it.second, constports)) { solver.addGraph(graph_name, mod_graph); needle_map[graph_name] = mod_it.second; } @@ -237,7 +267,7 @@ struct ExtractPass : public Pass { SubCircuit::Graph mod_graph; std::string graph_name = "haystack_" + mod_it.first.substr(mod_it.first[0] == '\\' ? 1 : 0); log("Creating haystack graph %s.\n", graph_name.c_str()); - if (module2graph(mod_graph, mod_it.second, design)) { + if (module2graph(mod_graph, mod_it.second, constports, design)) { solver.addGraph(graph_name, mod_graph); haystack_map[graph_name] = mod_it.second; }