mirror of
				https://github.com/YosysHQ/yosys
				synced 2025-10-26 17:29:23 +00:00 
			
		
		
		
	Add _nowide variants of LUT libraries in -nowidelut flows
This commit is contained in:
		
							parent
							
								
									741ebba70a
								
							
						
					
					
						commit
						988e6163ab
					
				
					 4 changed files with 44 additions and 13 deletions
				
			
		
							
								
								
									
										12
									
								
								techlibs/ecp5/abc_5g_nowide.lut
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								techlibs/ecp5/abc_5g_nowide.lut
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,12 @@ | |||
| # ECP5-5G LUT library for ABC | ||||
| # Note that ECP5 architecture assigns difference | ||||
| # in LUT input delay to interconnect, so this is | ||||
| # considered too | ||||
| 
 | ||||
| 
 | ||||
| # Simple LUTs | ||||
| #  area  D    C    B    A | ||||
| 1  1     141 | ||||
| 2  1     141  275 | ||||
| 3  1     141  275  379 | ||||
| 4  1     141  275  379  379 | ||||
|  | @ -273,6 +273,9 @@ struct SynthEcp5Pass : public ScriptPass | |||
| 			} | ||||
| 			run("techmap -map +/ecp5/latches_map.v"); | ||||
| 			if (abc9) { | ||||
| 				if (nowidelut) | ||||
| 					run("abc9 -lut +/ecp5/abc_5g_nowide.lut -box +/ecp5/abc_5g.box -W 200"); | ||||
| 				else | ||||
| 					run("abc9 -lut +/ecp5/abc_5g.lut -box +/ecp5/abc_5g.box -W 200"); | ||||
| 			} else { | ||||
| 				if (nowidelut) | ||||
|  |  | |||
							
								
								
									
										10
									
								
								techlibs/xilinx/abc_xc7_nowide.lut
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								techlibs/xilinx/abc_xc7_nowide.lut
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,10 @@ | |||
| # Max delays from https://github.com/SymbiFlow/prjxray-db/blob/82bf5f158cd8e9a11ac4d04f1aeef48ed1a528a5/artix7/timings/CLBLL_L.sdf | ||||
| #            and  https://github.com/SymbiFlow/prjxray-db/blob/82bf5f158cd8e9a11ac4d04f1aeef48ed1a528a5/artix7/tile_type_CLBLL_L.json | ||||
| 
 | ||||
| # K	area	delay | ||||
| 1 	1	127 | ||||
| 2	2	127 238 | ||||
| 3	3	127 238 407 | ||||
| 4	3	127 238 407 472 | ||||
| 5	3	127 238 407 472 631 | ||||
| 6	5	127 238 407 472 631 642 | ||||
|  | @ -100,14 +100,14 @@ struct SynthXilinxPass : public ScriptPass | |||
| 	} | ||||
| 
 | ||||
| 	std::string top_opt, edif_file, blif_file, abc, arch; | ||||
| 	bool flatten, retime, vpr, nobram, nodram, nosrl, nocarry, nowidelut; | ||||
| 	bool flatten, retime, vpr, nobram, nodram, nosrl, nocarry, nowidelut, abc9; | ||||
| 
 | ||||
| 	void clear_flags() YS_OVERRIDE | ||||
| 	{ | ||||
| 		top_opt = "-auto-top"; | ||||
| 		edif_file.clear(); | ||||
| 		blif_file.clear(); | ||||
| 		abc = "abc"; | ||||
| 		arch = "xc7"; | ||||
| 		flatten = false; | ||||
| 		retime = false; | ||||
| 		vpr = false; | ||||
|  | @ -117,7 +117,7 @@ struct SynthXilinxPass : public ScriptPass | |||
| 		nosrl = false; | ||||
| 		nocarry = false; | ||||
| 		nowidelut = false; | ||||
| 		arch = "xc7"; | ||||
| 		abc9 = false; | ||||
| 	} | ||||
| 
 | ||||
| 	void execute(std::vector<std::string> args, RTLIL::Design *design) YS_OVERRIDE | ||||
|  | @ -189,7 +189,7 @@ struct SynthXilinxPass : public ScriptPass | |||
| 				continue; | ||||
| 			} | ||||
| 			if (args[argidx] == "-abc9") { | ||||
| 				abc = "abc9"; | ||||
| 				abc9 = true; | ||||
| 				continue; | ||||
| 			} | ||||
| 			break; | ||||
|  | @ -284,7 +284,7 @@ struct SynthXilinxPass : public ScriptPass | |||
| 				techmap_files += " -map +/xilinx/arith_map.v"; | ||||
| 				if (vpr) | ||||
| 					techmap_files += " -D _EXPLICIT_CARRY"; | ||||
| 				else if (abc == "abc9") | ||||
| 				else if (abc9) | ||||
| 					techmap_files += " -D _CLB_CARRY"; | ||||
| 			} | ||||
| 			run("techmap " + techmap_files); | ||||
|  | @ -298,14 +298,20 @@ struct SynthXilinxPass : public ScriptPass | |||
| 
 | ||||
| 		if (check_label("map_luts")) { | ||||
| 			run("opt_expr -mux_undef"); | ||||
| 			if (abc == "abc9") | ||||
| 				run(abc + " -lut +/xilinx/abc_xc7.lut -box +/xilinx/abc_xc7.box -W " + XC7_WIRE_DELAY + string(retime ? " -dff" : "")); | ||||
| 			else if (help_mode) | ||||
| 			if (help_mode) | ||||
| 				run("abc -luts 2:2,3,6:5[,10,20] [-dff]", "(skip if 'nowidelut', only for '-retime')"); | ||||
| 			else if (nowidelut) | ||||
| 			else if (abc9) { | ||||
| 				if (nowidelut) | ||||
| 					run("abc9 -lut +/xilinx/abc_xc7_nowide.lut -box +/xilinx/abc_xc7.box -W " + std::string(XC7_WIRE_DELAY) + string(retime ? " -dff" : "")); | ||||
| 				else | ||||
| 					run("abc9 -lut +/xilinx/abc_xc7.lut -box +/xilinx/abc_xc7.box -W " + std::string(XC7_WIRE_DELAY) + string(retime ? " -dff" : "")); | ||||
| 			} | ||||
| 			else { | ||||
| 				if (nowidelut) | ||||
| 					run("abc -luts 2:2,3,6:5" + string(retime ? " -dff" : "")); | ||||
| 				else | ||||
| 				run(abc + " -luts 2:2,3,6:5,10,20" + string(retime ? " -dff" : "")); | ||||
| 					run("abc -luts 2:2,3,6:5,10,20" + string(retime ? " -dff" : "")); | ||||
| 			} | ||||
| 			run("clean"); | ||||
| 
 | ||||
| 			// This shregmap call infers fixed length shift registers after abc
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue