mirror of
				https://github.com/YosysHQ/yosys
				synced 2025-10-26 17:29:23 +00:00 
			
		
		
		
	Replaced signed_parameters API with CONST_FLAG_SIGNED
This commit is contained in:
		
							parent
							
								
									93a70959f3
								
							
						
					
					
						commit
						f4b46ed31e
					
				
					 10 changed files with 11 additions and 16 deletions
				
			
		|  | @ -158,7 +158,7 @@ void ILANG_BACKEND::dump_cell(FILE *f, std::string indent, const RTLIL::Cell *ce | |||
| 	} | ||||
| 	fprintf(f, "%s" "cell %s %s\n", indent.c_str(), cell->type.c_str(), cell->name.c_str()); | ||||
| 	for (auto it = cell->parameters.begin(); it != cell->parameters.end(); it++) { | ||||
| 		fprintf(f, "%s  parameter%s %s ", indent.c_str(), cell->signed_parameters.count(it->first) ? " signed" : "", it->first.c_str()); | ||||
| 		fprintf(f, "%s  parameter%s %s ", indent.c_str(), (it->second.flags & RTLIL::CONST_FLAG_SIGNED) != 0 ? " signed" : "", it->first.c_str()); | ||||
| 		dump_const(f, it->second); | ||||
| 		fprintf(f, "\n"); | ||||
| 	} | ||||
|  |  | |||
|  | @ -642,7 +642,7 @@ void dump_cell(FILE *f, std::string indent, RTLIL::Cell *cell) | |||
| 			if (it != cell->parameters.begin()) | ||||
| 				fprintf(f, ","); | ||||
| 			fprintf(f, "\n%s  .%s(", indent.c_str(), id(it->first).c_str()); | ||||
| 			bool is_signed = cell->signed_parameters.count(it->first) > 0; | ||||
| 			bool is_signed = (it->second.flags & RTLIL::CONST_FLAG_SIGNED) != 0; | ||||
| 			dump_const(f, it->second, -1, 0, !is_signed, is_signed); | ||||
| 			fprintf(f, ")"); | ||||
| 		} | ||||
|  |  | |||
|  | @ -819,7 +819,7 @@ AstModule::~AstModule() | |||
| } | ||||
| 
 | ||||
| // create a new parametric module (when needed) and return the name of the generated module
 | ||||
| RTLIL::IdString AstModule::derive(RTLIL::Design *design, std::map<RTLIL::IdString, RTLIL::Const> parameters, std::set<RTLIL::IdString> signed_parameters) | ||||
| RTLIL::IdString AstModule::derive(RTLIL::Design *design, std::map<RTLIL::IdString, RTLIL::Const> parameters) | ||||
| { | ||||
| 	log_header("Executing AST frontend in derive mode using pre-parsed AST for module `%s'.\n", name.c_str()); | ||||
| 
 | ||||
|  | @ -853,7 +853,7 @@ RTLIL::IdString AstModule::derive(RTLIL::Design *design, std::map<RTLIL::IdStrin | |||
| 	rewrite_parameter: | ||||
| 			para_info += stringf("%s=%s", child->str.c_str(), log_signal(RTLIL::SigSpec(parameters[para_id]))); | ||||
| 			delete child->children.at(0); | ||||
| 			child->children[0] = AstNode::mkconst_bits(parameters[para_id].bits, signed_parameters.count(para_id) > 0); | ||||
| 			child->children[0] = AstNode::mkconst_bits(parameters[para_id].bits, (parameters[para_id].flags & RTLIL::CONST_FLAG_SIGNED) != 0); | ||||
| 			hash_data.insert(hash_data.end(), child->str.begin(), child->str.end()); | ||||
| 			hash_data.push_back(0); | ||||
| 			hash_data.insert(hash_data.end(), parameters[para_id].bits.begin(), parameters[para_id].bits.end()); | ||||
|  |  | |||
|  | @ -229,7 +229,7 @@ namespace AST | |||
| 		AstNode *ast; | ||||
| 		bool nolatches, nomem2reg, mem2reg, lib, noopt; | ||||
| 		virtual ~AstModule(); | ||||
| 		virtual RTLIL::IdString derive(RTLIL::Design *design, std::map<RTLIL::IdString, RTLIL::Const> parameters, std::set<RTLIL::IdString> signed_parameters); | ||||
| 		virtual RTLIL::IdString derive(RTLIL::Design *design, std::map<RTLIL::IdString, RTLIL::Const> parameters); | ||||
| 		virtual RTLIL::Module *clone() const; | ||||
| 	}; | ||||
| 
 | ||||
|  |  | |||
|  | @ -1304,12 +1304,8 @@ RTLIL::SigSpec AstNode::genRTLIL(int width_hint, bool sign_hint) | |||
| 					if (child->str.size() == 0) { | ||||
| 						char buf[100]; | ||||
| 						snprintf(buf, 100, "$%d", ++para_counter); | ||||
| 						if (child->children[0]->is_signed) | ||||
| 							cell->signed_parameters.insert(buf); | ||||
| 						cell->parameters[buf] = child->children[0]->asParaConst(); | ||||
| 					} else { | ||||
| 						if (child->children[0]->is_signed) | ||||
| 							cell->signed_parameters.insert(child->str); | ||||
| 						cell->parameters[child->str] = child->children[0]->asParaConst(); | ||||
| 					} | ||||
| 					continue; | ||||
|  |  | |||
|  | @ -191,7 +191,7 @@ cell_body: | |||
| 	} | | ||||
| 	cell_body TOK_PARAMETER TOK_SIGNED TOK_ID constant TOK_EOL { | ||||
| 		current_cell->parameters[$4] = *$5; | ||||
| 		current_cell->signed_parameters.insert($4); | ||||
| 		current_cell->parameters[$4].flags |= RTLIL::CONST_FLAG_SIGNED; | ||||
| 		free($4); | ||||
| 		delete $5; | ||||
| 	} | | ||||
|  |  | |||
|  | @ -285,7 +285,7 @@ RTLIL::Module::~Module() | |||
| 		delete it->second; | ||||
| } | ||||
| 
 | ||||
| RTLIL::IdString RTLIL::Module::derive(RTLIL::Design*, std::map<RTLIL::IdString, RTLIL::Const>, std::set<RTLIL::IdString>) | ||||
| RTLIL::IdString RTLIL::Module::derive(RTLIL::Design*, std::map<RTLIL::IdString, RTLIL::Const>) | ||||
| { | ||||
| 	log_error("Module `%s' is used with parameters but is not parametric!\n", id2cstr(name)); | ||||
| } | ||||
|  |  | |||
|  | @ -52,7 +52,7 @@ namespace RTLIL | |||
| 	enum ConstFlags { | ||||
| 		CONST_FLAG_NONE   = 0, | ||||
| 		CONST_FLAG_STRING = 1, | ||||
| 		CONST_FLAG_SIGNED = 2,  // unused -- to be used for parameters
 | ||||
| 		CONST_FLAG_SIGNED = 2,  // only used for parameters
 | ||||
| 		CONST_FLAG_REAL   = 4   // unused -- to be used for parameters
 | ||||
| 	}; | ||||
| 
 | ||||
|  | @ -275,7 +275,7 @@ struct RTLIL::Module { | |||
| 	std::vector<RTLIL::SigSig> connections; | ||||
| 	RTLIL_ATTRIBUTE_MEMBERS | ||||
| 	virtual ~Module(); | ||||
| 	virtual RTLIL::IdString derive(RTLIL::Design *design, std::map<RTLIL::IdString, RTLIL::Const> parameters, std::set<RTLIL::IdString> signed_parameters); | ||||
| 	virtual RTLIL::IdString derive(RTLIL::Design *design, std::map<RTLIL::IdString, RTLIL::Const> parameters); | ||||
| 	virtual size_t count_id(RTLIL::IdString id); | ||||
| 	virtual void check(); | ||||
| 	virtual void optimize(); | ||||
|  | @ -310,7 +310,6 @@ struct RTLIL::Cell { | |||
| 	RTLIL::IdString type; | ||||
| 	std::map<RTLIL::IdString, RTLIL::SigSpec> connections; | ||||
| 	std::map<RTLIL::IdString, RTLIL::Const> parameters; | ||||
| 	std::set<RTLIL::IdString> signed_parameters; | ||||
| 	RTLIL_ATTRIBUTE_MEMBERS | ||||
| 	void optimize(); | ||||
| 
 | ||||
|  |  | |||
|  | @ -150,7 +150,7 @@ static bool expand_module(RTLIL::Design *design, RTLIL::Module *module, bool fla | |||
| 		if (design->modules.at(cell->type)->get_bool_attribute("\\blackbox")) | ||||
| 			continue; | ||||
| 		RTLIL::Module *mod = design->modules[cell->type]; | ||||
| 		cell->type = mod->derive(design, cell->parameters, cell->signed_parameters); | ||||
| 		cell->type = mod->derive(design, cell->parameters); | ||||
| 		cell->parameters.clear(); | ||||
| 		did_something = true; | ||||
| 	} | ||||
|  |  | |||
|  | @ -259,7 +259,7 @@ static bool techmap_module(RTLIL::Design *design, RTLIL::Module *module, RTLIL:: | |||
| 				tpl = techmap_cache[key]; | ||||
| 			} else { | ||||
| 				if (cell->parameters.size() != 0) { | ||||
| 					derived_name = tpl->derive(map, parameters, cell->signed_parameters); | ||||
| 					derived_name = tpl->derive(map, parameters); | ||||
| 					tpl = map->modules[derived_name]; | ||||
| 					log_continue = true; | ||||
| 				} | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue