diff options
author | Eddie Hung <eddie@fpgeh.com> | 2019-08-16 13:47:37 -0700 |
---|---|---|
committer | Eddie Hung <eddie@fpgeh.com> | 2019-08-16 13:47:37 -0700 |
commit | fab067cecef205ce246904cf122a5e545e348f99 (patch) | |
tree | d1970ac9e0102733fec438b39be2beffb1674225 /passes/opt | |
parent | 51d28645dad159d3526929505b0e444f0127c5cd (diff) | |
download | yosys-fab067cecef205ce246904cf122a5e545e348f99.tar.gz yosys-fab067cecef205ce246904cf122a5e545e348f99.tar.bz2 yosys-fab067cecef205ce246904cf122a5e545e348f99.zip |
Add 'opt_share' to 'opt -full'
Diffstat (limited to 'passes/opt')
-rw-r--r-- | passes/opt/opt.cc | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/passes/opt/opt.cc b/passes/opt/opt.cc index e9a43e0f3..396819883 100644 --- a/passes/opt/opt.cc +++ b/passes/opt/opt.cc @@ -44,6 +44,7 @@ struct OptPass : public Pass { log(" opt_muxtree\n"); log(" opt_reduce [-fine] [-full]\n"); log(" opt_merge [-share_all]\n"); + log(" opt_share (-full only)\n"); log(" opt_rmdff [-keepdc] [-sat]\n"); log(" opt_clean [-purge]\n"); log(" opt_expr [-mux_undef] [-mux_bool] [-undriven] [-clkinv] [-fine] [-full] [-keepdc]\n"); @@ -70,6 +71,7 @@ struct OptPass : public Pass { std::string opt_reduce_args; std::string opt_merge_args; std::string opt_rmdff_args; + bool opt_share = false; bool fast_mode = false; log_header(design, "Executing OPT pass (performing simple optimizations).\n"); @@ -105,6 +107,7 @@ struct OptPass : public Pass { if (args[argidx] == "-full") { opt_expr_args += " -full"; opt_reduce_args += " -full"; + opt_share = true; continue; } if (args[argidx] == "-keepdc") { @@ -151,6 +154,8 @@ struct OptPass : public Pass { Pass::call(design, "opt_muxtree"); Pass::call(design, "opt_reduce" + opt_reduce_args); Pass::call(design, "opt_merge" + opt_merge_args); + if (opt_share) + Pass::call(design, "opt_share"); Pass::call(design, "opt_rmdff" + opt_rmdff_args); Pass::call(design, "opt_clean" + opt_clean_args); Pass::call(design, "opt_expr" + opt_expr_args); |