mirror of
				https://github.com/YosysHQ/yosys
				synced 2025-10-26 17:29:23 +00:00 
			
		
		
		
	Add error for cell output ports that are connected to constants
This commit is contained in:
		
							parent
							
								
									024ba310ec
								
							
						
					
					
						commit
						b6bd12fade
					
				
					 1 changed files with 22 additions and 21 deletions
				
			
		|  | @ -620,34 +620,31 @@ struct HierarchyPass : public Pass { | |||
| 			} | ||||
| 		} | ||||
| 
 | ||||
| 		if (!keep_portwidths) | ||||
| 		for (auto module : design->modules()) | ||||
| 		for (auto cell : module->cells()) | ||||
| 		{ | ||||
| 			for (auto module : design->modules()) | ||||
| 			for (auto cell : module->cells()) | ||||
| 			if (GetSize(cell->parameters) != 0) | ||||
| 				continue; | ||||
| 
 | ||||
| 			Module *m = design->module(cell->type); | ||||
| 
 | ||||
| 			if (m == nullptr || m->get_bool_attribute("\\blackbox")) | ||||
| 				continue; | ||||
| 
 | ||||
| 			for (auto &conn : cell->connections()) | ||||
| 			{ | ||||
| 				if (GetSize(cell->parameters) != 0) | ||||
| 				Wire *w = m->wire(conn.first); | ||||
| 
 | ||||
| 				if (w == nullptr || w->port_id == 0) | ||||
| 					continue; | ||||
| 
 | ||||
| 				Module *m = design->module(cell->type); | ||||
| 
 | ||||
| 				if (m == nullptr || m->get_bool_attribute("\\blackbox")) | ||||
| 				if (GetSize(conn.second) == 0) | ||||
| 					continue; | ||||
| 
 | ||||
| 				for (auto &conn : cell->connections()) | ||||
| 				SigSpec sig = conn.second; | ||||
| 
 | ||||
| 				if (!keep_portwidths && GetSize(w) != GetSize(conn.second)) | ||||
| 				{ | ||||
| 					Wire *w = m->wire(conn.first); | ||||
| 
 | ||||
| 					if (w == nullptr || w->port_id == 0) | ||||
| 						continue; | ||||
| 
 | ||||
| 					if (GetSize(conn.second) == 0) | ||||
| 						continue; | ||||
| 
 | ||||
| 					if (GetSize(w) == GetSize(conn.second)) | ||||
| 						continue; | ||||
| 
 | ||||
| 					SigSpec sig = conn.second; | ||||
| 
 | ||||
| 					if (GetSize(w) < GetSize(conn.second)) | ||||
| 					{ | ||||
| 						int n = GetSize(conn.second) - GetSize(w); | ||||
|  | @ -669,6 +666,10 @@ struct HierarchyPass : public Pass { | |||
| 								log_id(conn.first), GetSize(conn.second), GetSize(sig)); | ||||
| 					cell->setPort(conn.first, sig); | ||||
| 				} | ||||
| 
 | ||||
| 				if (w->port_output && !w->port_input && sig.has_const()) | ||||
| 					log_error("Output port %s.%s.%s (%s) is connected to constants: %s\n", | ||||
| 							log_id(module), log_id(cell), log_id(conn.first), log_id(cell->type), log_signal(sig)); | ||||
| 			} | ||||
| 		} | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue