aboutsummaryrefslogtreecommitdiffstats
path: root/techlibs
diff options
context:
space:
mode:
authorEddie Hung <eddie@fpgeh.com>2019-07-08 21:43:16 -0700
committerGitHub <noreply@github.com>2019-07-08 21:43:16 -0700
commit7f8c420cf78eb41784fc6852524ba33074f84d64 (patch)
treecbeee12303a5d0682d79dc28237f39aca6080080 /techlibs
parent7600ffe4bdf064f71f6380563060f85877ce481e (diff)
parentfccabd09436aae780875fae2d833f58549f38418 (diff)
downloadyosys-7f8c420cf78eb41784fc6852524ba33074f84d64.tar.gz
yosys-7f8c420cf78eb41784fc6852524ba33074f84d64.tar.bz2
yosys-7f8c420cf78eb41784fc6852524ba33074f84d64.zip
Merge pull request #1166 from YosysHQ/eddie/synth_keepdc
Add "synth -keepdc" option
Diffstat (limited to 'techlibs')
-rw-r--r--techlibs/common/synth.cc15
1 files changed, 13 insertions, 2 deletions
diff --git a/techlibs/common/synth.cc b/techlibs/common/synth.cc
index 555de9fba..af70cc498 100644
--- a/techlibs/common/synth.cc
+++ b/techlibs/common/synth.cc
@@ -78,6 +78,9 @@ struct SynthPass : public ScriptPass
log(" -abc9\n");
log(" use new ABC9 flow (EXPERIMENTAL)\n");
log("\n");
+ log(" -keepdc\n");
+ log(" do not optimize explicit don't-care values on $mux cells.\n");
+ log("\n");
log("\n");
log("The following commands are executed by this synthesis command:\n");
help_script();
@@ -85,7 +88,7 @@ struct SynthPass : public ScriptPass
}
string top_module, fsm_opts, memory_opts, abc;
- bool autotop, flatten, noalumacc, nofsm, noabc, noshare;
+ bool autotop, flatten, noalumacc, nofsm, noabc, noshare, keepdc;
int lut;
void clear_flags() YS_OVERRIDE
@@ -102,6 +105,7 @@ struct SynthPass : public ScriptPass
noabc = false;
noshare = false;
abc = "abc";
+ keepdc = false;
}
void execute(std::vector<std::string> args, RTLIL::Design *design) YS_OVERRIDE
@@ -167,6 +171,10 @@ struct SynthPass : public ScriptPass
abc = "abc9";
continue;
}
+ if (args[argidx] == "-keepdc") {
+ keepdc = true;
+ continue;
+ }
break;
}
extra_args(args, argidx, design);
@@ -211,7 +219,10 @@ struct SynthPass : public ScriptPass
run("opt_clean");
run("check");
run("opt");
- run("wreduce");
+ if (help_mode)
+ run("wreduce [-keepdc]");
+ else
+ run("wreduce" + std::string(keepdc ? " -keepdc" : ""));
run("peepopt");
run("opt_clean");
if (help_mode)