mirror of
				https://github.com/YosysHQ/yosys
				synced 2025-10-26 17:29:23 +00:00 
			
		
		
		
	Fine tune aigerparse
This commit is contained in:
		
							parent
							
								
									1e201a9b01
								
							
						
					
					
						commit
						5a46a0b385
					
				
					 2 changed files with 32 additions and 63 deletions
				
			
		|  | @ -85,21 +85,10 @@ end_of_header: | |||
| 	else | ||||
| 		log_abort(); | ||||
| 
 | ||||
| 	RTLIL::Wire* n0 = module->wire("\\n0"); | ||||
| 	RTLIL::Wire* n0 = module->wire("\\__0__"); | ||||
| 	if (n0) | ||||
| 		module->connect(n0, RTLIL::S0); | ||||
| 
 | ||||
| 	for (unsigned i = 0; i < outputs.size(); ++i) { | ||||
| 		RTLIL::Wire *wire = outputs[i]; | ||||
| 		if (wire->port_input) { | ||||
| 			RTLIL::Wire *o_wire = module->addWire(wire->name.str() + "_o"); | ||||
| 			o_wire->port_output = true; | ||||
| 			wire->port_output = false; | ||||
| 			module->connect(o_wire, wire); | ||||
| 			outputs[i] = o_wire; | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	// Parse footer (symbol table, comments, etc.)
 | ||||
| 	unsigned l1; | ||||
| 	std::string s; | ||||
|  | @ -212,6 +201,10 @@ void AigerReader::parse_xaiger() | |||
| 	else | ||||
| 		log_abort(); | ||||
| 
 | ||||
| 	RTLIL::Wire* n0 = module->wire("\\__0__"); | ||||
| 	if (n0) | ||||
| 		module->connect(n0, RTLIL::S0); | ||||
| 
 | ||||
| 	dict<int,IdString> box_lookup; | ||||
| 	for (auto m : design->modules()) { | ||||
| 		auto it = m->attributes.find("\\abc_box_id"); | ||||
|  | @ -386,31 +379,17 @@ void AigerReader::parse_aiger_ascii() | |||
| 		if (!(f >> l1)) | ||||
| 			log_error("Line %u cannot be interpreted as an output!\n", line_count); | ||||
| 
 | ||||
| 		RTLIL::Wire *wire; | ||||
| 		if (l1 == 0 || l1 == 1) { | ||||
| 			wire = module->addWire(NEW_ID); | ||||
| 			if (l1 == 0) | ||||
| 				module->connect(wire, RTLIL::State::S0); | ||||
| 			else if (l1 == 1) | ||||
| 				module->connect(wire, RTLIL::State::S1); | ||||
| 			else | ||||
| 				log_abort(); | ||||
| 		} | ||||
| 		else { | ||||
| 			log_debug("%d is an output\n", l1); | ||||
| 			const unsigned variable = l1 >> 1; | ||||
| 			const bool invert = l1 & 1; | ||||
| 			RTLIL::IdString wire_name(stringf("\\__%d%s__", variable, invert ? "b" : "")); // FIXME: is "b" the right suffix?
 | ||||
| 			wire = module->wire(wire_name); | ||||
| 			if (!wire) | ||||
| 				wire = createWireIfNotExists(module, l1); | ||||
| 			else { | ||||
| 				if (wire->port_input || wire->port_output) { | ||||
| 					RTLIL::Wire *new_wire = module->addWire(NEW_ID); | ||||
| 					module->connect(new_wire, wire); | ||||
| 					wire = new_wire; | ||||
| 				} | ||||
| 			} | ||||
| 		log_debug("%d is an output\n", l1); | ||||
| 		const unsigned variable = l1 >> 1; | ||||
| 		const bool invert = l1 & 1; | ||||
| 		RTLIL::IdString wire_name(stringf("\\__%d%s__", variable, invert ? "b" : "")); // FIXME: is "b" the right suffix?
 | ||||
| 		RTLIL::Wire *wire = module->wire(wire_name); | ||||
| 		if (!wire) | ||||
| 			wire = createWireIfNotExists(module, l1); | ||||
| 		else if (wire->port_input || wire->port_output) { | ||||
| 			RTLIL::Wire *new_wire = module->addWire(NEW_ID); | ||||
| 			module->connect(new_wire, wire); | ||||
| 			wire = new_wire; | ||||
| 		} | ||||
| 		wire->port_output = true; | ||||
| 		outputs.push_back(wire); | ||||
|  | @ -525,31 +504,17 @@ void AigerReader::parse_aiger_binary() | |||
| 		if (!(f >> l1)) | ||||
| 			log_error("Line %u cannot be interpreted as an output!\n", line_count); | ||||
| 
 | ||||
| 		RTLIL::Wire *wire; | ||||
| 		if (l1 == 0 || l1 == 1) { | ||||
| 			wire = module->addWire(NEW_ID); | ||||
| 			if (l1 == 0) | ||||
| 				module->connect(wire, RTLIL::State::S0); | ||||
| 			else if (l1 == 1) | ||||
| 				module->connect(wire, RTLIL::State::S1); | ||||
| 			else | ||||
| 				log_abort(); | ||||
| 		} | ||||
| 		else { | ||||
| 			log_debug("%d is an output\n", l1); | ||||
| 			const unsigned variable = l1 >> 1; | ||||
| 			const bool invert = l1 & 1; | ||||
| 			RTLIL::IdString wire_name(stringf("\\__%d%s__", variable, invert ? "b" : "")); // FIXME: is "_b" the right suffix?
 | ||||
| 			wire = module->wire(wire_name); | ||||
| 			if (!wire) | ||||
| 				wire = createWireIfNotExists(module, l1); | ||||
| 			else { | ||||
| 				if (wire->port_input || wire->port_output) { | ||||
| 					RTLIL::Wire *new_wire = module->addWire(NEW_ID); | ||||
| 					module->connect(new_wire, wire); | ||||
| 					wire = new_wire; | ||||
| 				} | ||||
| 			} | ||||
| 		log_debug("%d is an output\n", l1); | ||||
| 		const unsigned variable = l1 >> 1; | ||||
| 		const bool invert = l1 & 1; | ||||
| 		RTLIL::IdString wire_name(stringf("\\__%d%s__", variable, invert ? "b" : "")); // FIXME: is "_b" the right suffix?
 | ||||
| 		RTLIL::Wire *wire = module->wire(wire_name); | ||||
| 		if (!wire) | ||||
| 			wire = createWireIfNotExists(module, l1); | ||||
| 		else if (wire->port_input || wire->port_output) { | ||||
| 			RTLIL::Wire *new_wire = module->addWire(NEW_ID); | ||||
| 			module->connect(new_wire, wire); | ||||
| 			wire = new_wire; | ||||
| 		} | ||||
| 		wire->port_output = true; | ||||
| 		outputs.push_back(wire); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue