diff options
author | Clifford Wolf <clifford@clifford.at> | 2013-07-07 12:59:30 +0200 |
---|---|---|
committer | Clifford Wolf <clifford@clifford.at> | 2013-07-07 12:59:30 +0200 |
commit | cf885c4a28590d79f9c1bdcf47d40846cce68488 (patch) | |
tree | 5b08b314e163416d1c8db3d7dcd7331831337feb /passes/opt/opt_clean.cc | |
parent | 0c0197cf45ae5ca0f40cfeb34d289acc9bca5b7e (diff) | |
download | yosys-cf885c4a28590d79f9c1bdcf47d40846cce68488.tar.gz yosys-cf885c4a28590d79f9c1bdcf47d40846cce68488.tar.bz2 yosys-cf885c4a28590d79f9c1bdcf47d40846cce68488.zip |
Added opt_clean -purge option
Diffstat (limited to 'passes/opt/opt_clean.cc')
-rw-r--r-- | passes/opt/opt_clean.cc | 26 |
1 files changed, 19 insertions, 7 deletions
diff --git a/passes/opt/opt_clean.cc b/passes/opt/opt_clean.cc index 0b4defdf4..983e5d5fa 100644 --- a/passes/opt/opt_clean.cc +++ b/passes/opt/opt_clean.cc @@ -129,7 +129,7 @@ static bool check_public_name(RTLIL::IdString id) return true; } -static void rmunused_module_signals(RTLIL::Module *module) +static void rmunused_module_signals(RTLIL::Module *module, bool purge_mode) { SigMap assign_map(module); for (auto &it : module->wires) { @@ -168,7 +168,7 @@ static void rmunused_module_signals(RTLIL::Module *module) std::vector<RTLIL::Wire*> del_wires; for (auto &it : module->wires) { RTLIL::Wire *wire = it.second; - if (check_public_name(wire->name)) { + if ((!purge_mode && check_public_name(wire->name)) || wire->port_id != 0) { RTLIL::SigSpec s1 = RTLIL::SigSpec(wire), s2 = s1; assign_map.apply(s2); if (!used_signals.check_any(s2) && wire->port_id == 0) { @@ -232,12 +232,12 @@ static void rmunused_module_signals(RTLIL::Module *module) log(" removed %d unused temporary wires.\n", del_wires_count); } -static void rmunused_module(RTLIL::Module *module) +static void rmunused_module(RTLIL::Module *module, bool purge_mode) { log("Finding unused cells or wires in module %s..\n", module->name.c_str()); rmunused_module_cells(module); - rmunused_module_signals(module); + rmunused_module_signals(module, purge_mode); } struct OptCleanPass : public Pass { @@ -246,7 +246,7 @@ struct OptCleanPass : public Pass { { // |---v---|---v---|---v---|---v---|---v---|---v---|---v---|---v---|---v---|---v---| log("\n"); - log(" opt_clean [selection]\n"); + log(" opt_clean [options] [selection]\n"); log("\n"); log("This pass identifies wires and cells that are unused and removes them. Other\n"); log("passes often remove cells but leave the wires in the design or reconnect the\n"); @@ -255,13 +255,25 @@ struct OptCleanPass : public Pass { log("\n"); log("This pass only operates on completely selected modules without processes.\n"); log("\n"); + log(" -purge\n"); + log(" also remove internal nets if they have a public name\n"); + log("\n"); } virtual void execute(std::vector<std::string> args, RTLIL::Design *design) { + bool purge_mode = false; + log_header("Executing OPT_CLEAN pass (remove unused cells and wires).\n"); log_push(); - extra_args(args, 1, design); + size_t argidx; + for (argidx = 1; argidx < args.size(); argidx++) { + if (args[argidx] == "-purge") { + purge_mode = true; + continue; + } + } + extra_args(args, argidx, design); ct.setup_internals(); ct.setup_internals_mem(); @@ -277,7 +289,7 @@ struct OptCleanPass : public Pass { if (mod_it.second->processes.size() > 0) { log("Skipping module %s as it contains processes.\n", mod_it.second->name.c_str()); } else { - rmunused_module(mod_it.second); + rmunused_module(mod_it.second, purge_mode); } } |