mirror of
				https://github.com/YosysHQ/yosys
				synced 2025-10-26 17:29:23 +00:00 
			
		
		
		
	Minor fixes in handling of "init" attribute
This commit is contained in:
		
							parent
							
								
									229825e1b8
								
							
						
					
					
						commit
						d176e613c2
					
				
					 2 changed files with 12 additions and 7 deletions
				
			
		|  | @ -295,15 +295,15 @@ void dump_wire(std::ostream &f, std::string indent, RTLIL::Wire *wire) | |||
| 		f << stringf("%s" "output%s %s;\n", indent.c_str(), range.c_str(), id(wire->name).c_str()); | ||||
| 	if (wire->port_input && wire->port_output) | ||||
| 		f << stringf("%s" "inout%s %s;\n", indent.c_str(), range.c_str(), id(wire->name).c_str()); | ||||
| 	if (reg_wires.count(wire->name)) | ||||
| 	if (reg_wires.count(wire->name)) { | ||||
| 		f << stringf("%s" "reg%s %s;\n", indent.c_str(), range.c_str(), id(wire->name).c_str()); | ||||
| 	else if (!wire->port_input && !wire->port_output) | ||||
| 		f << stringf("%s" "wire%s %s;\n", indent.c_str(), range.c_str(), id(wire->name).c_str()); | ||||
| 		if (wire->attributes.count("\\init")) { | ||||
| 			f << stringf("%s" "initial %s = ", indent.c_str(), id(wire->name).c_str()); | ||||
| 			dump_const(f, wire->attributes.at("\\init")); | ||||
| 			f << stringf(";\n"); | ||||
| 		} | ||||
| 	} else if (!wire->port_input && !wire->port_output) | ||||
| 		f << stringf("%s" "wire%s %s;\n", indent.c_str(), range.c_str(), id(wire->name).c_str()); | ||||
| #endif | ||||
| } | ||||
| 
 | ||||
|  |  | |||
|  | @ -244,6 +244,7 @@ struct ProcArstPass : public Pass { | |||
| 		} | ||||
| 
 | ||||
| 		extra_args(args, argidx, design); | ||||
| 		pool<Wire*> delete_initattr_wires; | ||||
| 
 | ||||
| 		for (auto mod : design->modules()) | ||||
| 			if (design->selected(mod)) { | ||||
|  | @ -265,6 +266,7 @@ struct ProcArstPass : public Pass { | |||
| 										value.extend_u0(chunk.wire->width, false); | ||||
| 										arst_sig.append(chunk); | ||||
| 										arst_val.append(value.extract(chunk.offset, chunk.width)); | ||||
| 										delete_initattr_wires.insert(chunk.wire); | ||||
| 									} | ||||
| 								if (arst_sig.size()) { | ||||
| 									log("Added global reset to process %s: %s <- %s\n", | ||||
|  | @ -281,6 +283,9 @@ struct ProcArstPass : public Pass { | |||
| 					} | ||||
| 				} | ||||
| 			} | ||||
| 
 | ||||
| 		for (auto wire : delete_initattr_wires) | ||||
| 			wire->attributes.erase("\\init"); | ||||
| 	} | ||||
| } ProcArstPass; | ||||
|   | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue