mirror of
				https://github.com/YosysHQ/yosys
				synced 2025-11-04 05:19:11 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			69 lines
		
	
	
	
		
			1.8 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			69 lines
		
	
	
	
		
			1.8 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
read_verilog init.v
 | 
						|
read_verilog -lib -specify +/gowin/cells_sim.v
 | 
						|
design -save read
 | 
						|
 | 
						|
proc
 | 
						|
flatten
 | 
						|
synth_gowin -run coarse:
 | 
						|
 | 
						|
# check if all init values are handled
 | 
						|
check -assert -noinit
 | 
						|
# check if every flop mapped correctly
 | 
						|
select -assert-count 1 t:DFF
 | 
						|
select -assert-count 1 t:DFFC
 | 
						|
select -assert-count 1 t:DFFCE
 | 
						|
select -assert-count 1 t:DFFE
 | 
						|
select -assert-count 1 t:DFFN
 | 
						|
select -assert-count 1 t:DFFNC
 | 
						|
select -assert-count 1 t:DFFNCE
 | 
						|
select -assert-count 1 t:DFFNE
 | 
						|
select -assert-count 1 t:DFFNP
 | 
						|
select -assert-count 1 t:DFFNPE
 | 
						|
select -assert-count 1 t:DFFNR
 | 
						|
select -assert-count 1 t:DFFNRE
 | 
						|
select -assert-count 1 t:DFFNS
 | 
						|
select -assert-count 1 t:DFFNSE
 | 
						|
select -assert-count 1 t:DFFP
 | 
						|
select -assert-count 1 t:DFFPE
 | 
						|
select -assert-count 1 t:DFFR
 | 
						|
select -assert-count 1 t:DFFRE
 | 
						|
select -assert-count 1 t:DFFS
 | 
						|
select -assert-count 1 t:DFFSE
 | 
						|
 | 
						|
design -load read
 | 
						|
 | 
						|
# these should synth to a flop with reset
 | 
						|
chparam -set INIT 1 myDFF myDFFN myDFFE myDFFNE
 | 
						|
 | 
						|
# async would give an error
 | 
						|
# sync should synth to a mux
 | 
						|
chparam -set INIT 0 myDFF*S*
 | 
						|
chparam -set INIT 1 myDFF*R*
 | 
						|
 | 
						|
proc
 | 
						|
flatten
 | 
						|
synth_gowin -run coarse:
 | 
						|
 | 
						|
# check the flops mapped as expected
 | 
						|
select -assert-count 2 t:DFF
 | 
						|
select -assert-count 1 t:DFFC
 | 
						|
select -assert-count 1 t:DFFCE
 | 
						|
select -assert-count 0 t:DFFE
 | 
						|
select -assert-count 2 t:DFFN
 | 
						|
select -assert-count 1 t:DFFNC
 | 
						|
select -assert-count 1 t:DFFNCE
 | 
						|
select -assert-count 0 t:DFFNE
 | 
						|
select -assert-count 1 t:DFFNP
 | 
						|
select -assert-count 1 t:DFFNPE
 | 
						|
select -assert-count 0 t:DFFNR
 | 
						|
select -assert-count 0 t:DFFNRE
 | 
						|
select -assert-count 3 t:DFFNS
 | 
						|
select -assert-count 1 t:DFFNSE
 | 
						|
select -assert-count 1 t:DFFP
 | 
						|
select -assert-count 1 t:DFFPE
 | 
						|
select -assert-count 0 t:DFFR
 | 
						|
select -assert-count 0 t:DFFRE
 | 
						|
select -assert-count 3 t:DFFS
 | 
						|
select -assert-count 1 t:DFFSE
 | 
						|
select -assert-count 4 t:LUT2
 | 
						|
select -assert-count 4 t:LUT4
 |