在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

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

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

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

介紹SystemVerilog幾種常用的調(diào)試功能

sanyue7758 ? 來源:芯片學(xué)堂 ? 2023-01-09 11:51 ? 次閱讀

在工作日里,如果你問驗證工程師在干嘛,多半時間他/她會告訴你在Debug。換句話說,一般在驗證周期內(nèi),工程師有超過一半的時間都消耗在了功能調(diào)試上,盡管這里面包含了驗證工程師跟自己“作對”的時間,即驗證環(huán)境或者測試用例本身存在bug。所以,調(diào)試這項工作還是很重要的!

調(diào)試這項工作除了要求工程師對設(shè)計規(guī)范(Specification)、DUT(Design Under Test)、測試環(huán)境(testbench)結(jié)構(gòu)和用例(test case)的測試意圖有一定的了解,掌握必要的工具、方法和技巧也十分重要,它能夠幫助工程師獲得更多有效的信息,加速問題定位,提高工作效率。

方法4:可視化調(diào)試

可視化調(diào)試主要分為Post-process和Interactive這兩種模式。可視化調(diào)試工具是工程師在定位代碼問題時的有力工具,也是現(xiàn)在驗證工程師主流的調(diào)試工具。工具的使用一般可以參考官方的用戶手冊(User Guide),也能夠在官網(wǎng)上找到相應(yīng)的培訓(xùn)鏈接和視頻

常用的可視化調(diào)試工具有Synopsys家的Verdi,Siemens家的Visualizer,還有Cadence家的SimVision。對于個人用戶來說,可能沒有辦法去實操體驗,但通常所在公司會購買至少一家的License。三家公司的工具的操作流程和基礎(chǔ)調(diào)試功能都差不多,然后又分別有自己調(diào)試的獨特功能。

2a8e2f5c-8d49-11ed-bfe3-dac502259ad0.jpg

先介紹下后處理調(diào)試模式(post-process,即在仿真結(jié)束之后再去可視化和處理仿真結(jié)果,有些地方會叫做PPE,post-processing environment)的使用,因為這種方式在實際工作中用的比較多。在使用可視化調(diào)試工具之前,通常需要將testbench和RTL編譯到同一個數(shù)據(jù)庫中,該數(shù)據(jù)庫包含了文件信息、RTL例化層次信息、信號連接關(guān)系等等,以供調(diào)試工具的追蹤和分析。

如果使用Verdi工具,需要使用VCS在編譯(Compilation=Analysis+Elaboration)的時候,通過加參數(shù)-kdb -lca來生成KDB庫(Knowledge Database),其中l(wèi)ca(Limited Customer Availability Features)參數(shù)是為了指定工具特性。KDB數(shù)據(jù)庫格式是Verdi專用的格式,所以KDB庫有時候也可以叫Verdi庫。打開verdi的時候使用命令verdi加參數(shù)-elab來選擇該KDB庫。

如果使用Visualizer工具,需要使用Questa/ModelSim在對設(shè)計完成編譯(vlog/vcom)之后,使用vopt命令加參數(shù)-debug -designfile design.bin來生成.bin文件,同樣該文件格式是Visualizer專用的。打開Visualizer的時候使用命令visualizer加參數(shù)-designfile來選擇該bin文件,使用參數(shù)-wavefile來選擇db波形文件。

如果使用SimVision工具,需要在仿真階段使用NC仿真器或者XCelium仿真器(具有更高的仿真性能,比如支持多核等)將設(shè)計和波形都導(dǎo)出成shm格式。在仿真結(jié)束之后,你可以看到名為example.shm的目錄,該目錄下會有兩個文件:.dsn文件和.trn文件,前者包含的是設(shè)計的信息(類似于我們上面說的數(shù)據(jù)庫),后者包含的是波形信息。打開SimVision的時候使用命令simvision直接加example.shm來打開待調(diào)試的數(shù)據(jù)庫。

2a94671e-8d49-11ed-bfe3-dac502259ad0.jpg

再看看交互模式(interactive mode),交互模式相對于后處理模式增加了仿真控制的功能,即可以設(shè)置仿真斷點、控制仿真的暫停、運行和重啟等,并實時地觀察到信號的行為。交互模式下,上述EDA工具的界面上會多出來一些調(diào)試控件。不過這種模式的仿真運行速度比較慢,且在分發(fā)和重現(xiàn)代碼行為上不是很友好,所以在實際工作中也用的比較少,除非遇到非常棘手但卻摸不著頭腦的問題。以上提到的幾家工具都支持交互模式調(diào)試,操作流程也都差不多,并且跟后處理模式一樣也需要先編譯出來一個數(shù)據(jù)庫。

如果使用Synopsys家的工具,在設(shè)置完必要的環(huán)境變量之后,比如VCS_HOME和VERDI_HOME,需要使用VCS命令vcs -kdb -lca -debug_access+all 編譯出KDB庫和simv可執(zhí)行的仿真文件,然后在執(zhí)行simv的時候加上參數(shù)-verdi就可以打開交互模式下的Verdi了,這個時候調(diào)試器和仿真器是關(guān)聯(lián)起來的。

如果使用Siemens家的工具,同樣在設(shè)置完必要的環(huán)境變量并使用命令vopt編譯出design.bin文件之后,可以使用命令vsim -visualizer=design.bin -qwavedb=+signal+class -f 打開交互模式下的Visualizer,便可以在調(diào)試工具界面去控制仿真器。

如果使用Cadence家的工具,那就相對復(fù)雜一點,因為Cadence前前后后有幾個仿真器,比如verilog、ncsim、irun,并且進交互調(diào)試模式的方法也比較多樣,但大致可以分兩種:一種是可以通過參數(shù)-gui直接開啟帶SimVision的仿真器,另一種方式是單獨啟動SimVision,使用參數(shù)-connect host/pid連接到運行在本地或者遠端的仿真上。

以上命令只是展示大概的使用過程,實際應(yīng)以對應(yīng)版本的用戶手冊為準哈。當(dāng)你打開可視化調(diào)試工具調(diào)試界面之后,有這么幾種常用的調(diào)試功能:

通過Hierarchy等窗口瀏覽源代碼的例化層次結(jié)構(gòu),類繼承關(guān)系等;

通過查找Driver和Load來定位信號的傳播通路(這個是用的最多的);

通過Filter來分類查看當(dāng)前文件包含的輸入輸出信號、參數(shù)、變量等;

通過查找來定位某一個module例化出來的所有模塊;

原理圖和狀態(tài)機跳轉(zhuǎn)圖可以有限地幫助你理解代碼行為;

配合波形文件查看各種信號隨時間變化的行為;

調(diào)試工具的功能還有很多,具體可以查看各個工具的官方介紹和培訓(xùn)視頻。

方法5:SVA斷言在調(diào)試中的應(yīng)用

概述:SystemVerilog Assertion(斷言)主要用于驗證設(shè)計的行為,并且可以提供功能覆蓋率信息。Assertion可以應(yīng)用于兩種不同的驗證方法中,一種是在動態(tài)仿真中去動態(tài)地檢查各個既定屬性(property)是否滿足,另一種測試用于Formal驗證工具去證明設(shè)計是否符合規(guī)范。

作用:如果你剛接觸,可以把斷言簡單理解成checker或者monitor,它指的是在設(shè)計中嵌入一些工程師根據(jù)待測特性自行定義的一些屬性,仿真的時候仿真工具會去判斷這些屬性是否成立,以此來判斷某個特性是否實現(xiàn)正確。SVA在本文中作為調(diào)試的方法來介紹,就是因為斷言可以幫助我們監(jiān)測屬性,為我們報出來哪些時刻行為正常、哪些時刻行為異常,且這些行為可以是有時序的!

分類:在SystemVerilog中,斷言大致可以分為兩類:立即斷言(immediate assertion)和并發(fā)斷言(concurrent assertion)。立即斷言是基于仿真事件(simulation event)的,當(dāng)它被執(zhí)行到的時候就會立即對多定義的屬性做出判斷并給出結(jié)果;而并發(fā)斷言是基于時鐘的,斷言的評估(evaluate)發(fā)生在時鐘邊沿,這也使得并發(fā)斷言具有監(jiān)測的能力,這也是下面要主要介紹的。

結(jié)構(gòu):斷言的具體實現(xiàn)依賴于更基礎(chǔ)的元素,比如sequence和property。Sequence是最底層的元素,它可以復(fù)用和嵌套。Sequence可以用來定義簡單的布爾表達式,也可以用來描述多周期的時序行為。Property則可以實現(xiàn)跟sequence一樣的內(nèi)容,也可以通過組合不同的sequence來構(gòu)造更加復(fù)雜的時序行為。為了規(guī)范化,建議將嵌入的時鐘信號@(posedge clk)放在property這一層,而將sequence跟時鐘獨立開來,方便基礎(chǔ)sequence的復(fù)用。

調(diào)度:SystemVerilog的仿真基于事件驅(qū)動模型,事件的調(diào)度機制在SV語言標準中有明確說明。該調(diào)度機制將每個仿真時刻(time slot)再劃分成多個region,如下圖所示,每個region都有自己明確的操作。仿真調(diào)度算法的確定,可以使得仿真環(huán)境跟DUT交互時顯示出同步的效果。其中跟SVA相關(guān)的region有Preponed、Observed和Reactive。在Preponed中,SVA會對有關(guān)聯(lián)的變量完成采樣;在Observed中,多有的property完成評估,即判斷斷言描述是否成立;在Reactive中,執(zhí)行斷言評估結(jié)果需要采取的對應(yīng)的操作。

2a9f994a-8d49-11ed-bfe3-dac502259ad0.png

應(yīng)用:斷言的應(yīng)用主要可以分成四個步驟:1、構(gòu)造基礎(chǔ)布爾表達式;2、構(gòu)造sequence序列;3、構(gòu)造斷言屬性property;4、將屬性代碼插入或綁定(bind)到待測模塊中。SVA提供了一些好用又強大的功能:判斷信號邊沿和狀態(tài)、添加延時來構(gòu)造信號時序行為、支持構(gòu)造不定周期的時序窗口、判斷過去的信號狀態(tài)、支持斷言的邏輯運算等等,本文篇幅顯然是不夠的了。

方法6:軟件調(diào)試方法的借鑒和應(yīng)用

這一節(jié)的內(nèi)容更像是討論,有哪些軟件開發(fā)中用到的調(diào)試方法,或者問題定位策略是可以借鑒過來應(yīng)用到芯片驗證中的。

有個前提需要明確的是,硬件仿真始終是基于事件驅(qū)動的程序執(zhí)行過程,盡管仿真調(diào)度機制簡潔明了,但往往待測設(shè)計規(guī)模龐大(具體表現(xiàn)為硬件行為具備并行性質(zhì),一個時鐘信號的翻轉(zhuǎn)事件關(guān)聯(lián)著成千上萬的信號動作),所以硬件仿真的運行速度會非常的慢,這是跟單純軟件程序的一個顯著區(qū)別。

運行速度上的差異帶來了調(diào)試方法上的一些不同。軟件調(diào)試中交互式的操作非常多,比如解釋執(zhí)行的腳本(比如Python)不需要編譯就可以馬上得到執(zhí)行的結(jié)果,又比如基于斷點的調(diào)試可以非常容易地檢查變量值和堆棧跟蹤。反觀硬件調(diào)試,工程師很難快速地知道在哪里設(shè)置斷點,往往需要反復(fù)的嘗試,這會浪費掉很多時間。因此硬件的調(diào)試更多依賴于信息的導(dǎo)出,其形式通常是仿真日志和波形文件。

如何提高硬件調(diào)試的交互性可能是軟件調(diào)試帶來的啟示,有這么一些不成熟的想法,比如是否可以增加調(diào)試信息(代碼、波形和仿真日志)之間的關(guān)聯(lián),實現(xiàn)自動化跳轉(zhuǎn);是否可以增加工具對代碼的理解或者記錄調(diào)試過程來進行自動化分析;是否可以在增量編譯的概念上實現(xiàn)增量仿真;等等等等。







審核編輯:劉清

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

    關(guān)注

    4

    文章

    267

    瀏覽量

    31794
  • VCS
    VCS
    +關(guān)注

    關(guān)注

    0

    文章

    79

    瀏覽量

    9608
  • DUT
    DUT
    +關(guān)注

    關(guān)注

    0

    文章

    189

    瀏覽量

    12382

原文標題:SystemVerilog | 這些Debug調(diào)試方法你都知道嗎?| Part II

文章出處:【微信號:處芯積律,微信公眾號:處芯積律】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    單片機Debug工具性能對比 單片機調(diào)試常用命令

    。以下是對單片機調(diào)試工具性能的簡要對比以及一些常用調(diào)試命令。 單片機Debug工具性能對比 Keil uVision 性能 :Keil uVision 是一款功能強大的集成開發(fā)環(huán)境(
    的頭像 發(fā)表于 12-19 09:56 ?213次閱讀

    Minitab常用功能介紹 如何在 Minitab 中進行回歸分析

    Minitab是一款強大的質(zhì)量管理統(tǒng)計軟件,為質(zhì)量改善、教育和研究應(yīng)用領(lǐng)域提供統(tǒng)計軟件和數(shù)據(jù)分析工具。以下是對Minitab常用功能介紹,以及使用Minitab進行回歸分析的具體步驟
    的頭像 發(fā)表于 12-02 15:38 ?611次閱讀

    【AI技術(shù)支持】ESP32無線Wi-Fi常用調(diào)試API

    Wi-Fi常用調(diào)試API在使用esp32調(diào)試Wi-Fi功能時,由于場景和各種因素的影響,難免會遇到各種連接不上,Wi-Fi斷連等問題。下面介紹
    的頭像 發(fā)表于 10-26 08:00 ?593次閱讀
    【AI技術(shù)支持】ESP32無線Wi-Fi<b class='flag-5'>常用</b><b class='flag-5'>調(diào)試</b>API

    室內(nèi)北斗定位系統(tǒng)常用幾種定位方式

    隨著科技的不斷進步,室內(nèi)定位技術(shù)日益成熟,為人們的日常生活和工作帶來了極大的便利。特別是在室內(nèi)環(huán)境中,北斗衛(wèi)星定位系統(tǒng)通過一系列創(chuàng)新技術(shù),實現(xiàn)了高精度、高可靠的定位服務(wù)。接下來就由深圳滄穹科技給大家具體介紹室內(nèi)北斗定位系統(tǒng)常用幾種
    的頭像 發(fā)表于 09-23 10:00 ?408次閱讀

    幾種常用的共模電感磁芯類型

    電子發(fā)燒友網(wǎng)站提供《幾種常用的共模電感磁芯類型.docx》資料免費下載
    發(fā)表于 09-20 11:27 ?0次下載

    嵌入式常用總線有哪些

    嵌入式系統(tǒng)中常用的總線種類繁多,它們各自具有不同的特點和應(yīng)用場景。以下將詳細介紹幾種嵌入式開發(fā)中常用的總線,包括UART、I2C、SPI、RS-232、RS-485、CAN以及USB等
    的頭像 發(fā)表于 09-10 11:34 ?621次閱讀

    shell基本介紹常用命令之shell介紹

    是“$”,在命令提示符后邊輸入命令即可和系統(tǒng)進行交互操作。Ubuntu默認的Shell是Bash(Bourne Again Shell)。Linux命令有很多,功能比較強大,下節(jié)我們簡單介紹一些常用
    發(fā)表于 08-15 09:28

    思科設(shè)備常用的巡檢命令介紹

    思科(Cisco)設(shè)備在網(wǎng)絡(luò)領(lǐng)域具有廣泛的應(yīng)用,其可靠性和功能強大使其成為許多企業(yè)網(wǎng)絡(luò)基礎(chǔ)設(shè)施的核心。然而,確保這些設(shè)備始終高效運行,定期進行巡檢是必不可少的。這篇文章將詳細介紹思科設(shè)備巡檢中常用的命令,幫助網(wǎng)絡(luò)管理員了解并掌握
    的頭像 發(fā)表于 08-12 18:16 ?619次閱讀

    新思科技Verdi調(diào)試平臺的功能

    ,以及確保不同功能場景和測試模式的正確性等。每個階段都可能耗費大量時間,有時需要多次迭代,導(dǎo)致整個調(diào)試過程不斷延長。
    的頭像 發(fā)表于 08-12 10:03 ?370次閱讀
    新思科技Verdi<b class='flag-5'>調(diào)試</b>平臺的<b class='flag-5'>功能</b>

    PLC遠程調(diào)試模塊是什么?PLC遠程調(diào)試模塊的功能

    PLC(可編程邏輯控制器)遠程調(diào)試模塊是一種設(shè)備或軟件功能,它允許工程師或技術(shù)人員在遠離實際現(xiàn)場的情況下,通過網(wǎng)絡(luò)對PLC進行編程、監(jiān)控、故障診斷和參數(shù)調(diào)整。這對于分布廣泛或難以直接接觸的工業(yè)
    的頭像 發(fā)表于 05-22 14:53 ?740次閱讀
    PLC遠程<b class='flag-5'>調(diào)試</b>模塊是什么?PLC遠程<b class='flag-5'>調(diào)試</b>模塊的<b class='flag-5'>功能</b>

    幾種常用單片機的在線升級能力比較

    電子發(fā)燒友網(wǎng)站提供《幾種常用單片機的在線升級能力比較.pdf》資料免費下載
    發(fā)表于 03-24 09:39 ?2次下載

    在Vivado Synthesis中怎么使用SystemVerilog接口連接邏輯呢?

    SystemVerilog 接口的開發(fā)旨在讓設(shè)計中層級之間的連接變得更加輕松容易。 您可以把這類接口看作是多個模塊共有的引腳集合。
    的頭像 發(fā)表于 03-04 15:25 ?964次閱讀
    在Vivado Synthesis中怎么使用<b class='flag-5'>SystemVerilog</b>接口連接邏輯呢?

    常用封裝尺寸資料介紹

    電子發(fā)燒友網(wǎng)站提供《常用封裝尺寸資料介紹.zip》資料免費下載
    發(fā)表于 02-29 09:23 ?0次下載

    介紹6種常見的反調(diào)試方法

    是一種防止逆向的方案。逆向人員如果遇到復(fù)雜的代碼混淆,有時會使用調(diào)試器動態(tài)分析代碼邏輯簡化分析流程。例如惡意軟件通常會被安全研究人員、反病毒廠商和其他安全專業(yè)人員分析和調(diào)試,以了解其行為和功能,并
    的頭像 發(fā)表于 01-15 09:53 ?3866次閱讀
    <b class='flag-5'>介紹</b>6種常見的反<b class='flag-5'>調(diào)試</b>方法

    常用的角速度傳感器包括幾種類型

    常用的角速度傳感器包括幾種類型? 常用的角速度傳感器包括以下幾種類型: 1. 陀螺儀:陀螺儀是最常見的角速度傳感器之一。它通過測量旋轉(zhuǎn)物體相對于某個參考點的角速度來確定旋轉(zhuǎn)物體的角度變
    的頭像 發(fā)表于 01-03 17:13 ?1493次閱讀
    主站蜘蛛池模板: 人人艹人人插| 中文字幕在线观看一区二区| 亚洲视频一区网站| 色香焦| 成年看片免费高清观看| 国产全部理论片线观看| 短篇禁伦小说| 美女视频毛片| 免费观看成年欧美1314www色| 免费一区在线观看| 美国一级毛片不卡无毒| 人人天天夜夜| 国产精品久久久久久久久免费观看| 日本黄大乳片免费观看| 天天躁天天爽| 美女露出尿口让男人桶爽网站| 人人看人人玩| 日日操操干干| 一级片高清| 丁香花在线影院观看在线播放| 爱爱视频天天干| 四虎a456tncom| 午夜久久免费视频| 欧美一卡二卡科技有限公司| 美女拍拍拍爽爽爽爽爽爽| 男女性高爱麻豆| 亚洲 欧洲 日韩| 悠悠影院欧美日韩国产| 日本一视频一区视频二区| 噜噜吧噜噜色| 波多野结衣一级特黄毛片| 特级淫片aaaaa片毛片| 天天综合天天添夜夜添狠狠添| 女上男下边吃奶边做视频成都| 九色综合久久综合欧美97| 网站黄色在线观看| 欧美一区二区三区免费看| 久久久久久久影院| 四虎网址最新| 欧美亚洲韩国国产综合五月天| 亚洲欧美日韩综合一区|