Verilog 仿真问题:打拍失败

1:记录一下在今的天仿真的时候,对信号打拍操作,发现打拍失败。

打拍失败现象如下:

verilog代码如下:

cpp 复制代码
    always @ (posedge clkb or negedge rst_n)
    	if (!rst_n)
    		begin
    			pulse_reg1	<=	0;
    			pulse_reg2	<=	0;
    		end
    	else
    		begin
    			pulse_reg1	<=	pulse_ina	;
    			pulse_reg2	<=	pulse_reg1	;
    		end

仿真代码如下:

cpp 复制代码
module sim_slow2fast_cdc ( );
	reg		clka	;
	reg		clkb	;
	reg		rst_n	;
	reg		pulse_ina;
	
	wire	pulse_outb;
	
	slow2fast_cdc	slow2fast_cdc_inst (
		.clka		(clka)	,
		.clkb		(clkb)	,
		.rst_n		(rst_n)	,
		.pulse_ina	(pulse_ina)	,
		
		.pulse_outb	(pulse_outb)
	);
	
	always #10	clka = ~clka;
	always #6	clkb = ~clkb;
	initial	begin
		clka		=	0;
		clkb		=	0;
		rst_n		=	0;
		pulse_ina	=	0;
		#25
		rst_n		=	1;	// 复位无效
		
		#5	// 对齐
		
		clk_come;	#45
		clk_come;	#35
		clk_come;	#50
		clk_come;
	end
	
	task	clk_come;
	   begin
		  pulse_ina	=	1;	// 来一个慢时钟下的高脉冲
		  #20
		  pulse_ina	=	0;
	   end
	endtask
	
endmodule

2:现象:可以看见pulse_reg1将pulse_ina信号采集并没有延迟1拍,从而形成打拍失败的结果;

3:问题原因:因为我们这个pulse_ina是模拟外部信号进入,是reg变量,我这里是D触发器要去采集pulse_ina,这里仿真代码是使用的是阻塞赋值;故而出现仿真打拍失败。

4:解决办法:将仿真文件里面的pulse_ina的阻塞赋值改成非阻塞赋值,即可解决。

修改之后仿真代码:

5:仿真结果如下;

放大图效果:

6:总结:打拍成功;

7:参考资料Verilog 仿真问题:打拍失败_哔哩哔哩_bilibili

相关推荐
乌恩大侠10 小时前
【OAI】 USRP 在conf文件中的配置,RU选项
fpga开发
qq_小单车1 天前
xilinx-DNA
fpga开发·xilinx
Flamingˢ1 天前
FPGA中的嵌入式块存储器RAM:从原理到实现的完整指南
fpga开发
Flamingˢ1 天前
FPGA中的存储器模型:从IP核到ROM的深度解析与应用实例
网络协议·tcp/ip·fpga开发
FPGA小c鸡2 天前
【FPGA深度学习加速】RNN与LSTM硬件加速完全指南:从算法原理到硬件实现
rnn·深度学习·fpga开发
Aaron15882 天前
通信灵敏度计算与雷达灵敏度计算对比分析
网络·人工智能·深度学习·算法·fpga开发·信息与通信·信号处理
博览鸿蒙3 天前
IC 和 FPGA,到底区别在哪?
fpga开发
思尔芯S2C3 天前
FPGA原型验证实战:如何应对外设连接问题
fpga开发·risc-v·soc设计·prototyping·原型验证
Flamingˢ3 天前
FPGA实战:VGA成像原理、时序详解与Verilog控制器设计与验证
fpga开发
FPGA_小田老师3 天前
xilinx原语:OSERDES2(并串转换器)原语详解
fpga开发·lvds·xilinx原语·oserdese·并串转换