Verilog中的Timescale做用

不少时候,咱们拿到已有的东西理所固然的用了,其实,你真的对你所使用的东西了解吗?编译

再次犯下这样的错误,是由于在把代码从Altera 的CycloneV移植到Xilinx的Spartan6上,我遇到了很是奇怪的问题:test

在modelsim下,对Xilinx平台下的代码进行功能仿真,发现工程中Xilinx的IP核所有都有异常, 乱七八糟的错。model

为此,还向FAE求助?可是最终的问题是出如今timescale上,这里,对timescale进行一次详细的梳理,为了不之后程序

还会出现相似的错误im

timescale是Verilog HDL 中的一种时间尺度预编译指令,它用来定义模块的仿真 时的时间单位和时间精度。格式以下:异常

`timescale 仿真时间单位/时间精度文件

注意:用于说明仿真时间单位和时间精度的 数字只能是一、十、100,不能为其它的数字。并且,时间精度不能比时间单位还要大。最多两则同样大。好比:下面定义都是对的:时间

`timescale 1ns/1ps工作

`timescale 100ns/100nstime

下面的定义是错的:

`timescale 1ps/1ns 仿真的单位时间是不能小于时间精度的!

时间精度就是模块仿真时间和延时的精确程序,

回头讲讲为啥我仿真IP核会工做异常,由于个人testbench中,定义了两个timescale,

timescale 1ps/1ps

timescale 1ns/1ps

源文件中的

timescale 1ns/1ps

 

最终的结果就致使modelsim 仿真Xilinx的IP功能时序混乱了!

相关文章
相关标签/搜索