mirror of
				https://github.com/YosysHQ/yosys
				synced 2025-10-26 17:29:23 +00:00 
			
		
		
		
	Adjust buf-normalized mode
This commit is contained in:
		
							parent
							
								
									80119386c0
								
							
						
					
					
						commit
						865df26fac
					
				
					 5 changed files with 49 additions and 37 deletions
				
			
		|  | @ -118,16 +118,16 @@ void RTLIL_BACKEND::dump_sigspec(std::ostream &f, const RTLIL::SigSpec &sig, boo | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void RTLIL_BACKEND::dump_wire(std::ostream &f, std::string indent, const RTLIL::Wire *wire, bool flag_d) | void RTLIL_BACKEND::dump_wire(std::ostream &f, std::string indent, const RTLIL::Wire *wire) | ||||||
| { | { | ||||||
| 	for (auto &it : wire->attributes) { | 	for (auto &it : wire->attributes) { | ||||||
| 		f << stringf("%s" "attribute %s ", indent.c_str(), it.first.c_str()); | 		f << stringf("%s" "attribute %s ", indent.c_str(), it.first.c_str()); | ||||||
| 		dump_const(f, it.second); | 		dump_const(f, it.second); | ||||||
| 		f << stringf("\n"); | 		f << stringf("\n"); | ||||||
| 	} | 	} | ||||||
| 	if (flag_d && wire->driverCell) { | 	if (wire->driverCell_) { | ||||||
| 		f << stringf("%s" "driver %s %s\n", indent.c_str(), | 		f << stringf("%s" "# driver %s %s\n", indent.c_str(), | ||||||
| 				wire->driverCell->name.c_str(), wire->driverPort.c_str()); | 				wire->driverCell()->name.c_str(), wire->driverPort().c_str()); | ||||||
| 	} | 	} | ||||||
| 	f << stringf("%s" "wire ", indent.c_str()); | 	f << stringf("%s" "wire ", indent.c_str()); | ||||||
| 	if (wire->width != 1) | 	if (wire->width != 1) | ||||||
|  | @ -302,7 +302,7 @@ void RTLIL_BACKEND::dump_conn(std::ostream &f, std::string indent, const RTLIL:: | ||||||
| 	f << stringf("\n"); | 	f << stringf("\n"); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void RTLIL_BACKEND::dump_module(std::ostream &f, std::string indent, RTLIL::Module *module, RTLIL::Design *design, bool only_selected, bool flag_m, bool flag_n, bool flag_d) | void RTLIL_BACKEND::dump_module(std::ostream &f, std::string indent, RTLIL::Module *module, RTLIL::Design *design, bool only_selected, bool flag_m, bool flag_n) | ||||||
| { | { | ||||||
| 	bool print_header = flag_m || design->selected_whole_module(module->name); | 	bool print_header = flag_m || design->selected_whole_module(module->name); | ||||||
| 	bool print_body = !flag_n || !design->selected_whole_module(module->name); | 	bool print_body = !flag_n || !design->selected_whole_module(module->name); | ||||||
|  | @ -339,7 +339,7 @@ void RTLIL_BACKEND::dump_module(std::ostream &f, std::string indent, RTLIL::Modu | ||||||
| 			if (!only_selected || design->selected(module, it)) { | 			if (!only_selected || design->selected(module, it)) { | ||||||
| 				if (only_selected) | 				if (only_selected) | ||||||
| 					f << stringf("\n"); | 					f << stringf("\n"); | ||||||
| 				dump_wire(f, indent + "  ", it, flag_d); | 				dump_wire(f, indent + "  ", it); | ||||||
| 			} | 			} | ||||||
| 
 | 
 | ||||||
| 		for (auto it : module->memories) | 		for (auto it : module->memories) | ||||||
|  | @ -388,7 +388,7 @@ void RTLIL_BACKEND::dump_module(std::ostream &f, std::string indent, RTLIL::Modu | ||||||
| 		f << stringf("%s" "end\n", indent.c_str()); | 		f << stringf("%s" "end\n", indent.c_str()); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void RTLIL_BACKEND::dump_design(std::ostream &f, RTLIL::Design *design, bool only_selected, bool flag_m, bool flag_n, bool flag_d) | void RTLIL_BACKEND::dump_design(std::ostream &f, RTLIL::Design *design, bool only_selected, bool flag_m, bool flag_n) | ||||||
| { | { | ||||||
| 	int init_autoidx = autoidx; | 	int init_autoidx = autoidx; | ||||||
| 
 | 
 | ||||||
|  | @ -414,7 +414,7 @@ void RTLIL_BACKEND::dump_design(std::ostream &f, RTLIL::Design *design, bool onl | ||||||
| 		if (!only_selected || design->selected(module)) { | 		if (!only_selected || design->selected(module)) { | ||||||
| 			if (only_selected) | 			if (only_selected) | ||||||
| 				f << stringf("\n"); | 				f << stringf("\n"); | ||||||
| 			dump_module(f, "", module, design, only_selected, flag_m, flag_n, flag_d); | 			dump_module(f, "", module, design, only_selected, flag_m, flag_n); | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | @ -460,7 +460,7 @@ struct RTLILBackend : public Backend { | ||||||
| 
 | 
 | ||||||
| 		log("Output filename: %s\n", filename.c_str()); | 		log("Output filename: %s\n", filename.c_str()); | ||||||
| 		*f << stringf("# Generated by %s\n", yosys_version_str); | 		*f << stringf("# Generated by %s\n", yosys_version_str); | ||||||
| 		RTLIL_BACKEND::dump_design(*f, design, selected, true, false, false); | 		RTLIL_BACKEND::dump_design(*f, design, selected, true, false); | ||||||
| 	} | 	} | ||||||
| } RTLILBackend; | } RTLILBackend; | ||||||
| 
 | 
 | ||||||
|  | @ -510,7 +510,7 @@ struct DumpPass : public Pass { | ||||||
| 	void execute(std::vector<std::string> args, RTLIL::Design *design) override | 	void execute(std::vector<std::string> args, RTLIL::Design *design) override | ||||||
| 	{ | 	{ | ||||||
| 		std::string filename; | 		std::string filename; | ||||||
| 		bool flag_m = false, flag_n = false, flag_d = false, append = false; | 		bool flag_m = false, flag_n = false, append = false; | ||||||
| 
 | 
 | ||||||
| 		size_t argidx; | 		size_t argidx; | ||||||
| 		for (argidx = 1; argidx < args.size(); argidx++) | 		for (argidx = 1; argidx < args.size(); argidx++) | ||||||
|  | @ -534,10 +534,6 @@ struct DumpPass : public Pass { | ||||||
| 				flag_n = true; | 				flag_n = true; | ||||||
| 				continue; | 				continue; | ||||||
| 			} | 			} | ||||||
| 			if (arg == "-d") { |  | ||||||
| 				flag_d = true; |  | ||||||
| 				continue; |  | ||||||
| 			} |  | ||||||
| 			break; | 			break; | ||||||
| 		} | 		} | ||||||
| 		extra_args(args, argidx, design); | 		extra_args(args, argidx, design); | ||||||
|  | @ -559,7 +555,7 @@ struct DumpPass : public Pass { | ||||||
| 			f = &buf; | 			f = &buf; | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		RTLIL_BACKEND::dump_design(*f, design, true, flag_m, flag_n, flag_d); | 		RTLIL_BACKEND::dump_design(*f, design, true, flag_m, flag_n); | ||||||
| 
 | 
 | ||||||
| 		if (!empty) { | 		if (!empty) { | ||||||
| 			delete f; | 			delete f; | ||||||
|  |  | ||||||
|  | @ -34,7 +34,7 @@ namespace RTLIL_BACKEND { | ||||||
| 	void dump_const(std::ostream &f, const RTLIL::Const &data, int width = -1, int offset = 0, bool autoint = true); | 	void dump_const(std::ostream &f, const RTLIL::Const &data, int width = -1, int offset = 0, bool autoint = true); | ||||||
| 	void dump_sigchunk(std::ostream &f, const RTLIL::SigChunk &chunk, bool autoint = true); | 	void dump_sigchunk(std::ostream &f, const RTLIL::SigChunk &chunk, bool autoint = true); | ||||||
| 	void dump_sigspec(std::ostream &f, const RTLIL::SigSpec &sig, bool autoint = true); | 	void dump_sigspec(std::ostream &f, const RTLIL::SigSpec &sig, bool autoint = true); | ||||||
| 	void dump_wire(std::ostream &f, std::string indent, const RTLIL::Wire *wire, bool flag_d = false); | 	void dump_wire(std::ostream &f, std::string indent, const RTLIL::Wire *wire); | ||||||
| 	void dump_memory(std::ostream &f, std::string indent, const RTLIL::Memory *memory); | 	void dump_memory(std::ostream &f, std::string indent, const RTLIL::Memory *memory); | ||||||
| 	void dump_cell(std::ostream &f, std::string indent, const RTLIL::Cell *cell); | 	void dump_cell(std::ostream &f, std::string indent, const RTLIL::Cell *cell); | ||||||
| 	void dump_proc_case_body(std::ostream &f, std::string indent, const RTLIL::CaseRule *cs); | 	void dump_proc_case_body(std::ostream &f, std::string indent, const RTLIL::CaseRule *cs); | ||||||
|  | @ -42,8 +42,8 @@ namespace RTLIL_BACKEND { | ||||||
| 	void dump_proc_sync(std::ostream &f, std::string indent, const RTLIL::SyncRule *sy); | 	void dump_proc_sync(std::ostream &f, std::string indent, const RTLIL::SyncRule *sy); | ||||||
| 	void dump_proc(std::ostream &f, std::string indent, const RTLIL::Process *proc); | 	void dump_proc(std::ostream &f, std::string indent, const RTLIL::Process *proc); | ||||||
| 	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); | ||||||
| 	void dump_module(std::ostream &f, std::string indent, RTLIL::Module *module, RTLIL::Design *design, bool only_selected, bool flag_m = true, bool flag_n = false, bool flag_d = false); | 	void dump_module(std::ostream &f, std::string indent, RTLIL::Module *module, RTLIL::Design *design, bool only_selected, bool flag_m = true, bool flag_n = false); | ||||||
| 	void dump_design(std::ostream &f, RTLIL::Design *design, bool only_selected, bool flag_m = true, bool flag_n = false, bool flag_d = false); | 	void dump_design(std::ostream &f, RTLIL::Design *design, bool only_selected, bool flag_m = true, bool flag_n = false); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| YOSYS_NAMESPACE_END | YOSYS_NAMESPACE_END | ||||||
|  |  | ||||||
|  | @ -24,7 +24,7 @@ PRIVATE_NAMESPACE_BEGIN | ||||||
| 
 | 
 | ||||||
| void bitwise_unary_op(AbstractCellEdgesDatabase *db, RTLIL::Cell *cell) | void bitwise_unary_op(AbstractCellEdgesDatabase *db, RTLIL::Cell *cell) | ||||||
| { | { | ||||||
| 	bool is_signed = cell->getParam(ID::A_SIGNED).as_bool(); | 	bool is_signed = (cell->type != ID($buf)) && cell->getParam(ID::A_SIGNED).as_bool(); | ||||||
| 	int a_width = GetSize(cell->getPort(ID::A)); | 	int a_width = GetSize(cell->getPort(ID::A)); | ||||||
| 	int y_width = GetSize(cell->getPort(ID::Y)); | 	int y_width = GetSize(cell->getPort(ID::Y)); | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -3575,10 +3575,12 @@ void RTLIL::Design::bufNormalize(bool enable) | ||||||
| 		for (auto module : modules()) { | 		for (auto module : modules()) { | ||||||
| 			module->bufNormQueue.clear(); | 			module->bufNormQueue.clear(); | ||||||
| 			for (auto wire : module->wires()) { | 			for (auto wire : module->wires()) { | ||||||
| 				wire->driverCell = nullptr; | 				wire->driverCell_ = nullptr; | ||||||
| 				wire->driverPort = IdString(); | 				wire->driverPort_ = IdString(); | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
|  | 
 | ||||||
|  | 		flagBufferedNormalized = false; | ||||||
| 		return; | 		return; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | @ -3592,9 +3594,9 @@ void RTLIL::Design::bufNormalize(bool enable) | ||||||
| 					continue; | 					continue; | ||||||
| 				if (conn.second.is_wire()) { | 				if (conn.second.is_wire()) { | ||||||
| 					Wire *wire = conn.second.as_wire(); | 					Wire *wire = conn.second.as_wire(); | ||||||
| 					log_assert(wire->driverCell == nullptr); | 					log_assert(wire->driverCell_ == nullptr); | ||||||
| 					wire->driverCell = cell; | 					wire->driverCell_ = cell; | ||||||
| 					wire->driverPort = conn.first; | 					wire->driverPort_ = conn.first; | ||||||
| 				} else { | 				} else { | ||||||
| 					pair<RTLIL::Cell*, RTLIL::IdString> key(cell, conn.first); | 					pair<RTLIL::Cell*, RTLIL::IdString> key(cell, conn.first); | ||||||
| 					module->bufNormQueue.insert(key); | 					module->bufNormQueue.insert(key); | ||||||
|  | @ -3614,7 +3616,7 @@ void RTLIL::Module::bufNormalize() | ||||||
| 	if (!design->flagBufferedNormalized) | 	if (!design->flagBufferedNormalized) | ||||||
| 		return; | 		return; | ||||||
| 
 | 
 | ||||||
| 	while (GetSize(bufNormQueue)) | 	while (GetSize(bufNormQueue) || !connections_.empty()) | ||||||
| 	{ | 	{ | ||||||
| 		pool<pair<RTLIL::Cell*, RTLIL::IdString>> queue; | 		pool<pair<RTLIL::Cell*, RTLIL::IdString>> queue; | ||||||
| 		bufNormQueue.swap(queue); | 		bufNormQueue.swap(queue); | ||||||
|  | @ -3636,9 +3638,13 @@ void RTLIL::Module::bufNormalize() | ||||||
| 
 | 
 | ||||||
| 			if (sig.is_wire()) { | 			if (sig.is_wire()) { | ||||||
| 				Wire *wire = sig.as_wire(); | 				Wire *wire = sig.as_wire(); | ||||||
| 				log_assert(wire->driverCell == nullptr); | 				if (wire->driverCell_) { | ||||||
| 				wire->driverCell = cell; | 					log_error("Conflict between %s %s in module %s\n", | ||||||
| 				wire->driverPort = portname; | 										log_id(cell), log_id(wire->driverCell_), log_id(this)); | ||||||
|  | 				} | ||||||
|  | 				log_assert(wire->driverCell_ == nullptr); | ||||||
|  | 				wire->driverCell_ = cell; | ||||||
|  | 				wire->driverPort_ = portname; | ||||||
| 				continue; | 				continue; | ||||||
| 			} | 			} | ||||||
| 
 | 
 | ||||||
|  | @ -3688,9 +3694,9 @@ void RTLIL::Cell::setPort(const RTLIL::IdString& portname, RTLIL::SigSpec signal | ||||||
| 
 | 
 | ||||||
| 		if (conn_it->second.is_wire()) { | 		if (conn_it->second.is_wire()) { | ||||||
| 			Wire *w = conn_it->second.as_wire(); | 			Wire *w = conn_it->second.as_wire(); | ||||||
| 			if (w->driverCell == this && w->driverPort == portname) { | 			if (w->driverCell_ == this && w->driverPort_ == portname) { | ||||||
| 				w->driverCell = nullptr; | 				w->driverCell_ = nullptr; | ||||||
| 				w->driverPort = IdString(); | 				w->driverPort_ = IdString(); | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
|  | @ -3705,12 +3711,12 @@ void RTLIL::Cell::setPort(const RTLIL::IdString& portname, RTLIL::SigSpec signal | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		Wire *w = signal.as_wire(); | 		Wire *w = signal.as_wire(); | ||||||
| 		if (w->driverCell != nullptr) { | 		if (w->driverCell_ != nullptr) { | ||||||
| 			pair<RTLIL::Cell*, RTLIL::IdString> other_key(w->driverCell, w->driverPort); | 			pair<RTLIL::Cell*, RTLIL::IdString> other_key(w->driverCell_, w->driverPort_); | ||||||
| 			module->bufNormQueue.insert(other_key); | 			module->bufNormQueue.insert(other_key); | ||||||
| 		} | 		} | ||||||
| 		w->driverCell = this; | 		w->driverCell_ = this; | ||||||
| 		w->driverPort = portname; | 		w->driverPort_ = portname; | ||||||
| 
 | 
 | ||||||
| 		module->bufNormQueue.erase(key); | 		module->bufNormQueue.erase(key); | ||||||
| 		break; | 		break; | ||||||
|  |  | ||||||
|  | @ -1510,6 +1510,10 @@ public: | ||||||
| #endif | #endif | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | namespace RTLIL_BACKEND { | ||||||
|  | void dump_wire(std::ostream &f, std::string indent, const RTLIL::Wire *wire); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| struct RTLIL::Wire : public RTLIL::AttrObject | struct RTLIL::Wire : public RTLIL::AttrObject | ||||||
| { | { | ||||||
| 	unsigned int hashidx_; | 	unsigned int hashidx_; | ||||||
|  | @ -1521,6 +1525,12 @@ protected: | ||||||
| 	Wire(); | 	Wire(); | ||||||
| 	~Wire(); | 	~Wire(); | ||||||
| 
 | 
 | ||||||
|  | 	friend struct RTLIL::Design; | ||||||
|  | 	friend struct RTLIL::Cell; | ||||||
|  | 	friend void RTLIL_BACKEND::dump_wire(std::ostream &f, std::string indent, const RTLIL::Wire *wire); | ||||||
|  | 	RTLIL::Cell *driverCell_ = nullptr; | ||||||
|  | 	RTLIL::IdString driverPort_; | ||||||
|  | 
 | ||||||
| public: | public: | ||||||
| 	// do not simply copy wires
 | 	// do not simply copy wires
 | ||||||
| 	Wire(RTLIL::Wire &other) = delete; | 	Wire(RTLIL::Wire &other) = delete; | ||||||
|  | @ -1531,8 +1541,8 @@ public: | ||||||
| 	int width, start_offset, port_id; | 	int width, start_offset, port_id; | ||||||
| 	bool port_input, port_output, upto, is_signed; | 	bool port_input, port_output, upto, is_signed; | ||||||
| 
 | 
 | ||||||
| 	RTLIL::Cell *driverCell = nullptr; | 	RTLIL::Cell *driverCell() const    { log_assert(driverCell_); return driverCell_; }; | ||||||
| 	RTLIL::IdString driverPort; | 	RTLIL::IdString driverPort() const { log_assert(driverCell_); return driverPort_; }; | ||||||
| 
 | 
 | ||||||
| #ifdef WITH_PYTHON | #ifdef WITH_PYTHON | ||||||
| 	static std::map<unsigned int, RTLIL::Wire*> *get_all_wires(void); | 	static std::map<unsigned int, RTLIL::Wire*> *get_all_wires(void); | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue