91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

SystemVerilog中bind用法總結(jié)+送實驗源碼和腳本

芯片驗證日記 ? 來源:芯片驗證日記 ? 作者:芯片驗證日記 ? 2023-01-11 08:59 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

1.前言

bind是systemverilog中一個重要的知識點,很多時候能夠在驗證中發(fā)揮重要的作用,今天就針對這個知識點做一個梳理,希望能幫助到大家。

2. 為什么需要bind

當(dāng)RTL已經(jīng)編寫完畢,驗證工程師有責(zé)任添加斷言時。RTL設(shè)計者不希望驗證工程師為了添加斷言而修改其RTL,于是SystemVerilog的綁定特性應(yīng)運而生。bind可以實現(xiàn)驗證和設(shè)計的分離,將module/interface/program綁定到任意的設(shè)計模塊或者其特定例化中,可以將interface直接bind到top module中進(jìn)行例化。bind可以使得驗證工程師不改動或最小的改動原有設(shè)計代碼和文件結(jié)構(gòu),就能夠?qū)崿F(xiàn)對設(shè)計代碼的檢查。

SystemVerilog斷言(SVA)可以直接添加到RTL代碼中,也可以通過bindfile間接添加。實踐表明,大多數(shù)的斷言最好是使用bindfile添加。在獨立的文件中寫入所有必需的斷言,使用bind就可以將斷言文件的端口與測試代碼中RTL的端口/信號綁定。這是多么酷的一個功能。

3. bind的語法

bind用于指定module、interface、program的一個或多個實例化,而無需修改目標(biāo)文件的代碼。因此,封裝在module、interface、program中的插入代碼或斷言可以以非侵入方式(non-intrusive manner)在目標(biāo)模塊或模塊實例中實例化。類似地,封裝在接口中的檢測代碼可以綁定到目標(biāo)接口或接口實例。

SVA檢驗器通過關(guān)鍵字bind可以與設(shè)計中的任何模塊(module)或者實例(instance)綁定。將SVA檢驗器可以與模塊、模塊的實例或者一個模塊的多個實例進(jìn)行bind綁定。實現(xiàn)綁定時,使用的是設(shè)計中的實際信號,語法如下:


bind ;

這里注意以下幾點:

[1] 通過bind語句將SVA的checker與設(shè)計模塊綁定,等價于將SVA例化到設(shè)計模塊中。

[2] bind不僅可以將斷言與設(shè)計module綁定,也可以將任意兩個模塊之間進(jìn)行綁定。

[3] bind功能可用于以下位置:

pYYBAGO9SyCAIRw_AAHGbcqxaZs341.png

4. bind的具體應(yīng)用實例

4.1 通過模塊名實現(xiàn)綁定

語法:bind module_name sva_name sva_inst;

具體實例的代碼如下圖所示:

poYBAGO9S1SAEFLxAAQH_dnyFnw213.png

針對上圖中代碼的一些解釋:

[1] dut 是module的名字

[2] dut_assert 是內(nèi)部包含 property 以及斷言的模塊,可以是 module 或者 interface

[3] my_assert是dut_assert的實例化名字

[4] 括號中的信號clk/rst_n/vld/rdy是dut的端口信號,并且連接到dut_assert的對應(yīng)端口

[5] 包含斷言的interface/module,其端口信號的方向均為input,也就是說property中包含的信號都是從該interface/module外部給進(jìn)來的。

bind成功后,斷言會關(guān)聯(lián)到module_name的所有例化示例,sva_inst路徑位于rtl_inst下一層,參考下面仿真器中的hierarchy結(jié)構(gòu):

poYBAGO9S5aAO3B4AALc3gMNbag086.png

具體的實驗源代碼和腳本,請參考分享的網(wǎng)盤鏈接中的basic目錄。

4.2 通過模塊實例化名實現(xiàn)綁定

語法:bind module_name:mudule_inst_name sva_name sva_inst;

具體實例的代碼如下圖所示:

pYYBAGO9S8yASX9kAAQXjJBVP5g577.png

注意跟4.1的區(qū)別:

上圖中第64行中,對dut的實例化my_dut1和my_dut2進(jìn)行bind。

下圖中的hierarchy結(jié)構(gòu)圖和上圖中的代碼是正確對應(yīng)的,這也很好理解。

pYYBAGO9S_-AGAK3AANFJMDf9IA074.png

具體的實驗源代碼和腳本,請參考分享的網(wǎng)盤鏈接中的basic目錄。

4.3 通過模塊名實現(xiàn)bind的另一個例子

前面的例子對bind的基本用法已經(jīng)講的很清楚了,下面的例子只是想說明下面這一點:可以將需要的所有斷言寫入獨立的文件中,使用bind也可以將斷言文件的端口與測試臺代碼中RTL的端口/信號綁定。下面是這個例子的詳細(xì)代碼截圖。

下圖是testbench(最大的module)的代碼截圖:

pYYBAGO9TDqAMKNdAAPyPv-aTEg495.png

下圖是DUT代碼的截圖:

poYBAGO9TGmATDUCAAGr6CnB2P8445.png

下圖是斷言模塊:

pYYBAGO9TJiADw1DAALrierxAKQ989.png

如下圖所示,bind功能單獨寫在一個獨立module中,這種用法EDA工具也是支持的,這是這個例子跟上面例子的最大區(qū)別。

pYYBAGO9TMeAcy6OAALWZ0EYUOA867.png

注意理解下圖中的hierarchy結(jié)構(gòu),

pYYBAGO9TPWAemONAAExYw1LjDo190.png

具體的實驗源代碼和腳本,請參考分享的網(wǎng)盤鏈接中的asic-world目錄。

4.4 參數(shù)化bind的實例

從前面的例子,我們可以很好的理解SV中的綁定命令允許向模塊添加新功能,通常用于向RTL模塊添加新的檢查。再往深里研究一下,bind還可以繼承參數(shù),綁定模塊可以根據(jù)其使用位置參數(shù)化自身。

下面的代碼用于演示bind的參數(shù)化特性,該特性允許綁定模塊(bdut模塊)根據(jù)其使用位置參數(shù)化自身。

當(dāng)查看bind語句(下圖中第29行)時,它使用的所有參數(shù)都沒有在第29行定義,但當(dāng)綁定被激活時,它就有了參數(shù)化自身的作用域。其實也很好理解,我們可以想象把第29行粘貼到“dut”中;在那里所有的定制參數(shù)都將流到“bdut”的實例化中。

需要注意的一個特殊情況是,第29行的“.Z()”參數(shù)化為空。這允許“bdut”的默認(rèn)值接管。第10行根據(jù)參數(shù)化在“bdut”中創(chuàng)建“邏輯[X]總線”。這可用于生成參數(shù)化覆蓋點或其他需要參數(shù)化的功能。

poYBAGO9TSyAJdsAAAMuvrwcSLg506.png

具體的實驗源代碼和腳本,請參考分享的網(wǎng)盤鏈接中的parameter_bind-master目錄。

5. 通過interface實現(xiàn)bind功能

這在用法上跟上面模塊的例子一模一樣,只是把module換成interface即可,這里就不再贅述了。

6. 贈送實驗源碼和Makefile腳本

關(guān)注微信公眾號《芯片驗證日記》,后臺回復(fù)”bind”,可得本文所有的源碼和Makefile腳本對應(yīng)的百度鏈接,目錄如下圖所示,這樣你就可以在本地復(fù)現(xiàn)本文中的所有。

pYYBAGO9TVqAXQBxAABkeriucIU376.png

審核編輯:湯梓紅
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • Verilog
    +關(guān)注

    關(guān)注

    30

    文章

    1374

    瀏覽量

    114525
  • System
    +關(guān)注

    關(guān)注

    0

    文章

    166

    瀏覽量

    38670
  • 源碼
    +關(guān)注

    關(guān)注

    8

    文章

    685

    瀏覽量

    31319
  • Bind
    +關(guān)注

    關(guān)注

    0

    文章

    5

    瀏覽量

    7827
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    從Linux源碼分析bind系統(tǒng)調(diào)用

    眾所周知,一個Server端Socket的建立,需要socket、bind、listen、accept四個步驟。
    的頭像 發(fā)表于 10-16 11:08 ?4193次閱讀
    從Linux<b class='flag-5'>源碼</b>分析<b class='flag-5'>bind</b>系統(tǒng)調(diào)用

    SystemVerilog的Virtual Methods

    SystemVerilog多態(tài)能夠工作的前提是父類的方法被聲明為virtual的。
    發(fā)表于 11-28 11:12 ?1141次閱讀

    Bind源代碼包安裝

    先到官方下載Bind的安裝包 wgetftp://ftp.isc.org/isc/bind9/9.6.0-P1/bind-9.6.0-P1.tar.gz tar xzvf
    發(fā)表于 04-04 20:30 ?23次下載

    OpenCV3編程入門-源碼例程全集-resize函數(shù)用法示例

    OpenCV3編程入門-源碼例程全集-resize函數(shù)用法示例
    發(fā)表于 09-18 16:38 ?2次下載

    OpenCV3編程入門-源碼例程全集-sobel函數(shù)用法示例

    OpenCV3編程入門-源碼例程全集-sobel函數(shù)用法示例
    發(fā)表于 09-18 16:38 ?1次下載

    OpenCV3編程入門-源碼例程全集-Scharr函數(shù)用法示例

    OpenCV3編程入門-源碼例程全集-Scharr函數(shù)用法示例
    發(fā)表于 09-18 16:38 ?0次下載

    OpenCV3編程入門-源碼例程全集-remap函數(shù)用法示例

    OpenCV3編程入門-源碼例程全集-remap函數(shù)用法示例
    發(fā)表于 09-18 16:38 ?0次下載

    OpenCV3編程入門-源碼例程全集-pyrDown函數(shù)用法示例

    OpenCV3編程入門-源碼例程全集-pyrDown函數(shù)用法示例
    發(fā)表于 09-18 16:38 ?1次下載

    OpenCV3編程入門-源碼例程全集-pyrUp函數(shù)用法示例

    OpenCV3編程入門-源碼例程全集-pyrUp函數(shù)用法示例
    發(fā)表于 09-18 16:38 ?0次下載

    STM32實驗10輸入捕獲實驗源碼

    STM32 實驗10 輸入捕獲實驗源碼
    發(fā)表于 05-05 16:06 ?7次下載

    SystemVerilog枚舉類型的使用建議

    SystemVerilog枚舉類型雖然屬于一種“強(qiáng)類型”,但是枚舉類型還是提供了一些“不正經(jīng)”的用法可以實現(xiàn)一些很常見的功能,本文將示例一些在枚舉類型使用過程的一些“不正經(jīng)”
    的頭像 發(fā)表于 09-01 14:20 ?2640次閱讀

    SystemVerilog的Shallow Copy

    SystemVerilog的句柄賦值和對象復(fù)制的概念是有區(qū)別的。
    的頭像 發(fā)表于 11-21 10:32 ?1496次閱讀

    SystemVerilogifndef如何避免重復(fù)編譯

    `ifndef是SystemVerilog/Verilog的一種條件編譯命令,可以認(rèn)為其是"if not defined"的縮寫,其用法與`ifdef相反,他們主要用來根據(jù)其后
    的頭像 發(fā)表于 06-25 15:59 ?4627次閱讀
    <b class='flag-5'>SystemVerilog</b><b class='flag-5'>中</b>ifndef如何避免重復(fù)編譯

    什么是bind?你真的熟悉bind嗎?

    bind()方法創(chuàng)建一個新的函數(shù),在bind()被調(diào)用時,這個新函數(shù)的this被指定 bind()的第一個參數(shù),而其余參數(shù)將作為新函數(shù)的參數(shù),供調(diào)用時使用。
    的頭像 發(fā)表于 07-13 09:56 ?6698次閱讀

    Linux bind的核心執(zhí)行函數(shù)

    bind的核心執(zhí)行函數(shù) bind系統(tǒng)調(diào)用的核心函數(shù)調(diào)用流程如下: SYSCALL_DEFINE3( bind , int , fd, struct sockaddr __user
    的頭像 發(fā)表于 07-31 10:51 ?1235次閱讀