diff options
| author | Eddie Hung <eddieh@ece.ubc.ca> | 2019-02-19 14:20:04 -0800 | 
|---|---|---|
| committer | Eddie Hung <eddieh@ece.ubc.ca> | 2019-02-19 14:20:04 -0800 | 
| commit | f9af902532bcf44ddd0c5f0f28ac70880e5f2d07 (patch) | |
| tree | 057979f44068605f749b02f357c80e448d129064 /backends/verilog | |
| parent | 8158bc3f9930634462166aac72da96d9c9c1a5e0 (diff) | |
| parent | 2a8e5bf9535a25bba9c9c11fc7e40d5a08958d4c (diff) | |
| download | yosys-f9af902532bcf44ddd0c5f0f28ac70880e5f2d07.tar.gz yosys-f9af902532bcf44ddd0c5f0f28ac70880e5f2d07.tar.bz2 yosys-f9af902532bcf44ddd0c5f0f28ac70880e5f2d07.zip | |
Merge branch 'master' into xaig
Diffstat (limited to 'backends/verilog')
| -rw-r--r-- | backends/verilog/verilog_backend.cc | 31 | 
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) | 
