mirror of
				https://github.com/YosysHQ/yosys
				synced 2025-11-03 21:09:12 +00:00 
			
		
		
		
	Add comment on why partial multipliers are 18x18
This commit is contained in:
		
							parent
							
								
									792cd31052
								
							
						
					
					
						commit
						6c5e1234e1
					
				
					 1 changed files with 8 additions and 4 deletions
				
			
		| 
						 | 
				
			
			@ -342,10 +342,14 @@ struct SynthXilinxPass : public ScriptPass
 | 
			
		|||
		if (check_label("map_dsp", "(skip if '-nodsp')")) {
 | 
			
		||||
			if (!nodsp || help_mode) {
 | 
			
		||||
				// NB: Xilinx multipliers are signed only
 | 
			
		||||
				run("techmap -map +/mul2dsp.v -map +/xilinx/dsp_map.v -D DSP_A_MAXWIDTH=25 -D DSP_A_MAXWIDTH_PARTIAL=18 -D DSP_B_MAXWIDTH=18 "
 | 
			
		||||
						"-D DSP_A_MINWIDTH=2 -D DSP_B_MINWIDTH=2 " // Blocks Nx1 multipliers
 | 
			
		||||
						"-D DSP_Y_MINWIDTH=9 " // UG901 suggests small multiplies are those 4x4 and smaller
 | 
			
		||||
						"-D DSP_SIGNEDONLY=1 -D DSP_NAME=$__MUL25X18");
 | 
			
		||||
				run("techmap -map +/mul2dsp.v -map +/xilinx/dsp_map.v -D DSP_A_MAXWIDTH=25 "
 | 
			
		||||
					"-D DSP_A_MAXWIDTH_PARTIAL=18 -D DSP_B_MAXWIDTH=18 "    // Partial multipliers are intentionally
 | 
			
		||||
												// limited to 18x18 in order to take
 | 
			
		||||
												// advantage of the (PCOUT << 17) -> PCIN
 | 
			
		||||
												// dedicated cascade chain capability
 | 
			
		||||
					"-D DSP_A_MINWIDTH=2 -D DSP_B_MINWIDTH=2 " // Blocks Nx1 multipliers
 | 
			
		||||
					"-D DSP_Y_MINWIDTH=9 " // UG901 suggests small multiplies are those 4x4 and smaller
 | 
			
		||||
					"-D DSP_SIGNEDONLY=1 -D DSP_NAME=$__MUL25X18");
 | 
			
		||||
				run("select a:mul2dsp");
 | 
			
		||||
				run("setattr -unset mul2dsp");
 | 
			
		||||
				run("opt_expr -fine");
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue