diff options
author | bfg86 <1920022+bfg86@users.noreply.github.com> | 2022-02-11 00:05:13 +0100 |
---|---|---|
committer | bfg86 <1920022+bfg86@users.noreply.github.com> | 2022-02-11 00:05:13 +0100 |
commit | 7ac98d1c87c10f1bd0221b440efd573cfb73044c (patch) | |
tree | 1801677047278699b46274c7471c160c62b14749 /passes | |
parent | 61324cf55fc5c5237161d4cee157c121fe115fa1 (diff) | |
download | yosys-7ac98d1c87c10f1bd0221b440efd573cfb73044c.tar.gz yosys-7ac98d1c87c10f1bd0221b440efd573cfb73044c.tar.bz2 yosys-7ac98d1c87c10f1bd0221b440efd573cfb73044c.zip |
Add -suffix option to rename -wire.
See #3195
Diffstat (limited to 'passes')
-rw-r--r-- | passes/cmds/rename.cc | 17 |
1 files changed, 13 insertions, 4 deletions
diff --git a/passes/cmds/rename.cc b/passes/cmds/rename.cc index 1d08fc514..8316ecd6f 100644 --- a/passes/cmds/rename.cc +++ b/passes/cmds/rename.cc @@ -66,7 +66,7 @@ static std::string derive_name_from_src(const std::string &src, int counter) return stringf("\\%s$%d", src_base.c_str(), counter); } -static IdString derive_name_from_cell_output_wire(const RTLIL::Cell *cell) +static IdString derive_name_from_cell_output_wire(const RTLIL::Cell *cell, string suffix) { // Find output const SigSpec *output = nullptr; @@ -99,7 +99,10 @@ static IdString derive_name_from_cell_output_wire(const RTLIL::Cell *cell) } } - return name + cell->type.str(); + if (suffix.empty()) { + suffix = cell->type.str(); + } + return name + suffix; } struct RenamePass : public Pass { @@ -127,10 +130,12 @@ struct RenamePass : public Pass { log("cells with private names.\n"); log("\n"); log("\n"); - log(" rename -wire [selection]\n"); + log(" rename -wire [selection] [-suffix <suffix>]\n"); log("\n"); log("Assign auto-generated names based on the wires they drive to all selected\n"); log("cells with private names. Ignores cells driving privatly named wires.\n"); + log("The -suffix option can be used to set a suffix to the renamed cells.\n"); + log("The default suffix is the cell type.\n"); log("\n"); log("\n"); log(" rename -enumerate [-pattern <pattern>] [selection]\n"); @@ -155,6 +160,7 @@ struct RenamePass : public Pass { void execute(std::vector<std::string> args, RTLIL::Design *design) override { std::string pattern_prefix = "_", pattern_suffix = "_"; + std::string cell_suffix = ""; bool flag_src = false; bool flag_wire = false; bool flag_enumerate = false; @@ -203,6 +209,9 @@ struct RenamePass : public Pass { pattern_suffix = args[argidx].substr(pos+1); continue; } + if (arg == "-suffix" && argidx + 1 < args.size()) { + cell_suffix = args[++argidx]; + } break; } @@ -240,7 +249,7 @@ struct RenamePass : public Pass { dict<RTLIL::Cell *, IdString> new_cell_names; for (auto cell : module->selected_cells()) if (cell->name[0] == '$') - new_cell_names[cell] = derive_name_from_cell_output_wire(cell); + new_cell_names[cell] = derive_name_from_cell_output_wire(cell, cell_suffix); for (auto &it : new_cell_names) module->rename(it.first, it.second); } |