mirror of
				https://github.com/YosysHQ/yosys
				synced 2025-10-26 17:29:23 +00:00 
			
		
		
		
	backends/firrtl: Ensure modInstance is valid
				
					
				
			This should fix #3648 where when calling `emit_elaborated_extmodules` it checks to see if a module is a black-box, however there was no validation that the cell type was actually known, and it just always assumed that we would get a valid instance, causing a segfault.
This commit is contained in:
		
							parent
							
								
									221036c5b6
								
							
						
					
					
						commit
						a90f940615
					
				
					 1 changed files with 6 additions and 0 deletions
				
			
		|  | @ -346,6 +346,12 @@ void emit_elaborated_extmodules(RTLIL::Design *design, std::ostream &f) | ||||||
| 			{ | 			{ | ||||||
| 				// Find the module corresponding to this instance.
 | 				// Find the module corresponding to this instance.
 | ||||||
| 				auto modInstance = design->module(cell->type); | 				auto modInstance = design->module(cell->type); | ||||||
|  | 				// Ensure that we actually have a module instance
 | ||||||
|  | 				if (modInstance == nullptr) { | ||||||
|  | 					log_error("Unknown cell type %s\n", cell->type.c_str()); | ||||||
|  | 					return; | ||||||
|  | 				} | ||||||
|  | 
 | ||||||
| 				bool modIsBlackbox = modInstance->get_blackbox_attribute(); | 				bool modIsBlackbox = modInstance->get_blackbox_attribute(); | ||||||
| 
 | 
 | ||||||
| 				if (modIsBlackbox) | 				if (modIsBlackbox) | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue