mirror of
				https://github.com/YosysHQ/yosys
				synced 2025-10-26 09:24:37 +00:00 
			
		
		
		
	Add "write_edif -lsbidx"
This commit is contained in:
		
							parent
							
								
									d3ee4eba5b
								
							
						
					
					
						commit
						fb9e12761b
					
				
					 1 changed files with 11 additions and 3 deletions
				
			
		|  | @ -120,6 +120,9 @@ struct EdifBackend : public Backend { | ||||||
| 		log("        sets the delimiting character for module port rename clauses to\n"); | 		log("        sets the delimiting character for module port rename clauses to\n"); | ||||||
| 		log("        parentheses, square brackets, or angle brackets.\n"); | 		log("        parentheses, square brackets, or angle brackets.\n"); | ||||||
| 		log("\n"); | 		log("\n"); | ||||||
|  | 		log("    -lsbidx\n"); | ||||||
|  | 		log("        use index 0 for the LSB bit of a net or port instead of MSB.\n"); | ||||||
|  | 		log("\n"); | ||||||
| 		log("Unfortunately there are different \"flavors\" of the EDIF file format. This\n"); | 		log("Unfortunately there are different \"flavors\" of the EDIF file format. This\n"); | ||||||
| 		log("command generates EDIF files for the Xilinx place&route tools. It might be\n"); | 		log("command generates EDIF files for the Xilinx place&route tools. It might be\n"); | ||||||
| 		log("necessary to make small modifications to this command when a different tool\n"); | 		log("necessary to make small modifications to this command when a different tool\n"); | ||||||
|  | @ -132,6 +135,7 @@ struct EdifBackend : public Backend { | ||||||
| 		std::string top_module_name; | 		std::string top_module_name; | ||||||
| 		bool port_rename = false; | 		bool port_rename = false; | ||||||
| 		bool attr_properties = false; | 		bool attr_properties = false; | ||||||
|  | 		bool lsbidx = false; | ||||||
| 		std::map<RTLIL::IdString, std::map<RTLIL::IdString, int>> lib_cell_ports; | 		std::map<RTLIL::IdString, std::map<RTLIL::IdString, int>> lib_cell_ports; | ||||||
| 		bool nogndvcc = false, gndvccy = false, keepmode = false; | 		bool nogndvcc = false, gndvccy = false, keepmode = false; | ||||||
| 		CellTypes ct(design); | 		CellTypes ct(design); | ||||||
|  | @ -173,6 +177,10 @@ struct EdifBackend : public Backend { | ||||||
| 				} | 				} | ||||||
| 				continue; | 				continue; | ||||||
| 			} | 			} | ||||||
|  | 			if (args[argidx] == "-lsbidx") { | ||||||
|  | 				lsbidx = true; | ||||||
|  | 				continue; | ||||||
|  | 			} | ||||||
| 			break; | 			break; | ||||||
| 		} | 		} | ||||||
| 		extra_args(f, filename, args, argidx); | 		extra_args(f, filename, args, argidx); | ||||||
|  | @ -437,7 +445,7 @@ struct EdifBackend : public Backend { | ||||||
| 					*f << ")\n"; | 					*f << ")\n"; | ||||||
| 					for (int i = 0; i < wire->width; i++) { | 					for (int i = 0; i < wire->width; i++) { | ||||||
| 						RTLIL::SigSpec sig = sigmap(RTLIL::SigSpec(wire, i)); | 						RTLIL::SigSpec sig = sigmap(RTLIL::SigSpec(wire, i)); | ||||||
| 						net_join_db[sig].insert(make_pair(stringf("(portRef (member %s %d))", EDIF_REF(wire->name), GetSize(wire)-i-1), wire->port_input)); | 						net_join_db[sig].insert(make_pair(stringf("(portRef (member %s %d))", EDIF_REF(wire->name), lsbidx ? i : GetSize(wire)-i-1), wire->port_input)); | ||||||
| 					} | 					} | ||||||
| 				} | 				} | ||||||
| 			} | 			} | ||||||
|  | @ -468,13 +476,13 @@ struct EdifBackend : public Backend { | ||||||
| 							log_warning("Bit %d of cell port %s.%s.%s driven by %s will be left unconnected in EDIF output.\n", | 							log_warning("Bit %d of cell port %s.%s.%s driven by %s will be left unconnected in EDIF output.\n", | ||||||
| 									i, log_id(module), log_id(cell), log_id(p.first), log_signal(sig[i])); | 									i, log_id(module), log_id(cell), log_id(p.first), log_signal(sig[i])); | ||||||
| 						else { | 						else { | ||||||
| 							int member_idx = GetSize(sig)-i-1; | 							int member_idx = lsbidx ? i : GetSize(sig)-i-1; | ||||||
| 							auto m = design->module(cell->type); | 							auto m = design->module(cell->type); | ||||||
| 							int width = sig.size(); | 							int width = sig.size(); | ||||||
| 							if (m) { | 							if (m) { | ||||||
| 								auto w = m->wire(p.first); | 								auto w = m->wire(p.first); | ||||||
| 								if (w) { | 								if (w) { | ||||||
| 									member_idx = GetSize(w)-i-1; | 									member_idx = lsbidx ? i : GetSize(w)-i-1; | ||||||
| 									width = GetSize(w); | 									width = GetSize(w); | ||||||
| 								} | 								} | ||||||
| 							} | 							} | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue