Marcelina Kościelnicka 
								
							 
						 
						
							
							
							
							
								
							
							
								b0bee396a8 
								
							 
						 
						
							
							
								
								Add new builtin FF types  
							
							... 
							
							
							
							The new types include:
- FFs with async reset and enable (`$adffe`, `$_DFFE_[NP][NP][01][NP]_`)
- FFs with sync reset (`$sdff`, `$_SDFF_[NP][NP][01]_`)
- FFs with sync reset and enable, reset priority (`$sdffs`, `$_SDFFE_[NP][NP][01][NP]_`)
- FFs with sync reset and enable, enable priority (`$sdffce`, `$_SDFFCE_[NP][NP][01][NP]_`)
- FFs with async reset, set, and enable (`$dffsre`, `$_DFFSRE_[NP][NP][NP][NP]_`)
- latches with reset or set (`$adlatch`, `$_DLATCH_[NP][NP][01]_`)
The new FF types are not actually used anywhere yet (this is left
for future commits). 
							
						 
						
							2020-06-23 15:40:02 +02:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									whitequark 
								
							 
						 
						
							
							
							
							
								
							
							
								7191dd16f9 
								
							 
						 
						
							
							
								
								Use C++11 final/override keywords.  
							
							
							
						 
						
							2020-06-18 23:34:52 +00:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Xark 
								
							 
						 
						
							
							
							
							
								
							
							
								9509444ef2 
								
							 
						 
						
							
							
								
								Fix Verilator sim warnings: 1 BLKSEQ and 3 WIDTH  
							
							
							
						 
						
							2020-06-14 00:45:22 -07:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Dan Ravensloft 
								
							 
						 
						
							
							
							
							
								
							
							
								8b4eb78849 
								
							 
						 
						
							
							
								
								intel_alm: fix DFFE matching  
							
							
							
						 
						
							2020-06-11 19:55:51 +02:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Claire Wolf 
								
							 
						 
						
							
							
							
							
								
							
							
								3c7122c378 
								
							 
						 
						
							
							
								
								Do not optimize away FFs in "prep" and Verific fron-end  
							
							... 
							
							
							
							Signed-off-by: Claire Wolf <claire@symbioticeda.com> 
							
						 
						
							2020-06-09 15:54:14 +02:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Eddie Hung 
								
							 
						 
						
							
							
								
								
							
							
							
								
							
							
								69850204c4 
								
							 
						 
						
							
							
								
								Merge pull request  #2077  from YosysHQ/eddie/abc9_dff_improve  
							
							... 
							
							
							
							abc9: -dff improvements 
							
						 
						
							2020-06-04 08:15:25 -07:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Eddie Hung 
								
							 
						 
						
							
							
							
							
								
							
							
								d3b53bc495 
								
							 
						 
						
							
							
								
								abc9_ops: -reintegrate use SigMap to remove (* init *) from $_DFF_[NP]_  
							
							
							
						 
						
							2020-05-29 17:17:40 -07:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Xiretza 
								
							 
						 
						
							
							
								
								
							
							
							
								
							
							
								edd8ff2c07 
								
							 
						 
						
							
							
								
								Add flooring division operator  
							
							... 
							
							
							
							The $div and $mod cells use truncating division semantics (rounding
towards 0), as defined by e.g. Verilog. Another rounding mode, flooring
(rounding towards negative infinity), can be used in e.g. VHDL. The
new $divfloor cell provides this flooring division.
This commit also fixes the handling of $div in opt_expr, which was
previously optimized as if it was $divfloor. 
							
						 
						
							2020-05-28 22:59:04 +02:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Xiretza 
								
							 
						 
						
							
							
								
								
							
							
							
								
							
							
								17163cf43a 
								
							 
						 
						
							
							
								
								Add flooring modulo operator  
							
							... 
							
							
							
							The $div and $mod cells use truncating division semantics (rounding
towards 0), as defined by e.g. Verilog. Another rounding mode, flooring
(rounding towards negative infinity), can be used in e.g. VHDL. The
new $modfloor cell provides this flooring modulo (also known as "remainder"
in several languages, but this name is ambiguous).
This commit also fixes the handling of $mod in opt_expr, which was
previously optimized as if it was $modfloor. 
							
						 
						
							2020-05-28 22:59:03 +02:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Eddie Hung 
								
							 
						 
						
							
							
							
							
								
							
							
								5b81df57c8 
								
							 
						 
						
							
							
								
								xilinx: tidy up cells_sim.v a little  
							
							
							
						 
						
							2020-05-25 09:48:11 -07:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Eddie Hung 
								
							 
						 
						
							
							
							
							
								
							
							
								76e0cc8276 
								
							 
						 
						
							
							
								
								ecp5: cleanup unused +/ecp5/abc9_model.v  
							
							
							
						 
						
							2020-05-23 08:17:40 -07:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Marcelina Kościelnicka 
								
							 
						 
						
							
							
							
							
								
							
							
								aee439360b 
								
							 
						 
						
							
							
								
								Add force_downto and force_upto wire attributes.  
							
							... 
							
							
							
							Fixes  #2058 . 
						
							2020-05-19 01:42:40 +02:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Eddie Hung 
								
							 
						 
						
							
							
							
							
								
							
							
								67fc0c3698 
								
							 
						 
						
							
							
								
								abc9: use (* abc9_keep *) instead of (* abc9_scc *); apply to $_DFF_?_  
							
							... 
							
							
							
							instead of moving them to $__ prefix 
							
						 
						
							2020-05-14 16:44:35 -07:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Eddie Hung 
								
							 
						 
						
							
							
							
							
								
							
							
								13f9d65b6f 
								
							 
						 
						
							
							
								
								abc9: preserve $_DFF_?_.Q's (* init *); rely on clean to remove it  
							
							
							
						 
						
							2020-05-14 10:33:57 -07:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Eddie Hung 
								
							 
						 
						
							
							
							
							
								
							
							
								97a0a04314 
								
							 
						 
						
							
							
								
								abc9_ops/xaiger: further reducing Module::derive() calls by ...  
							
							... 
							
							
							
							replacing _all_ (* abc9_box *) instantiations with their derived types 
							
						 
						
							2020-05-14 10:33:57 -07:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Eddie Hung 
								
							 
						 
						
							
							
							
							
								
							
							
								e79127fceb 
								
							 
						 
						
							
							
								
								Cleanup; reduce Module::derive() calls  
							
							
							
						 
						
							2020-05-14 10:33:57 -07:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Eddie Hung 
								
							 
						 
						
							
							
							
							
								
							
							
								cea614f5ae 
								
							 
						 
						
							
							
								
								ecp5: latches_map.v if *not* -asyncprld  
							
							
							
						 
						
							2020-05-14 10:33:57 -07:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Eddie Hung 
								
							 
						 
						
							
							
							
							
								
							
							
								fdc340db8e 
								
							 
						 
						
							
							
								
								ecp5: synth_ecp5 to no longer need +/ecp5/abc9_{,un}map.v  
							
							
							
						 
						
							2020-05-14 10:33:57 -07:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Eddie Hung 
								
							 
						 
						
							
							
							
							
								
							
							
								39759d5f0e 
								
							 
						 
						
							
							
								
								ecp5: fix rebase mistake  
							
							
							
						 
						
							2020-05-14 10:33:57 -07:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Eddie Hung 
								
							 
						 
						
							
							
							
							
								
							
							
								ca4f8c9444 
								
							 
						 
						
							
							
								
								xilinx: gate specify/attributes from iverilog  
							
							
							
						 
						
							2020-05-14 10:33:57 -07:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Eddie Hung 
								
							 
						 
						
							
							
							
							
								
							
							
								57c478c537 
								
							 
						 
						
							
							
								
								abc9: only do +/abc9_map if `DFF  
							
							
							
						 
						
							2020-05-14 10:33:57 -07:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Eddie Hung 
								
							 
						 
						
							
							
							
							
								
							
							
								8cda29137e 
								
							 
						 
						
							
							
								
								ecp5: TRELLIS_FF bypass path only in async mode  
							
							
							
						 
						
							2020-05-14 10:33:56 -07:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Eddie Hung 
								
							 
						 
						
							
							
							
							
								
							
							
								6c34945371 
								
							 
						 
						
							
							
								
								xilinx/ice40/ecp5: zinit requires selected wires, so select them all  
							
							
							
						 
						
							2020-05-14 10:33:56 -07:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Eddie Hung 
								
							 
						 
						
							
							
							
							
								
							
							
								a323881e15 
								
							 
						 
						
							
							
								
								xilinx/ecp5/ice40: add (* abc9_flop *) to bypass-able cells  
							
							
							
						 
						
							2020-05-14 10:33:56 -07:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Eddie Hung 
								
							 
						 
						
							
							
							
							
								
							
							
								7cd3f4a79b 
								
							 
						 
						
							
							
								
								abc9_ops: add -prep_bypass for auto bypass boxes; refactor  
							
							... 
							
							
							
							Eliminate need for abc9_{,un}map.v in xilinx
-prep_dff_{hier,unmap} -> -prep_hier 
							
						 
						
							2020-05-14 10:33:56 -07:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Eddie Hung 
								
							 
						 
						
							
							
							
							
								
							
							
								722540dbf9 
								
							 
						 
						
							
							
								
								abc9: not enough to techmap_fail on (* init=1 *), hide them using $__  
							
							
							
						 
						
							2020-05-14 10:33:56 -07:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Eddie Hung 
								
							 
						 
						
							
							
							
							
								
							
							
								8fbb55f4ab 
								
							 
						 
						
							
							
								
								synth_*: no need to explicitly read +/abc9_model.v  
							
							
							
						 
						
							2020-05-14 10:33:56 -07:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Eddie Hung 
								
							 
						 
						
							
							
							
							
								
							
							
								48052ad813 
								
							 
						 
						
							
							
								
								abc9: add flop boxes to basic $_DFF_P_ and $_DFF_N_ too  
							
							
							
						 
						
							2020-05-14 10:33:56 -07:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Eddie Hung 
								
							 
						 
						
							
							
							
							
								
							
							
								4cec21b93e 
								
							 
						 
						
							
							
								
								abc9_ops: -prep_dff_map to error if async flop found  
							
							
							
						 
						
							2020-05-14 10:33:56 -07:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Eddie Hung 
								
							 
						 
						
							
							
							
							
								
							
							
								6c66030dfb 
								
							 
						 
						
							
							
								
								Uncomment negative setup times; clamp to zero for connectivity  
							
							
							
						 
						
							2020-05-14 10:33:56 -07:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Eddie Hung 
								
							 
						 
						
							
							
							
							
								
							
							
								0d84ff3fc4 
								
							 
						 
						
							
							
								
								Revert "ecp5: replace ecp5_ffinit with techmap rules + dff2dffs -match-init"  
							
							... 
							
							
							
							This reverts commit 8c702b6cc0221a00021a3e4661c883bb591c924b. 
							
						 
						
							2020-05-14 10:33:56 -07:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Eddie Hung 
								
							 
						 
						
							
							
							
							
								
							
							
								a52f779eca 
								
							 
						 
						
							
							
								
								ecp5: (* abc9_flop *) gated behind YOSYS  
							
							
							
						 
						
							2020-05-14 10:33:56 -07:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Eddie Hung 
								
							 
						 
						
							
							
							
							
								
							
							
								34c7732642 
								
							 
						 
						
							
							
								
								ecp5: add synth_ecp5 -dff to work with -abc9  
							
							
							
						 
						
							2020-05-14 10:33:56 -07:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Eddie Hung 
								
							 
						 
						
							
							
							
							
								
							
							
								23c53a6bdd 
								
							 
						 
						
							
							
								
								ice40: synth_ice40 cleanup  
							
							
							
						 
						
							2020-05-14 10:33:56 -07:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Eddie Hung 
								
							 
						 
						
							
							
							
							
								
							
							
								5d5029fa75 
								
							 
						 
						
							
							
								
								ecp5: replace ecp5_ffinit with techmap rules + dff2dffs -match-init  
							
							
							
						 
						
							2020-05-14 10:33:56 -07:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Eddie Hung 
								
							 
						 
						
							
							
							
							
								
							
							
								fe7965e0ee 
								
							 
						 
						
							
							
								
								ice40: add synth_ice40 -dff option, support with -abc9  
							
							
							
						 
						
							2020-05-14 10:33:56 -07:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Eddie Hung 
								
							 
						 
						
							
							
							
							
								
							
							
								4a10c87ae1 
								
							 
						 
						
							
							
								
								ice40: split out cells_map.v into ff_map.v  
							
							
							
						 
						
							2020-05-14 10:33:56 -07:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Eddie Hung 
								
							 
						 
						
							
							
							
							
								
							
							
								c10757a8ea 
								
							 
						 
						
							
							
								
								synth_xilinx: rename dff_mode -> dff  
							
							
							
						 
						
							2020-05-14 10:33:56 -07:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Eddie Hung 
								
							 
						 
						
							
							
							
							
								
							
							
								95763c8d18 
								
							 
						 
						
							
							
								
								abc9_ops: add 'dff' label for auto handling of (* abc9_flop *) boxes  
							
							
							
						 
						
							2020-05-14 10:33:56 -07:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Claire Wolf 
								
							 
						 
						
							
							
								
								
							
							
							
								
							
							
								ee0beb481d 
								
							 
						 
						
							
							
								
								Merge pull request  #2027  from YosysHQ/eddie/verilog_neg_upto  
							
							... 
							
							
							
							ast: swap range regardless of range_left >= 0 
							
						 
						
							2020-05-14 18:06:18 +02:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Eddie Hung 
								
							 
						 
						
							
							
							
							
								
							
							
								27b7ffc754 
								
							 
						 
						
							
							
								
								ice40: fix ICESTORM_LC process sensitivity  
							
							
							
						 
						
							2020-05-12 15:40:48 -07:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Eddie Hung 
								
							 
						 
						
							
							
							
							
								
							
							
								4ecae8a673 
								
							 
						 
						
							
							
								
								ice40: fix whitespace  
							
							
							
						 
						
							2020-05-12 15:40:13 -07:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									David Shah 
								
							 
						 
						
							
							
							
							
								
							
							
								95fb3cf487 
								
							 
						 
						
							
							
								
								ecp5: Add missing SERDES parameters  
							
							... 
							
							
							
							Signed-off-by: David Shah <dave@ds0.me> 
							
						 
						
							2020-05-12 21:12:26 +01:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Dan Ravensloft 
								
							 
						 
						
							
							
							
							
								
							
							
								5b779f7f4e 
								
							 
						 
						
							
							
								
								intel_alm: direct LUTRAM cell instantiation  
							
							... 
							
							
							
							By instantiating the LUTRAM cell directly, we avoid a trip through
altsyncram, which speeds up Quartus synthesis time. This also gives
a little more flexibility, as Yosys can build RAMs out of individual
32x1 LUTRAM cells.
While working on this, I discovered that the mem_init0 parameter of
<family>_mlab_cell gets ignored by Quartus. 
							
						 
						
							2020-05-07 21:03:13 +02:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Eddie Hung 
								
							 
						 
						
							
							
							
							
								
							
							
								004999218f 
								
							 
						 
						
							
							
								
								techlibs/common: more robustness when *_WIDTH = 0  
							
							
							
						 
						
							2020-05-05 08:01:27 -07:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Eddie Hung 
								
							 
						 
						
							
							
							
							
								
							
							
								e6b55e8b38 
								
							 
						 
						
							
							
								
								synth_ice40/ecp5/xilinx: allow abc9.W to be overridden via scratchpad  
							
							
							
						 
						
							2020-05-04 11:44:00 -07:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									whitequark 
								
							 
						 
						
							
							
							
							
								
							
							
								26cda3c247 
								
							 
						 
						
							
							
								
								gowin,ecp5: remove generated files in make clean.  
							
							
							
						 
						
							2020-04-24 23:26:39 +00:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Dan Ravensloft 
								
							 
						 
						
							
							
							
							
								
							
							
								4ca5f9799b 
								
							 
						 
						
							
							
								
								intel_alm: cleanup duplication  
							
							
							
						 
						
							2020-04-24 11:26:48 +02:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Dan Ravensloft 
								
							 
						 
						
							
							
							
							
								
							
							
								3d149aff73 
								
							 
						 
						
							
							
								
								intel_alm: work around a Quartus ICE  
							
							
							
						 
						
							2020-04-23 11:03:28 +02:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Eddie Hung 
								
							 
						 
						
							
							
							
							
								
							
							
								51ae0f4e20 
								
							 
						 
						
							
							
								
								ecp5: ecp5_gsr to skip cells that don't have GSR parameter again  
							
							
							
						 
						
							2020-04-22 17:53:08 -07:00