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

相关推荐
9527华安11 小时前
国产安路FPGA开发设计培训课程,提供开发板+工程源码+视频教程+技术支持
fpga开发·fpga·安路·视频教程·培训·安路fpga
UVM_ERROR18 小时前
硬件设计实战:解决Valid单拍采样失效问题(附非阻塞赋值与时序对齐核心要点)
驱动开发·fpga开发·github·芯片
brave and determined18 小时前
可编程逻辑器件学习(day36):从沙粒到智能核心:芯片设计、制造与封装的万字全景解析
fpga开发·制造·verilog·fpga·芯片设计·硬件设计·芯片制造
步达硬件1 天前
【FPGA】FPGA开发流程
fpga开发
我爱C编程2 天前
【仿真测试】基于FPGA的完整16QAM通信链路实现,含频偏锁定,帧同步,定时点,Viterbi译码,信道,误码统计
fpga开发·16qam·帧同步·卷积编码·viterbi译码·维特比译码·频偏锁定
s09071363 天前
ZYNQ DMA to UDP 数据传输系统设计文档
网络协议·fpga开发·udp
燎原星火*3 天前
QSPI IP核 基本参数
fpga开发
XINVRY-FPGA3 天前
XCVU9P-2FLGC2104I Xilinx AMD Virtex UltraScale+ FPGA
嵌入式硬件·机器学习·计算机视觉·fpga开发·硬件工程·dsp开发·fpga
FPGA_小田老师3 天前
FPGA Debug:PCIE一直自动重启(link up一直高低切换)
fpga开发·pcie debug·pcie初始化问题
hexiaoyan8273 天前
视频信号检测板卡:208-Base Camera Link 图像信号模拟器
fpga开发·图像信号模拟器·视频信号检测·视频信号分析·智能图像分析