实例1:利用Modelsim 对Xinlinx 公司Virtex-II 产品DCM 模块进行仿真。
如图1 所示。
图1 基于Virtex-II 系列DCM 的模块设计图
Sl_Clk_i 为100MHz 的输入时钟,Sl_Rst_i 为复位控制信号,输入时钟经过一输入缓冲器后输入到DCM 的CLKIN 端,通过参数设置,我们分别设置无相位差控制,相位差3.5ns 和相位差4.2ns,利用Modelsim 对以上三种情况分别进行仿真得到的结果如图2(a)(b)(c)所示:
图2 相位延迟的Modelsim 仿真波形
从仿真结果来看,在无相位差控制的情况下,输出时钟相位延迟了2.38ns,在相位差为3.8ns 时,从图2(b)看出,输出时钟提前了近1.12ns,图2(c)中可以看出在相位差为4.2ns 的情况下,得到的输出时钟又向前提前了720ps。
通过实际测试分别得到图3(a)(b)(c)所示的波形图,从图3(a)可以看出,在没有相位差控制的情况下,输出时钟相位推迟了4.24ns,当将输出时钟相位差为3.5ns 时,从图3(b)可以看出,输出时钟相位还延迟了720ps,图3(c)显示了在相位差4.2ns 的情况下,输入时钟与输出时钟相位几乎完全一致。
(a) 无相位差控制的测试波形
(b) 相位差3.5ns 的测试波形
(c) 相位差4.2ns 的测试波形
图3 相位差的示波器实测波形
从实测波形与仿真波形的比较可以看出,仿真结果与实测结果还是比较吻合的,两者结果差别仅为1.88ns,造成这种差异的原因在于这么两个原因:
实例2:利用Modelsim 对亚稳态设计进行仿真及纠错
在具有异步设计的数字电路中,经常会由于数据的建立时间或保持时间不够的原因而造成亚稳态的错误。我们曾经在设计中曾经利用时钟锁存数据,但在设计过程中出现了数据建立时间和保持时间不够的情况,通过Modelsim 进行仿真,我们发现,数据输出端的采集数据出现错误,如图4(a)所示。为了纠正这一错误,我们一方面在设计中将时钟信号经过门延时对时钟的相位进行相应调节,另一方面利用较快的时钟对数据进行同步处理,然后再用调节后的时钟进行数据采集。再用Modelsim 进行仿真,发现数据输出端的采集数据符合采集要求,如图4(b)所示。
(a) 亚稳态采数错误
(b) 修改后的设计采数正确
图4 亚稳态问题示意图
文章评论(0条评论)
登录后参与讨论