加入星計(jì)劃,您可以享受以下權(quán)益:

  • 創(chuàng)作內(nèi)容快速變現(xiàn)
  • 行業(yè)影響力擴(kuò)散
  • 作品版權(quán)保護(hù)
  • 300W+ 專業(yè)用戶
  • 1.5W+ 優(yōu)質(zhì)創(chuàng)作者
  • 5000+ 長期合作伙伴
立即加入
  • 正文
    • 7.5  仿真測試文件(Testbench)的設(shè)計(jì)方法
  • 相關(guān)推薦
申請入駐 產(chǎn)業(yè)圖譜

FPGA系統(tǒng)設(shè)計(jì)的仿真驗(yàn)證之: 仿真測試文件(Testbench)的設(shè)計(jì)方法

2013/08/26
1
加入交流群
掃碼加入
獲取工程師必備禮包
參與熱點(diǎn)資訊討論

?

7.5??仿真測試文件(Testbench)的設(shè)計(jì)方法

7.5.1??測試文件的用途

隨著設(shè)計(jì)量和復(fù)雜度的不斷增加,數(shù)字設(shè)計(jì)驗(yàn)證變得越來越難,所消耗的成本也越來越高。面對這種挑戰(zhàn),驗(yàn)證工程師必須依靠相應(yīng)的驗(yàn)證工具和方法才行。對于大型的設(shè)計(jì),比如上百萬門的設(shè)計(jì)驗(yàn)證,工程師必須使用一整套規(guī)范的驗(yàn)證工具;而對于較小的設(shè)計(jì),使用具有HDL?testbench的仿真器是一個(gè)不錯(cuò)的選擇。

Testbench已經(jīng)成為了HLL(High-Level-Language,高級(jí)語言)設(shè)計(jì)標(biāo)準(zhǔn)驗(yàn)證方法。一般來說,它能夠完成下面一些任務(wù)。

·??實(shí)例化DUT(Design?Under?Test,被測設(shè)計(jì))。

·??通過為模塊添加測試向量對DUT進(jìn)行仿真。

·??通過終端或波形窗口提供仿真結(jié)果。

·??比較實(shí)際輸出與期望輸出的差異。

一般來說,Testbench使用工業(yè)標(biāo)準(zhǔn)VHDL或者Verilog?HDL語言來描述。簡單的Testbench通過調(diào)用用戶設(shè)計(jì)的功能模塊,然后進(jìn)行仿真。較為復(fù)雜的Testbench還包括一些其他的功能,比如包含特定的激勵(lì)向量或者進(jìn)行實(shí)際輸出與期望輸出的比較等。

如圖7.32所示是一個(gè)標(biāo)準(zhǔn)的HDL驗(yàn)證流程,圖中表達(dá)了上述的Testbench功能。

圖7.32??HDL?Testbench仿真流程

?

由于Testbench是使用VHDL或者Verilog?HDL編寫的,因此Testbench的驗(yàn)證流程是跨平臺(tái)的。同時(shí)由于這兩種語言是標(biāo)準(zhǔn)的非私有語言,所以使用它們進(jìn)行驗(yàn)證的流程可以在未來的設(shè)計(jì)中繼續(xù)使用。

下面講解Testbench的設(shè)計(jì)方法。

7.5.2??測試文件設(shè)計(jì)方法

由于測試文件只是在仿真時(shí)使用,因此在綜合中對RTL語言的語法限制在測試文件中并不存在。相反地,測試文件可以編寫得更加通俗,所有的行為結(jié)構(gòu)語法都可以使用,使之更加容易理解。所有的測試文件都包含了如表7.1所示的結(jié)構(gòu)。

表7.1 測試文件的共同結(jié)構(gòu)

VHDL

Verilog?HDL

實(shí)體和結(jié)構(gòu)聲明(Entity,Architecture)

模塊聲明(Module)

信號(hào)聲明(Signal)

信號(hào)生命(Signal)

頂層模塊實(shí)例化

頂層模塊實(shí)例化

激勵(lì)向量

激勵(lì)向量

?

正如所述,測試文件除了包含這些共有的結(jié)構(gòu)意外,還完成一些額外的工作。例如顯示結(jié)果、嵌入的誤碼檢測等。下面通過一些例子來展現(xiàn)測試文件中常用的結(jié)構(gòu)。

1.產(chǎn)生測試時(shí)鐘

仿真必須產(chǎn)生時(shí)鐘才能進(jìn)行,只有在推進(jìn)的仿真時(shí)鐘中才可以判定輸出的結(jié)果是否符合設(shè)計(jì)的要求。交互時(shí)鐘是硬件設(shè)計(jì)語言里面最容易實(shí)現(xiàn)的時(shí)鐘,下面通過Verilog語言的例子來說明如何生成測試時(shí)鐘。

Parameter ClockPeriod = 10;???????? // 聲明時(shí)鐘周期常量

//時(shí)鐘生成方法1:

???? initial begin

????????? forever Clock = #(ClockPeriod / 2) ~ Clock;

???? end

//時(shí)鐘生成方法2:

???? initial begin

????????? always #(ClockPeriod / 2) Clock = ~Clock;

???? end

在兩種實(shí)現(xiàn)方法中,都是用了initial塊語句。在方法1中,使用了forever語句,是最常用的產(chǎn)生時(shí)鐘的方法。在方法2中,使用過了always語句,同樣也實(shí)現(xiàn)了時(shí)鐘的生成。兩種方法都產(chǎn)生了周期為10?的時(shí)鐘波形。

2.提供激勵(lì)源

為了得到Testbench的驗(yàn)證結(jié)果,必須為DUT提供激勵(lì)向量。并行激勵(lì)模塊常常被用來為測試文件提供必要的激勵(lì)。有兩種不同的方法來實(shí)現(xiàn)并行的激勵(lì):一種是絕對時(shí)間激勵(lì),另一種是相對時(shí)間激勵(lì)。

在絕對時(shí)間激勵(lì)中,所有的仿真時(shí)間值都是相對仿真時(shí)間零點(diǎn)定義的。而在相對時(shí)間激勵(lì)中,一般會(huì)提供初始化值,然后等待事件來觸發(fā)激勵(lì)向量。兩種方法都可以根據(jù)設(shè)計(jì)者的需要在同一個(gè)測試文件中使用。

下面分別是兩種方法產(chǎn)生激勵(lì)的例子。

(1)絕對時(shí)間。

initial?begin

?????Reset?=?1;????????????????//仿真時(shí)間零點(diǎn)激勵(lì)

?????Load?=?0;?????????????????//仿真時(shí)間零點(diǎn)激勵(lì)

?????Count_UpDn?=?0;??????????//仿真時(shí)間零點(diǎn)激勵(lì)

?????#100?Reset?=?0;??????????//絕對時(shí)間100激勵(lì)

?????#20?Load?=?1;????????????//絕對時(shí)間120激勵(lì),相對上一個(gè)時(shí)間點(diǎn)20

?????#20?Count_UpDn?=?1;?????//絕對時(shí)間140激勵(lì),相對上一個(gè)時(shí)間點(diǎn)20

end

(2)相對時(shí)間。

always?@?(posedge?clock)

?????TB_Count?<=?TB_Count?+?1;????//絕對時(shí)間的遞增

initial?begin

?????if?(TB_Count?<=?5)????begin????//觸發(fā)事件,產(chǎn)生下列激勵(lì)

???????????Reset?=?1;

???????????Load?=?0;

???????????Count?_UpDn?=?0;

???????????end

?????else?begin????????????????//觸發(fā)事件,產(chǎn)生下列激勵(lì)

???????????Reset?=?0;

???????????Load?=?1;

???????????Count_UpDn?=?1;

?????end

end

initial?begin

?????if?(Count?==?1100)?begin????//觸發(fā)事件,產(chǎn)生歸零激勵(lì),并顯示結(jié)果

???????????Count_UpDn?<=?0;

???????????$display("Terminal?Count?Reached,?now?counting?down.");

???????????end

end

值得注意的是,Verilog?HDL語言的initial模塊之間是并行執(zhí)行的,但是initial模塊內(nèi)部是順序執(zhí)行的。也就是說,測試文件的激勵(lì)順序在仿真時(shí)間零點(diǎn)同時(shí)啟動(dòng)并行模塊,然后根據(jù)各個(gè)模塊的內(nèi)部激勵(lì)順序產(chǎn)生激勵(lì)向量。

3.結(jié)果輸出

測試文件通過關(guān)鍵詞$display和$monitor來實(shí)現(xiàn)結(jié)果的輸出。下面是使用Verilog?HDL語言實(shí)現(xiàn)在終端上顯示結(jié)果的例子:

//?在終端中打印信號(hào)的ASCII值

initial?begin

??????$timeformat(-9,1,"ns",12);?????????????????????????????????//設(shè)置輸出時(shí)鐘格式

??????$display("?Time?Clk?Rst?Ld?SftRg?Data?Sel");???????????//顯示輸入的字符串

??????$monitor("%t?%b?%b?%b?%b?%b?%b",????????????????????????//設(shè)置輸出信號(hào)的格式

??????$realtime,?clock,?reset,?load,?shiftreg,?data,?sel);?//指定輸出的信號(hào)

end

$display是將函數(shù)內(nèi)部雙引號(hào)中的字符串輸出在終端中。而$monitor則不同,因此它的輸出是事件驅(qū)動(dòng)的。在例子中,$monitor信號(hào)列表中的$realtime信號(hào)變化會(huì)觸發(fā)終端顯示事件的發(fā)生,該信號(hào)被設(shè)計(jì)者對應(yīng)到仿真時(shí)間中,每次$monitor的觸發(fā)將會(huì)把信號(hào)列表中的信號(hào)值顯示在終端中。

$monitor語句中的“%”用于定義信號(hào)列表中信號(hào)的輸出格式。例如,%t將信號(hào)按照時(shí)間格式輸出,%b將信號(hào)按照二進(jìn)制格式輸出。另外,Verilog?HDL語言還提供了其他的輸出格式,比如%h為十六進(jìn)制輸出,%d為十進(jìn)制輸出,%o為八進(jìn)制輸出等。更為詳細(xì)的格式輸出定義可以參看Verilog參考手冊。

?

7.5.3??測試常用語句

常用的Verilog測試用結(jié)構(gòu)語句,比如$monitor、$display和$time在上面已經(jīng)介紹過了。下面再來介紹一些其他的常用語句。

1.force/release

force和release語句可以用來強(qiáng)制對執(zhí)行過程中的寄存器或網(wǎng)絡(luò)型信號(hào)量賦值。這兩條語句共同完成一個(gè)強(qiáng)制賦值的過程。當(dāng)一個(gè)被force的信號(hào)被release以后,這個(gè)信號(hào)將會(huì)保持當(dāng)時(shí)的狀態(tài)直到下一個(gè)賦值語句產(chǎn)生為止。

下面舉個(gè)例子來說明這兩條語句的使用。

module?testbench;

?????...

?????initial?begin

??????????reset?=?1;????????????????//在仿真時(shí)間零點(diǎn)將reset激勵(lì)為1

??????????force?DataOut?=?101;????//在仿真時(shí)間零點(diǎn)強(qiáng)制使DataOut為101,并保持

??????????#25?reset?=?0;???????????//在仿真絕對時(shí)間25將reset激勵(lì)為0

??????????#25?release?DataOut;????//在仿真絕對時(shí)間50釋放

??????????????????????????????????????//?DataOut值將保持直至下一個(gè)對它的賦值語句

??????????...

??????????end

endmodule

2.a(chǎn)ssign/deassign

assign/deassign語句與force/release語句相類似,不過assign/deassign語句只能對設(shè)計(jì)中的寄存器型信號(hào)賦值。它們常常被用來設(shè)置輸入值。

下面是這兩個(gè)語句的例子。

module?testbench;

?????...

?????initial?begin

??????????reset?=?1;??????????????//絕對時(shí)間零點(diǎn)對reset賦值1

??????????DataOut?=?101;

??????????#25?reset?=?0;?????????//絕對時(shí)間25對reset賦值0

??????????release?DataOut;

??????????...

?????end

?????initial?begin

??????????#20?assign?reset?=?1;?//此條語句覆蓋之前的賦值語句(即絕對時(shí)間零點(diǎn)的賦值)

??????????#25?reset?=?0;??????????//絕對時(shí)間45對reset賦值0

??????????#50?release?reset;?????//絕對時(shí)間95釋放reset信號(hào)

endmodule

3.timescales

timescale語句用于定義測試文件的單位時(shí)間,同時(shí)也對仿真的精度有影響。它的語法定義如下:

‘timescale?reference_time/precision

其中,reference_time是單位時(shí)間的度量,precision決定了仿真的推進(jìn)延遲精度,同時(shí)也設(shè)置了仿真的推進(jìn)步進(jìn)單位。下面是timescale語句的使用范例:

‘timescale?1?ns?/?1?ps???????????//度量參考為1ns,精度為1ps

module?testbench;

?????...

?????initial?begin

??????????#5?reset?=?1;????????????//?5個(gè)仿真時(shí)間延遲,相當(dāng)于5×1ns?=?5ns?的仿真時(shí)間

??????????#10?reset?=?0;

??????????...

??????????end

?????initial?begin

??????????//display語句將在每一個(gè)仿真推進(jìn)步進(jìn)中執(zhí)行,也就是1ps執(zhí)行一次

??????????$display?(“%d?,?Reset?=?%b”,?$time,?reset);

??????????end

endmodule

應(yīng)該注意的是,如果仿真中使用了時(shí)間延遲值,那么仿真的精度應(yīng)大于最小的延遲值。例如仿真中使用了9ps的仿真時(shí)間延遲,那么仿真的推進(jìn)步進(jìn)精度必須為1ps來保證9ps的延遲。

4.Reading?Memory?Initialization?Files

Verilog?HDL提供了$readmemb和$readmemh命令來讀取ASCII文件,用于初始化memory的內(nèi)容。這兩個(gè)語句可以用于初始化FPGA中由IP?Core生成的存儲(chǔ)器宏模塊,例如RAM、ROM等。

下面是利用這個(gè)語句對Xilinx的實(shí)例(design_instance)進(jìn)行初始化的例子。

$readmemb?(“<design.mif>”,?design_instance);

其中,mif文件是Xilinx的Core?Generator建立的對存儲(chǔ)器進(jìn)行初始化的文件。用戶也可以自己編寫這個(gè)文件的內(nèi)容。

相關(guān)推薦

登錄即可解鎖
  • 海量技術(shù)文章
  • 設(shè)計(jì)資源下載
  • 產(chǎn)業(yè)鏈客戶資源
  • 寫文章/發(fā)需求
立即登錄

華清遠(yuǎn)見(www.farsight.com.cn)是國內(nèi)領(lǐng)先嵌入師培訓(xùn)機(jī)構(gòu),2004年注冊于中國北京海淀高科技園區(qū),除北京總部外,上海、深圳、成都、南京、武漢、西安、廣州均有直營分公司。華清遠(yuǎn)見除提供嵌入式相關(guān)的長期就業(yè)培訓(xùn)、短期高端培訓(xùn)、師資培訓(xùn)及企業(yè)員工內(nèi)訓(xùn)等業(yè)務(wù)外,其下屬研發(fā)中心還負(fù)責(zé)嵌入式、Android及物聯(lián)網(wǎng)方向的教學(xué)實(shí)驗(yàn)平臺(tái)的研發(fā)及培訓(xùn)教材的出版,截止目前為止已公開出版70余本嵌入式/移動(dòng)開發(fā)/物聯(lián)網(wǎng)相關(guān)圖書。企業(yè)理念:專業(yè)始于專注 卓識(shí)源于遠(yuǎn)見。企業(yè)價(jià)值觀:做良心教育、做專業(yè)教育,更要做受人尊敬的職業(yè)教育。