mirror of
				https://github.com/YosysHQ/yosys
				synced 2025-11-04 13:29:12 +00:00 
			
		
		
		
	Instead of INIT param on cells, use initial statement with hier ref as
per @cliffordwolf
This commit is contained in:
		
							parent
							
								
									3d3353e020
								
							
						
					
					
						commit
						11480b4fa3
					
				
					 1 changed files with 13 additions and 18 deletions
				
			
		| 
						 | 
					@ -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;
 | 
						Const initval;
 | 
				
			||||||
	bool gotinit = false;
 | 
						bool gotinit = false;
 | 
				
			||||||
| 
						 | 
					@ -308,7 +308,7 @@ void dump_reg_init(std::ostream &f, SigSpec sig, bool write_equals = true)
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (gotinit) {
 | 
						if (gotinit) {
 | 
				
			||||||
		if (write_equals) f << " = ";
 | 
							f << " = ";
 | 
				
			||||||
		dump_const(f, initval);
 | 
							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);
 | 
						dump_attributes(f, indent, cell->attributes);
 | 
				
			||||||
	f << stringf("%s" "%s", indent.c_str(), id(cell->type, false).c_str());
 | 
						f << stringf("%s" "%s", indent.c_str(), id(cell->type, false).c_str());
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	std::string init;
 | 
						if (!defparam && cell->parameters.size() > 0) {
 | 
				
			||||||
	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())) {
 | 
					 | 
				
			||||||
		f << stringf(" #(");
 | 
							f << stringf(" #(");
 | 
				
			||||||
		for (auto it = cell->parameters.begin(); it != cell->parameters.end(); ++it) {
 | 
							for (auto it = cell->parameters.begin(); it != cell->parameters.end(); ++it) {
 | 
				
			||||||
			if (it != cell->parameters.begin())
 | 
								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);
 | 
								dump_const(f, it->second, -1, 0, false, is_signed);
 | 
				
			||||||
			f << stringf(")");
 | 
								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());
 | 
							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());
 | 
						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) {
 | 
							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());
 | 
								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;
 | 
								bool is_signed = (it->second.flags & RTLIL::CONST_FLAG_SIGNED) != 0;
 | 
				
			||||||
			dump_const(f, it->second, -1, 0, false, is_signed);
 | 
								dump_const(f, it->second, -1, 0, false, is_signed);
 | 
				
			||||||
			f << stringf(";\n");
 | 
								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)
 | 
					void dump_conn(std::ostream &f, std::string indent, const RTLIL::SigSpec &left, const RTLIL::SigSpec &right)
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue