mirror of
				https://github.com/YosysHQ/yosys
				synced 2025-11-03 21:09:12 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			55 lines
		
	
	
	
		
			1.4 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			55 lines
		
	
	
	
		
			1.4 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
read_verilog -icells <<EOT
 | 
						|
module \$__XILINX_SHREG_ (input C, input D, input [31:0] L, input E, output Q, output SO);
 | 
						|
  parameter DEPTH = 2;
 | 
						|
  parameter [DEPTH-1:0] INIT = 0;
 | 
						|
  parameter CLKPOL = 1;
 | 
						|
  parameter ENPOL = 2;
 | 
						|
 | 
						|
  wire pos_clk = C == CLKPOL;
 | 
						|
  reg pos_en;
 | 
						|
  always @(E)
 | 
						|
    if (ENPOL == 2) pos_en = 1'b1;
 | 
						|
    else pos_en = (E == ENPOL[0]);
 | 
						|
 | 
						|
  reg [DEPTH-1:0] r;
 | 
						|
  always @(posedge pos_clk)
 | 
						|
    if (pos_en)
 | 
						|
      r <= {r[DEPTH-2:0], D};
 | 
						|
 | 
						|
  assign Q = r[L];
 | 
						|
  assign SO = r[DEPTH-1];
 | 
						|
endmodule
 | 
						|
EOT
 | 
						|
read_verilog +/xilinx/cells_sim.v
 | 
						|
proc
 | 
						|
design -save model
 | 
						|
 | 
						|
test_pmgen -generate xilinx_srl.fixed
 | 
						|
hierarchy -top pmtest_xilinx_srl_pm_fixed
 | 
						|
flatten; opt_clean
 | 
						|
 | 
						|
design -save gold
 | 
						|
xilinx_srl -fixed
 | 
						|
techmap -autoproc -map %model
 | 
						|
design -stash gate
 | 
						|
 | 
						|
design -copy-from gold -as gold pmtest_xilinx_srl_pm_fixed
 | 
						|
design -copy-from gate -as gate pmtest_xilinx_srl_pm_fixed
 | 
						|
miter -equiv -flatten -make_assert gold gate miter
 | 
						|
sat -set-init-zero -seq 5 -verify -prove-asserts miter
 | 
						|
 | 
						|
design -load model
 | 
						|
 | 
						|
test_pmgen -generate xilinx_srl.variable
 | 
						|
hierarchy -top pmtest_xilinx_srl_pm_variable
 | 
						|
flatten; opt_clean
 | 
						|
 | 
						|
design -save gold
 | 
						|
xilinx_srl -variable
 | 
						|
techmap -autoproc -map %model
 | 
						|
design -stash gate
 | 
						|
 | 
						|
design -copy-from gold -as gold pmtest_xilinx_srl_pm_variable
 | 
						|
design -copy-from gate -as gate pmtest_xilinx_srl_pm_variable
 | 
						|
miter -equiv -flatten -make_assert gold gate miter
 | 
						|
sat -set-init-zero -seq 5 -verify -prove-asserts miter
 |