aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorEddie Hung <eddieh@ece.ubc.ca>2019-02-17 12:18:12 -0800
committerEddie Hung <eddieh@ece.ubc.ca>2019-02-17 12:18:12 -0800
commit11480b4fa3ba031541e22b52d9ccd658a3e52ff1 (patch)
tree11fe86a3d1c5cd988593782125fc06cd26a98294
parent3d3353e02005883af916b1b1da2c670a29060169 (diff)
downloadyosys-11480b4fa3ba031541e22b52d9ccd658a3e52ff1.tar.gz
yosys-11480b4fa3ba031541e22b52d9ccd658a3e52ff1.tar.bz2
yosys-11480b4fa3ba031541e22b52d9ccd658a3e52ff1.zip
Instead of INIT param on cells, use initial statement with hier ref as
per @cliffordwolf
-rw-r--r--backends/verilog/verilog_backend.cc31
1 files changed, 13 insertions, 18 deletions
diff --git a/backends/verilog/verilog_backend.cc b/backends/verilog/verilog_backend.cc
index 4b5a13941..d351a6266 100644
--- a/backends/verilog/verilog_backend.cc
+++ b/backends/verilog/verilog_backend.cc
@@ -293,7 +293,7 @@ void dump_const(std::ostream &f, const RTLIL::Const &data, int width = -1, int o
}
}
-void dump_reg_init(std::ostream &f, SigSpec sig, bool write_equals = true)
+void dump_reg_init(std::ostream &f, SigSpec sig)
{
Const initval;
bool gotinit = false;
@@ -308,7 +308,7 @@ void dump_reg_init(std::ostream &f, SigSpec sig, bool write_equals = true)
}
if (gotinit) {
- if (write_equals) f << " = ";
+ f << " = ";
dump_const(f, initval);
}
}
@@ -1250,14 +1250,7 @@ void dump_cell(std::ostream &f, std::string indent, RTLIL::Cell *cell)
dump_attributes(f, indent, cell->attributes);
f << stringf("%s" "%s", indent.c_str(), id(cell->type, false).c_str());
- std::string init;
- if (reg_ct.count(cell->type) && cell->hasPort("\\Q")) {
- std::stringstream ss;
- dump_reg_init(ss, cell->getPort("\\Q"), false /* write_equals */);
- init = ss.str();
- }
-
- if (!defparam && (cell->parameters.size() > 0 || !init.empty())) {
+ if (!defparam && cell->parameters.size() > 0) {
f << stringf(" #(");
for (auto it = cell->parameters.begin(); it != cell->parameters.end(); ++it) {
if (it != cell->parameters.begin())
@@ -1267,11 +1260,6 @@ void dump_cell(std::ostream &f, std::string indent, RTLIL::Cell *cell)
dump_const(f, it->second, -1, 0, false, is_signed);
f << stringf(")");
}
- if (!init.empty()) {
- if (!cell->parameters.empty())
- f << stringf(",");
- f << stringf("\n%s .INIT(%s)", indent.c_str(), init.c_str());
- }
f << stringf("\n%s" ")", indent.c_str());
}
@@ -1313,17 +1301,24 @@ void dump_cell(std::ostream &f, std::string indent, RTLIL::Cell *cell)
}
f << stringf("\n%s" ");\n", indent.c_str());
- if (defparam && (cell->parameters.size() > 0 || !init.empty())) {
+ if (defparam && cell->parameters.size() > 0) {
for (auto it = cell->parameters.begin(); it != cell->parameters.end(); ++it) {
f << stringf("%sdefparam %s.%s = ", indent.c_str(), cell_name.c_str(), id(it->first).c_str());
bool is_signed = (it->second.flags & RTLIL::CONST_FLAG_SIGNED) != 0;
dump_const(f, it->second, -1, 0, false, is_signed);
f << stringf(";\n");
}
- if (!init.empty())
- f << stringf("%sdefparam %s.INIT = %s;\n", indent.c_str(), cell_name.c_str(), init.c_str());
}
+ if (reg_ct.count(cell->type) && cell->hasPort("\\Q")) {
+ std::stringstream ss;
+ dump_reg_init(ss, cell->getPort("\\Q"));
+ if (!ss.str().empty()) {
+ f << stringf("%sinitial %s.Q", indent.c_str(), cell_name.c_str());
+ f << ss.str();
+ f << ";\n";
+ }
+ }
}
void dump_conn(std::ostream &f, std::string indent, const RTLIL::SigSpec &left, const RTLIL::SigSpec &right)