今天看了很多博主寫的關(guān)于verilog中的timescale的東西,收獲很多。將大家的東西轉(zhuǎn)載一下,并加點(diǎn)自己的整理東西。
在Verilog HDL 模型中,所有時(shí)延都用單位時(shí)間表述。使用`timescale編譯器指令將時(shí)間單位與實(shí)際時(shí)間相關(guān)聯(lián)。該指令用于定義時(shí)延的單位和時(shí)延精度。`timescale編譯器指令格式為:
imescale time_unit / time_precision
time_unit 和time_precision 由值1、10、和100以及單位s、ms、us、ns、ps和fs組成。例如:
`imescale 1ns/100ps
表示時(shí)延單位為1ns, 時(shí)延精度為100ps。`timescale 編譯器指令在模塊說明外部出現(xiàn), 并且影響后面所有的時(shí)延值。例如:
`timescale 1ns/ 100ps
MODULE AndFunc (Z, A, B);
OUTPUT Z;
input A, B;
and # (5.22, 6.17 ) Al (Z, A, B);
//規(guī)定了上升及下降時(shí)延值。
endMODULE
編譯器指令定義時(shí)延以ns為單位,并且時(shí)延精度為1/10 ns(100 ps)。因此,時(shí)延值5.22對應(yīng)5.2 ns, 時(shí)延6.17對應(yīng)6.2 ns。如果用如下的`timescale程序指令代替上例中的編譯器指令,
`timescale 10ns/1ns
那么5.22對應(yīng)52ns, 6.17對應(yīng)62ns。
在編譯過程中,`timescale指令影響這一編譯器指令后面所有模塊中的時(shí)延值,直至遇到另一個(gè)`timescale指令或`resetall指令。當(dāng)一個(gè)設(shè)計(jì)中的多個(gè)模塊帶有自身的`timescale編譯指令時(shí)將發(fā)生什么?在這種情況下,模擬器總是定位在所有模塊的最小時(shí)延精度上,并且所有時(shí)延都相應(yīng)地?fù)Q算為最小時(shí)延精度。
(以下轉(zhuǎn)自另一篇文章:)
在verilog中是沒有默認(rèn)timescale的。一個(gè)沒有指定timescale的verilog模塊就有可能錯(cuò)誤的繼承了前面編譯模塊的無效timescale參數(shù)。
所以在verilog的LRM中推薦“在每個(gè)module的前面指定`timescale,并且相應(yīng)的在最后加一個(gè)`resetall來確保timescale的局部有效”
在編譯過程中,`timescale指令影響這一編譯器指令后面所有模塊中的時(shí)延值,直至遇到另一個(gè)`timescale指令或`resetall指令。當(dāng)一個(gè)設(shè)計(jì)中的多個(gè)模塊帶有自身的`timescale編譯指令時(shí)將發(fā)生什么?在這種情況下,模擬器總是定位在所有模塊的最小時(shí)延精度上,并且所有時(shí)延都相應(yīng)地?fù)Q算為最小時(shí)延精度。例如,
`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
在這個(gè)例子中,每個(gè)模塊都有自身的`timescale編譯器指令。`timescale編譯器指令第一次應(yīng)用于時(shí)延。因此,在第一個(gè)模塊中,5.22對應(yīng)5.2 ns, 6.17對應(yīng)6.2 ns; 在第二個(gè)模塊中5.21對應(yīng)52 ns, 10.4對應(yīng)104 ns, 15對應(yīng)150 ns。如果仿真模塊TB,設(shè)計(jì)中的所有模塊最小時(shí)間精度為100 ps。因此,所有延遲(特別是模塊TB中的延遲)將換算成精度為100 ps。延遲52 ns現(xiàn)在對應(yīng)520*100 ps,104對應(yīng)1040*100 ps,150對應(yīng)1500*100 ps。更重要的是,仿真使用100 ps為時(shí)間精度。如果仿真模塊AndFunc,由于模塊TB不是模塊AddFunc的子模塊,模塊TB中的`timescale程序指令將不再有效。
為了確認(rèn)這種用法,我編寫了一個(gè)小小的包含兩個(gè)模塊module_a和module_b的testbench,其中module_a,module_b與testbench指定了不同的timescale精度。通過simulation的波形可以發(fā)現(xiàn),Simulator的確在不同的module中使用了不同的times精度。
代碼如下:
文件名:module_a.v
`timescale 100ps/1ps
module module_a (clk) ;
input clk;
wire clk_a ;
assign #5 clk_a = clk;
endmodule
`resetall
文件名:module_b.v
`timescale 10ps/1ps
module 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;
#12 $finish;
end
always begin
#1 clk = ~clk;
end
module_a a_inst(clk);
module_b b_inst(clk);
endmodule
針對這三個(gè)文件,進(jìn)行不同的修改,得到不同的波形:
對應(yīng)源文件生成的波形圖如下:
另: 注意使用timescale時(shí),前面為" ` ",體現(xiàn)在鍵盤上為數(shù)字鍵“1”前的按鍵,否則,編譯時(shí)會(huì)出現(xiàn)以下問題:
** Error: src/counter16_tb.v(6): near "'t": Illegal base specifier in numeric constant.
** Error: src/counter16_tb.v(6): near "'t": expecting: LIBRARY CONFIG
** Error: src/counter16_tb.v(6): Expecting numeric digits.
|