From d77a914683207ab9e4be20d8a10573acd8af777a Mon Sep 17 00:00:00 2001 From: Clifford Wolf Date: Sat, 20 Aug 2016 12:52:50 +0200 Subject: [PATCH] Added "wreduce -memx" --- passes/opt/wreduce.cc | 17 ++++++++++++++--- techlibs/common/prep.cc | 8 ++++++-- 2 files changed, 20 insertions(+), 5 deletions(-) diff --git a/passes/opt/wreduce.cc b/passes/opt/wreduce.cc index b2f1bea7a..07503fbb3 100644 --- a/passes/opt/wreduce.cc +++ b/passes/opt/wreduce.cc @@ -366,15 +366,26 @@ struct WreducePass : public Pass { log(" assign y = a + b + c + 1;\n"); log(" endmodule\n"); log("\n"); + log("Options:\n"); + log("\n"); + log(" -memx\n"); + log(" Do not change the width of memory address ports. Use this options in\n"); + log(" flows that use the 'memory_memx' pass.\n"); + log("\n"); } virtual void execute(std::vector args, Design *design) { WreduceConfig config; + bool opt_memx = false; log_header(design, "Executing WREDUCE pass (reducing word size of cells).\n"); size_t argidx; for (argidx = 1; argidx < args.size(); argidx++) { + if (args[argidx] == "-memx") { + opt_memx = true; + continue; + } break; } extra_args(args, argidx, design); @@ -397,12 +408,12 @@ struct WreducePass : public Pass { module->connect(sig, Const(0, GetSize(sig))); } } - if (c->type.in("$memrd", "$memwr", "$meminit")) { + if (!opt_memx && c->type.in("$memrd", "$memwr", "$meminit")) { IdString memid = c->getParam("\\MEMID").decode_string(); RTLIL::Memory *mem = module->memories.at(memid); - if (mem->start_offset == 0) { + if (mem->start_offset >= 0) { int cur_addrbits = c->getParam("\\ABITS").as_int(); - int max_addrbits = ceil_log2(mem->size); + int max_addrbits = ceil_log2(mem->start_offset + mem->size); if (cur_addrbits > max_addrbits) { log("Removed top %d address bits (of %d) from memory %s port %s.%s (%s).\n", cur_addrbits-max_addrbits, cur_addrbits, diff --git a/techlibs/common/prep.cc b/techlibs/common/prep.cc index 8accb7e28..f797f5db7 100644 --- a/techlibs/common/prep.cc +++ b/techlibs/common/prep.cc @@ -173,8 +173,12 @@ struct PrepPass : public ScriptPass run("opt_clean"); run("check"); run("opt -keepdc"); - if (!ifxmode) - run("wreduce"); + if (!ifxmode) { + if (help_mode) + run("wreduce [-memx]"); + else + run(memxmode ? "wreduce -memx" : "wreduce"); + } run("memory_dff" + (help_mode ? " [-nordff]" : memory_opts)); if (help_mode || memxmode) run("memory_memx", "(if -memx)");