原创 关于`timescale(转载)

2009-1-15 20:23 5745 8 8 分类: FPGA/CPLD

关于`timescale(转载)<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />


    在Verilog HDL 模型中,所有时延都用单位时间表述。使用`timescale编译器指令将时间单位与实际时间相关联。该指令用于定义时延的单位和时延精度。`timescale编译器指令格式为:


 


`timescale time_unit / time_precision


time_unit time_precision 由值110、和100以及单位smsusnspsfs组成。例如:


 


`timescale 1ns/100ps


 


表示时延单位为1ns, 时延精度为100ps`timescale 编译器指令在模块说明外部出现, 并且影响后面所有的时延值。例如:


 


`timescale 1ns/ 100ps


MODULE AndFunc (Z, A, B);


OUTPUT Z;


input A, B;


 


and # (5.22, 6.17 ) Al (Z, A, B);


//规定了上升及下降时延值。


endMODULE


 


  编译器指令定义时延以ns为单位,并且时延精度为1/10 ns100 ps)。因此,时延值5.22对应5.2 ns, 时延6.17对应6.2 ns。如果用如下的`timescale程序指令代替上例中的编译器指令,


 


`timescale 10ns/1ns


 


那么5.22对应52ns, 6.17对应62ns


 


  在编译过程中,`timescale指令影响这一编译器指令后面所有模块中的时延值,直至遇到另一个`timescale指令或`resetall指令。当一个设计中的多个模块带有自身的`timescale编译指令时将发生什么?在这种情况下,模拟器总是定位在所有模块的最小时延精度上,并且所有时延都相应地换算为最小时延精度。例如,


 


`timescale 1ns/ 100ps


MODULE AndFunc (Z, A, B);


OUTPUT Z;


input A, B;


 


and # (5.22, 6.17 ) Al (Z, A, B);


endMODULE


 


`timescale 10ns/ 1ns


MODULE TB;


reg PutA, PutB;


WIRE GetO;


 


initial


begin


PutA = 0;


PutB = 0;


#5.21 PutB = 1;


#10.4 PutA = 1;


#15 PutB = 0;


end


AndFunc AF1(GetO, PutA, PutB);


endMODULE


 


在这个例子中,每个模块都有自身的`timescale编译器指令。`timescale编译器指令第一次应用于时延。因此,在第一个模块中,5.22对应5.2 ns, 6.17对应6.2 ns; 在第二个模块中5.21对应52 ns, 10.4对应104 ns, 15对应150 ns。如果仿真模块TB,设计中的所有模块最小时间精度为100 ps。因此,所有延迟(特别是模块TB中的延迟)将换算成精度为100 ps。延迟52 ns现在对应520*100 ps104对应1040*100 ps150对应1500*100 ps。更重要的是,仿真使用100 ps为时间精度。如果仿真模块AndFunc,由于模块TB不是模块AddFunc的子模块,模块TB中的`timescale程序指令将不再有效。


 


 


参考资料:


1.      http://blog.ednchina.com/thinkker/159517/message.aspx


 


 


 


关于verilog timescale的讨论


verilog中是没有默认timescale的。一个没有指定timescaleverilog模块就有可能错误的继承了前面编译模块的无效timescale参数。


所以在verilogLRM中推荐在每个module的前面指定`timescale,并且相应的在最后加一个`resetall来确保timescale的局部有效


 


为了确认这种用法,我编写了一个小小的包含两个模块module_amodule_btestbench,其中module_a,module_btestbench指定了不同的timescale精度。通过simulation的波形可以发现,Simulator的确在不同的module中使用了不同的times精度。


 


代码如下:


文件名:module_a.v


`timescale 100ps/1ps


 


module a (clk) ;


input clk;


wire clk_a ;


 


assign #5 clk_a = clk;


 


endmodule


 


`resetall


 


文件名:module_b.v


`timescale 10ps/1ps


 


module b (clk) ;


input clk;


wire clk_b ;


 


assign #5 clk_b = clk;


 


endmodule


 


`resetall


 


文件名:testbench.v


`timescale 1ns/10ps


 


module tb();


reg clk;


 


initial begin


clk = 0;


end


 


initial


begin


$fsdbDumpvars;


#12500 $finish;


end


 


 


always begin


#10 clk = ~clk;


end


 


a a_inst(clk);


b b_inst(clk);


 


endmodule


 


波形如下:


 


<?xml:namespace prefix = v ns = "urn:schemas-microsoft-com:vml" />


点击看大图 


 


结论:


从上面的波形中可以看出,虽然使用了相同的delay表述:


assign #5 clk_a(b) = clk;

但由于在module中指定的timescale精度不同,在实际的simulationdelay的长度是不同的,但都是等于5×timescale最小精度

文章评论0条评论)

登录后参与讨论
我要评论
0
8
关闭 站长推荐上一条 /2 下一条