aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorClifford Wolf <clifford@clifford.at>2019-03-14 18:42:45 +0100
committerGitHub <noreply@github.com>2019-03-14 18:42:45 +0100
commit44a44a06ed0a7489d6d3500c5fddc4a122afffa0 (patch)
tree5702034ed2245a403d2921a8edb35be76ae46a02
parent53b28b3f01b1ccef0cc5ba0af8000c6013d284bb (diff)
parent17caaa3fa898e39d1dbcfd8b92750a9d713a24af (diff)
downloadyosys-44a44a06ed0a7489d6d3500c5fddc4a122afffa0.tar.gz
yosys-44a44a06ed0a7489d6d3500c5fddc4a122afffa0.tar.bz2
yosys-44a44a06ed0a7489d6d3500c5fddc4a122afffa0.zip
Merge pull request #872 from YosysHQ/clifford/pmuxfix
Improve handling of "full_case" attributes
-rw-r--r--backends/ilang/ilang_backend.cc2
-rw-r--r--frontends/ast/genrtlil.cc9
2 files changed, 10 insertions, 1 deletions
diff --git a/backends/ilang/ilang_backend.cc b/backends/ilang/ilang_backend.cc
index 4c58ea087..dc39e5e08 100644
--- a/backends/ilang/ilang_backend.cc
+++ b/backends/ilang/ilang_backend.cc
@@ -204,7 +204,7 @@ void ILANG_BACKEND::dump_proc_switch(std::ostream &f, std::string indent, const
f << stringf("%s case ", indent.c_str());
for (size_t i = 0; i < (*it)->compare.size(); i++) {
if (i > 0)
- f << stringf(", ");
+ f << stringf(" , ");
dump_sigspec(f, (*it)->compare[i]);
}
f << stringf("\n");
diff --git a/frontends/ast/genrtlil.cc b/frontends/ast/genrtlil.cc
index d7da6fb40..b3a2a84be 100644
--- a/frontends/ast/genrtlil.cc
+++ b/frontends/ast/genrtlil.cc
@@ -525,7 +525,16 @@ struct AST_INTERNAL::ProcessGenerator
}
if (last_generated_case != NULL && ast->get_bool_attribute("\\full_case") && default_case == NULL) {
+ #if 0
+ // this is a valid transformation, but as optimization it is premature.
+ // better: add a default case that assigns 'x' to everything, and let later
+ // optimizations take care of the rest
last_generated_case->compare.clear();
+ #else
+ default_case = new RTLIL::CaseRule;
+ addChunkActions(default_case->actions, this_case_eq_ltemp, SigSpec(State::Sx, GetSize(this_case_eq_rvalue)));
+ sw->cases.push_back(default_case);
+ #endif
} else {
if (default_case == NULL) {
default_case = new RTLIL::CaseRule;