精品国产人成在线_亚洲高清无码在线观看_国产在线视频国产永久2021_国产AV综合第一页一个的一区免费影院黑人_最近中文字幕MV高清在线视频

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

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

3天內不再提示

這些Debug調試方法你知道多少?(上篇)

jf_78858299 ? 來源:芯片學堂 ? 作者:JKZHAN ? 2023-01-21 17:18 ? 次閱讀

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

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

Debug這一主題被拆成了兩篇文章,第一篇《SystemVerilog | 這些Debug調試方法你都知道嗎?| Part I》主要介紹的是一些基礎和常用的調試方法,而Part II將緊接著介紹其他一些工具、方法和想法。

方法4:可視化調試

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

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

圖片

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

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

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

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

圖片

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

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

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

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

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

  1. 通過Hierarchy等窗口瀏覽源代碼的例化層次結構,類繼承關系等;
  2. 通過查找Driver和Load來定位信號的傳播通路(這個是用的最多的);
  3. 通過Filter來分類查看當前文件包含的輸入輸出信號、參數、變量等;
  4. 通過查找來定位某一個module例化出來的所有模塊;
  5. 原理圖和狀態機跳轉圖可以有限地幫助你理解代碼行為;
  6. 配合波形文件查看各種信號隨時間變化的行為;
  7. 調試工具的功能還有很多,具體可以查看各個工具的官方介紹和培訓視頻。

方法5:SVA斷言在調試中的應用

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

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

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

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

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

圖片

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

方法6:軟件調試方法的借鑒和應用

這一節的內容更像是討論,有哪些軟件開發中用到的調試方法,或者問題定位策略是可以借鑒過來應用到芯片驗證中的。

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

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

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

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 調試
    +關注

    關注

    7

    文章

    572

    瀏覽量

    33897
  • 代碼
    +關注

    關注

    30

    文章

    4746

    瀏覽量

    68348
  • DEBUG
    +關注

    關注

    3

    文章

    89

    瀏覽量

    19884
收藏 人收藏

    評論

    相關推薦

    Xilinx FPGA遠程調試方法(二)

    上篇主要是分享了Vivado編譯軟件遠程調試方法。杰克使用Vivado軟件進行遠程連接,主要是用于固化程序以及FPGA(PL端)的異常排查。而本篇主要內容是對使用Vitis軟件遠程調試
    發表于 05-25 14:36 ?2625次閱讀
    Xilinx FPGA遠程<b class='flag-5'>調試</b><b class='flag-5'>方法</b>(二)

    經驗分享:查看例程時出現#ifdef DEBUG debug();#endif

    [table][tr][td] 在查看例程的時候,經常會發現如下現象: #ifdef DEBUGdebug(); #endif 知道是作為debug---也就是調試用的,但是不清楚其具體的表現
    發表于 07-06 02:19

    STM32的調試技巧知道哪些

    如何對STM32進行調試呢?STM32的調試技巧知道哪些?
    發表于 10-25 08:25

    關于5G知道這些,含5G覆蓋查詢方法

    真5G網絡來了,但要先知道這些!(附5G覆蓋查詢方法
    的頭像 發表于 08-27 17:03 ?1.7w次閱讀

    關于變壓器的這些冷知識,知道嗎?

    變壓器的這些冷知識,知道嗎?
    的頭像 發表于 02-04 15:28 ?4507次閱讀

    STM32F1系列DEBUG調試功能需要配置嗎?

    STM32F1系列的DEBUG調試功能需要配置嗎?
    的頭像 發表于 03-01 13:57 ?3310次閱讀

    淺談STM32調試DEBUG相關知識

    說說STM32調試DEBUG相關知識
    的頭像 發表于 03-06 15:23 ?4121次閱讀

    Vivado使用技巧:debug仿真設計的三種調試方法

    源代碼級別調試 Vivado Simulator提供了在仿真過程中debug設計的特性,通過為源代碼添加一些可控制的執行條件來檢查出問題的地方。總的來說有三種調試方法: 1.使用Ste
    的頭像 發表于 12-29 15:57 ?1.6w次閱讀
    Vivado使用技巧:<b class='flag-5'>debug</b>仿真設計的三種<b class='flag-5'>調試</b><b class='flag-5'>方法</b>

    示波器的這些安全操作知道嗎?

    示波器的這些安全操作知道嗎?示波器維修。很多人都知道示波器是用來干什么的,也知道示波器都有哪些種類和品牌,當然也
    發表于 11-05 11:19 ?1669次閱讀

    配置VScode編譯、調試STM32(二)Cortex-Debug插件

    配置VScode編譯、調試STM32(二)Cortex-Debug插件
    發表于 12-01 12:21 ?17次下載
    配置VScode編譯、<b class='flag-5'>調試</b>STM32(二)Cortex-<b class='flag-5'>Debug</b>插件

    STM32(Cortex-M)內核DEBUG調試接口知識

    學習STM32開發,肯定少不了debug調試這一步驟。那么,本文帶你了解一下這個調試相關的知識。
    發表于 02-08 16:02 ?9次下載
    STM32(Cortex-M)內核<b class='flag-5'>DEBUG</b><b class='flag-5'>調試</b>接口知識

    hypervisor的調試分析方法

    我們在編寫裸機程序(baremetal)、虛擬化管理程序(hypervisor)和操作系統(OS)時,Debug分析程序是必不可少的。不像linux內核,有大量的調試方法,很多裸機程序、hypervisor沒有完善的
    的頭像 發表于 10-08 09:40 ?1403次閱讀

    這些Debug調試方法知道多少?(下篇)

    調試指的是在遇到工程問題的時候,通過一些手段來進一步診斷問題原因,探索解決方法,最終使得系統功能正常運行的必要過程。
    的頭像 發表于 01-21 17:27 ?1073次閱讀
    <b class='flag-5'>這些</b><b class='flag-5'>Debug</b><b class='flag-5'>調試</b><b class='flag-5'>方法</b><b class='flag-5'>你</b><b class='flag-5'>知道</b>多少?(下篇)

    無源與有源器件的這些區別知道嗎?

    無源與有源器件的這些區別知道嗎?
    的頭像 發表于 10-26 15:27 ?4707次閱讀
    無源與有源器件的<b class='flag-5'>這些</b>區別<b class='flag-5'>你</b>都<b class='flag-5'>知道</b>嗎?

    這些磁棒電感發熱解決方法知道幾個

    這些磁棒電感發熱解決方法知道幾個 gujing 編輯:谷景電子 磁棒電感在使用中發熱是比較普遍的問題之一,但假如發熱嚴重就需要及時進行處理,不然就會影響到設備的性能和運作。所以,磁棒
    的頭像 發表于 03-06 22:10 ?369次閱讀