數字IC前端設計——前仿篇(VCS,DVE,Verdi)

文章目錄

  • 引言
  • 一、軟件介紹
    • 1. VCS
    • 2. DVE
    • 3. Verdi
  • 二、VCS的使用
    • 1. VCS的編譯流程
    • 2. 常用的編譯選項
      • 1)基礎編譯選項
      • 2)調試相關選項
      • 3)性能優化選項
      • 4)文件和路徑選項
    • 3. 常用仿真選項
      • 1)基礎仿真選項
      • 2)運行控制選項
      • 3)調試和分析選項
    • 3. VCS生成物
    • 4. 波形文件的生成
      • 1)VCD (Value Change Dump)的生成
      • 2)VPD (Verilog Procedural Dump)的生成
      • 3)FSDB (Fast Signal Database)的生成
  • 三、DVE/Verdi波形查看
    • 1. DVE查看波形
    • 2. Verdi查看波形
  • 四、VCS-Verdi lab(入門)
    • 1. 文件管理
    • 2. VCS編譯和仿真
      • 1)一步(推薦)
      • Verdi查看波形
      • DVE查看波形(需要修改tb中的波形生成部分成vpd和vcd)
      • 2)兩步
      • DVE查看波形
      • Verdi查看波形
    • 3. makefile
  • 附錄
    • 1. ALU代碼
    • 2. TestBench代碼


參考文獻
VCS使用教程 (Synopsys VCS Simulator Tutorial)
Linux下VCS與Verdi聯合仿真簡易教程及例子示范
Verdi快速使用技巧
Verdi的使用

引言

??在FPGAer/ICer的實際項目中,仿真無疑占了大量的時間。我想對于仿真工具有人更傾向于使用Vivado、ModelSim、QuestaSim這些編譯-仿真-看波形一體化的工具,也有人更傾向于VCS(編譯仿真)、Verdi和DVE(看波形)這些獨立功能的工具。兩者各有優劣。

??前者工具鏈簡單易上手,甚至Vivado除了編譯、仿真和看波形以外還能實現綜合、布局布線等等功能,可謂神器。但是前者也有明顯的缺點,比如說綜合、編譯、仿真速度很慢。

??而后者工具鏈較為復雜,編譯和看波形為獨立的工具。如果在做ASIC項目中,后者會更加方便和專業。首先,VCS編譯和仿真速度極快,效率極高,能夠大量節約仿真時間(仿真速度:FPGA>VCS>ModelSim/QuestaSim>Vivado)。而Verdi查看波形也十分方便,支持信號追溯等等功能。

??綜上所述,為了提高開發效率,下面將以一個簡單的ALU的工程來展示如何在Linux下使用VCS和Verdi進行邏輯仿真。此部分只涉及前仿,后仿涉及DC等綜合工具。

??可以看完第四部分跑完lab后再返回看VCS的詳細的選項功能

一、軟件介紹

1. VCS

?? VCS(Verilog Compiled Simulator)是 Synopsys 公司開發的一款高性能仿真工具,它采用編譯型仿真技術,將 Verilog/SystemVerilog 代碼編譯成優化的 C 代碼,再編譯成可執行文件,從而實現高速仿真。雖然 VCS 本身不直接提供圖形化調試界面,但它可以與 Synopsys 的其他工具(如 Verdi)集成,實現高效的調試和波形查看。

??同時,VCS 提供了豐富的編譯和仿真選項,可以根據設計需求進行靈活配置。VCS 提供了豐富的覆蓋率分析選項,包括行覆蓋率、條件覆蓋率、狀態機覆蓋率和翻轉覆蓋率等,有助于Verifier全面評估測試的充分性。

??為什么VCS會更快?因為VCS采用了編譯型仿真。相較于解釋型仿真(傳統模式),其優點在于仿真速度極快、內存使用效率高、支持大規模設計以及優化程度高,但是編譯時間較長、調試較為復雜并且修改代碼需要重新編譯。

2. DVE

??DVE(Design Verification Environment)是由Synopsys公司開發的一款強大的硬件設計驗證工具,主要用于協助工程師分析和調試仿真結果。DVE是集成在了VCS中。

3. Verdi

??Verdi 是 Synopsys 提供的一款強大的自動化電子設計自動化(EDA)工具,主要用于功能驗證和調試。Verdi 綜合了多種調試功能,如波形查看、信號追蹤、時序分析和覆蓋規劃等,為設計驗證工程師提供了一個全面的環境進行設計錯誤的識別和修正。Verdi是比DVE更強大的調試平臺,尤其在協議分析、性能分析和根本原因分析(RCA)方面表現出色。

??Verdi 工具集包括以下幾個組件:

  • Waveform Viewer (波形查看器):圖形化展示波形數據,支持對仿真數據進行深入分析。
  • Signal Spy (信號監視器):實時監測設計中的信號變化,用于調試。
  • Time Analysis (時序分析):分析設計中時序問題,幫助識別時序違規。
  • Coverage (覆蓋率分析器):分析驗證的覆蓋面,確保測試充分。
  • Data Mining (數據挖掘):利用高級算法來發現設計中的潛在問題。

二、VCS的使用

??值得注意的是VCS本身不提供圖形化界面,因此只能通過terminal來運行。

1. VCS的編譯流程

??VCS采用兩階段編譯模式,提供靈活性和高性能。

RTL源碼—>vlogan前端編譯—>生成數據庫文件—>vcs后端編譯—>生成simv可執行文件—>./simv仿真執行—>生成波形和日志  

??因此,VCS也提供了兩種編譯方式,分別為一步編譯(推薦用于簡單項目),兩步編譯(推薦用于復雜項目)。

# 一步編譯
vcs [編譯選項] [源文件] -o [輸出文件名]
# 兩步編譯
vlogan [編譯選項] [源文件]     # 前端編譯
vcs [鏈接選項] [頂層模塊] -o [輸出文件名]  # 后端編譯

??該文以一步編譯模式為主

2. 常用的編譯選項

1)基礎編譯選項

指令功能示例描述
-help顯示幫助文檔vcs -help查看vcs的可用選項
-full6464位編譯模式vcs -full64
-sverilog支持SystemVerilogvcs -sverilog
+v2k支持Verilog-2001vcs +v2k
-timescale指定時間精度vcs -timescale=1ns/1ps也可以tb中指定
-o 輸出文件名vcs -o my_sim默認simv
-kdb輸出fsdb文件需要vcs -kdb

2)調試相關選項

指令功能示例描述
-debug_access+all完全調試訪問vcs -debug_access+all查看所有信號
-debug_access+r只讀調試訪問vcs -debug_access+r只讀模式
-line啟用行號調試vcs -line
+lca生成覆蓋率數據庫vcs +lca用于覆蓋率分析
-cm 覆蓋率采集類型vcs -cm line+cond+fsm+tgl采集line/cond/fsm/tgl覆蓋率
-cm_dir 指定存放覆蓋率數據庫的目錄
-cm_name 為當次仿真產生的覆蓋率數據命名

NOTE:收集行覆蓋率(line)、條件覆蓋率(cond)、有限狀態機覆蓋率(fsm)和翻轉覆蓋率(tgl)

覆蓋率類型:
代碼覆蓋率 (Code Coverage)

  • line: 每行可執行代碼是否被執行。
  • cond: if-else、case語句的每個分支是否被走到。
  • fsm: 狀態機的每個狀態和狀態轉移是否被訪問。
  • tgl: 每個bit信號是否經歷了0->1和1->0的翻轉。

功能覆蓋率 (Functional Coverage):通過SystemVerilog的 covergroup 定義,衡量設計規格中的功能點是否被測試到。

斷言覆蓋率 (Assertion Coverage):衡量SVA斷言被觸發、成功和失敗的次數。

3)性能優化選項

指令功能示例描述
-Mupdate增量編譯vcs -Mupdate只編譯修改的文件
-j并行編譯核心數vcs -j88個CPU核心
-comp優化編譯vcs -comp編譯時優化
-no_save不保存中間文件vcs vcs -no_save節省可見
-fast快速模式vcs -fast

4)文件和路徑選項

指令功能示例描述
-f 文件列表vcs -f filelist.f包含源文件路徑
-v 庫文件vcs -v my_lib.v單個庫文件
-y庫目錄vcs -y ./lib單個庫目錄
+libext+庫文件擴展名+libext+.v+.sv搜索文件類型
+incdir+include目錄+incdir+./inc`include文件路徑
+define+預定義宏+define+SIM_MODE編譯時宏定義

3. 常用仿真選項

1)基礎仿真選項

指令功能示例描述
-R編譯后立即運行vcs -R tb.v一步完成
-gui啟動圖形界面./simv -gui=dveDVE調試界面,也可以-gui=verdi
-l 日志文件./simv -l sim.log指定仿真日志路徑
-s交互模式./simv -s在時間0停止

2)運行控制選項

指令功能示例描述
+ntb_random_seed=隨機種子./simv +ntb_random_seed=123確定性隨機序列
+vcs+lic_wait等待license./simv +vcs+lic_waitlicense不足時等待
+vcs+stop+指定停止時間./simv +vcs+stop+10001000時間單位后停止

3)調試和分析選項

指令功能示例描述
-ucli啟動UCLI./simv -ucli統一命令行界面
-vpd_file VPD文件名./simv -vpd_file sim.vpd指定波形文件
-cm_name 覆蓋率名稱./simv -cm_name test1覆蓋率數據庫名
-cm_dir 覆蓋率目錄./simv -cm_dir ./cov覆蓋率存儲路徑

3. VCS生成物

??執行vcs指令后一般會生成一些文件。其中比較關鍵的是:

  • simv:為可執行文件,可以使用./simv來運行仿真。
  • sim.log:為vcs的運行日志,名字為用戶自己設置。
  • csrc:存放vcs生成的C語言源碼。vcs將RTL代碼轉換成C代碼后再使用系統的C/C++編譯器來創建最終的可執行文件,
  • simv.daidir:為vcs的中間數據庫目錄,包含了設計的層次化信息。
  • .vcd/vpd/.fsdb:為波形文件,vcs生成,dve和verdi可以直接打開此類文件查看波形,無需重新編譯和仿真。

4. 波形文件的生成

??vcs可以生成不同格式的波形文件。常見的有以下三種:

格式優點缺點查看工具
VCD通用性強,可讀文件大,速度慢DVE,Verdi
VPD壓縮率高,VCS原生Synopsys生態DVE,Verdi
FSDB壓縮率極高,功能強Verdi生態Verdi

??以上這些波形文件格式的生成代碼需要放置再testbench中,指定波形文件格式和保存的內容。

1)VCD (Value Change Dump)的生成

//在Testbench中添加系統任務
initial begin$dumpfile("tb.vcd");$dumpvars(0, top_module_name); // 0表示dump所有層級
end

2)VPD (Verilog Procedural Dump)的生成

//在Testbench中添加 $vcdpluson; 系統任務,并在編譯時開啟調試選項。
initial begin$vcdpluson();
end

3)FSDB (Fast Signal Database)的生成

//需要Verdi的環境支持,并在Testbench中調用特定系統任務。
initial begin$fsdbDumpfile("tb.fsdb");$fsdbDumpvars(0, "top_module_name");
end

$fsdbDumpfile(fsdb_name[,limit_size])
指定波形文件名,第二個參數可選擇用來限制波形的大小(MB)。

$fsdbDumpvars([depth, instance][, “option”])
depth表示要加載波形的層次:
0表示當前instance下的所有變量以及其它module實例的波形;
1表示當前instance中的變量的波形,不包括當前instance中的其它module實例的波形;
2表示包含當前instance以及其中的第一級子instance的波形;以此類推。
instance指定要加載波形的module名。
option加載波形的選項:
+IO_Only – 只加載IO port信號;
+Reg_Only – 只加載reg類型信號;
+mda – 加載memory和MDA信號;
+packedmda – 加載packed MDA;
+struct – 加載structs;
+parameter – 加載parameter;
+fsdbfile+filename – 指定fsdb文件名字。(可覆蓋dumpfile操作)

三、DVE/Verdi波形查看

1. DVE查看波形

??DVE的啟動很簡單,只需要在vcs執行完生成vpd/vcd波形文件后,即可用以下指令打開。

dve -vpd vcdplus.vpd &
dve -vcd tb.vcd & 

2. Verdi查看波形

??Verdi的啟動也很簡單,只需要在vcs執行完生成vpd/vcd/fsdb波形文件后,即可用以下指令打開。

verdi -f filelist.f -ssf tb.fsdb &

四、VCS-Verdi lab(入門)

1. 文件管理

??首先,第一步就是進行文件管理。一般文件管理我采用以下結構,rtl用來放置RTL代碼,makefile為運行腳本,sim用來保存vcs仿真的結果和波形,tb用來放置testbench文件。此外,還有一個比較重要的便是設計文件列表filelist.f(注意文件的路徑正確)。
在這里插入圖片描述

在這里插入圖片描述

2. VCS編譯和仿真

1)一步(推薦)

??在sim路徑下打開terminal并執行以下指令
??單步執行的在編譯vcs時候加入了-R選項,使得vcs在編譯完后直接運行./simv。

# -kdb為生成fsdb所需,否則無法使用verdi打開
vcs -R -full64 -debug_access+all -timescale=1ns/1ps -f filelist.f

??執行完后得到一些文件,可見 第3小節文件生成物。值得關注的便是tb.fsdb波形文件。
在這里插入圖片描述

??單步編譯后可以直接查看波形。

Verdi查看波形

??在sim路徑下打開terminal并執行以下指令,啟動verdi

verdi -f filelist.f -ssf tb.fsdb &

??一開始可以看到沒有波形,需要右鍵選中alu,添加波形。
在這里插入圖片描述

??添加波形后
在這里插入圖片描述

DVE查看波形(需要修改tb中的波形生成部分成vpd和vcd)

# 使用dve查看波形(vcd,vpd)
dve -vpd vcdplus.vpd &
dve -vcd my_tb.vcd & 

2)兩步

??兩步執行的步驟在于先用vcs進行編譯得到simv可執行文件,然后再運行./simv文件產生波形文件,./simv可以指定DVE或者Verdi來查看仿真結果。

DVE查看波形

??在sim路徑下打開terminal并執行以下指令

# 步驟一,編譯,生成simv可執行文件
vcs -full64 -debug_access+all -timescale=1ns/1ps -f filelist.f
# 步驟二,仿真并使用dve打開gui界面
./simv -gui=dve & 

在這里插入圖片描述

添加波形
在這里插入圖片描述

在命令行中運行run,開始仿真
在這里插入圖片描述

Verdi查看波形

??在sim路徑下打開terminal并執行以下指令

# 步驟一,編譯,生成simv可執行文件
vcs -full64 -debug_access+all -kdb -timescale=1ns/1ps -f filelist.f
# 步驟二,仿真并使用verdi打開gui界面
./simv -gui=verdi & 

NOTE:需要注意的是這里vcs的編譯需要加-kdb選項,不然會無法打開verdi
在這里插入圖片描述

3. makefile

??可以將上述命令,添加到makefile腳本中,提高工作效率。

附錄

1. ALU代碼

module alu(input clk,input rst_n,input [7:0] in1,input [7:0] in2,input [1:0] in_ctrl,output [7:0] out
);reg [7:0] A,B;reg [1:0] C;reg [7:0] D;always @(posedge clk or negedge rst_n)beginif(!rst_n)beginA <= 8'd0;B <= 8'd0;C <= 2'd0;endelse beginA <= in1;B <= in2;C <= in_ctrl;endendalways @(posedge clk or negedge rst_n)beginif(!rst_n)D <= 8'd0;else case (C)2'b00 : D <= A + B;2'b01 : D <= ~A;2'b10 : D <= A & B;2'b11 : D <= A | B; default: D <= 8'd0;endcaseendassign out = D;
endmodule

2. TestBench代碼

`timescale 1ns/1ps
module tb();reg clk=0;reg rst_n=1;reg [7:0] in1=0;reg [7:0] in2=0;reg [1:0] in_ctrl=0;wire [7:0] out;always #5 clk=~clk;initial begin#10 rst_n=0;#10 rst_n=1;#100repeat(10)begin@(posedge clk) in1 = {$random}%(2**8);in2 = {$random}%(2**8);in_ctrl = {$random}%(2**2);end#100 $finish();endalu alu(.clk(clk),.rst_n(rst_n),.in1(in1),.in2(in2),.in_ctrl(in_ctrl),.out(out));initial begin$fsdbDumpfile("tb.fsdb");$fsdbDumpvars();end
/*initial begin$dumpfile("alu.vcd");$dumpvars(0, tb);end
*/
endmodule 

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/920572.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/920572.shtml
英文地址,請注明出處:http://en.pswp.cn/news/920572.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

20250826--inter

一、非對稱加密的應用 非對稱加密應用-CSDN博客 2、怎么避免跨站腳本攻擊&#xff0c;包括還有其他的一些web安全&#xff0c;怎么做的 網頁安全XSS攻擊和CSRF攻擊_csrf共計-CSDN博客 3、前端異常監控&#xff0c;性能監控&#xff0c;埋點&#xff0c;怎么做的 &#xff1f…

MongoDB Shell

MongoDB官方提供的單獨命令行工具 MongoDB Shell Download | MongoDB 下載MongoDB Shell windows系統打開&#xff0c;直接在解壓后的目錄里面找到bin目錄 然后雙擊打開mongosh.exe這個文件 看到這個命令行就表示Mongo Shell已經啟動成功了 test代表 當前正在使用的數據庫的…

Docker03-知識點整理

Docker03-知識點整理 文章目錄Docker03-知識點整理1-參考網址2-知識整理2-思考題1-Docker image和Docker Native image有什么區別1. Docker Image&#xff08;Docker 鏡像&#xff09;定義特點構建和使用示例2. Docker Native Image&#xff08;通常指 GraalVM Native Image 結…

華為 eNSP 從入門到精通:企業級網絡仿真全攻略

一、eNSP 簡介華為 eNSP&#xff08;Enterprise Network Simulation Platform &#xff09;是面向企業網絡的虛擬化仿真平臺&#xff0c;其核心架構基于分布式虛擬化引擎和真實設備鏡像&#xff0c;具備以下技術亮點&#xff1a;高度仿真&#xff1a;可模擬華為 AR 路由器、x7 …

docker compose設置命令別名的方法

docker compose名字比較長&#xff0c;輸入比較費事&#xff0c;可以為它設置別名來簡化輸入。1、Linux編輯~/.bash_aliasesalias dcdocker-compse編輯~/.bashrc&#xff0c;確認其包含以下內容&#xff1a;if [ -f ~/.bash_aliases ]; then. ~/.bash_aliasesfi重新加載 ~/.bas…

【RAGFlow代碼詳解-10】文本處理和查詢處理

概述 文本處理和查詢處理系統將自然語言查詢轉換為與 RAGFlow 的文檔存儲后端配合使用的優化搜索表達式。該系統支持中英文文本處理&#xff0c;具有專門的標記化、術語加權和查詢增強技術。核心組件 FulltextQueryer 類 FulltextQueryer 類是查詢處理和文本分析的主要接口。它…

利用機器學習優化Backtrader策略原理與實踐

1. Backtrader框架概述 1.1 Backtrader簡介 Backtrader是一個功能強大且靈活的Python庫&#xff0c;專為量化交易策略的開發、測試和執行而設計。它提供了豐富的功能&#xff0c;包括數據獲取、策略開發、回測、優化和繪圖等。Backtrader的核心優勢在于其模塊化設計和高度可擴展…

CPTS-Pressed復現(XML-RPC)

該box主要是了解wordpress-XML-RPC 的使用 端口掃描只有80端口開啟 可以使用wpscan進行掃描發現bak文件得到憑證&#xff0c;嘗試登陸&#xff08;這里是將原密碼的2021修改為2022嘗試登陸&#xff0c;該主機發布時間為2022年&#xff09;發現有2FA&#xff0c;但是能夠濫用 xm…

【機器學習深度學習】Embedding 與 RAG:讓 AI 更“聰明”的秘密

目錄 前言 一、RAG 的兩大階段 1. 知識庫構建階段 2. 查詢檢索與生成階段 二、為什么 RAG 比單純大模型更靠譜&#xff1f; 四、Embedding 在 RAG 中的作用 五、Embedding 的優勢 六、Embedding 的挑戰 七、RAG 優勢與挑戰對比 八、應用場景舉例 總結 前言 在大模型…

python 轉偶數

目錄 python變量轉偶數 box轉偶數 python變量轉偶數 x1 int(x1) // 2 * 2 y1 int(y1) // 2 * 2 x2 int(x2) // 2 * 2 y2 int(y2) // 2 * 2 box轉偶數 def save_mp4(output_path,box_list,img_list,clip_start,clip_end):writer imageio.get_writer(output_path,fps30,c…

Linux - 中文顯示亂碼問題解決方法(編碼查看及轉換)- 學習/實踐

1.應用場景 主要用于Linux中文顯示亂碼問題解決(編碼查看及轉換&#xff09; 2.學習/操作 1.文檔閱讀 Linux中文顯示亂碼問題解決方法(編碼查看及轉換&#xff09; - 整合俠 - 博客園 截圖&#xff1a; 2.整理輸出 TBD 后續補充 ... 3.問題/補充 TBD 后續補充 ...…

網絡_協議

關鍵詞&#xff1a; OSI是Open System Interconnect的縮寫&#xff0c;意為開放式系統互聯。 RTT &#xff1a; Round-Trip time 往返時間 RTO&#xff1a;Retransmission Timeout超時重傳時間 MSL : OSI 七層模型和 TCP/IP 四層模型 OSI七層模型和TCP/IP五層模型&#…

vscode有的結構體不能補全,有的可以補全問題的解決.

定義了一個結構體,發現不能自動補全變量名稱.而另外一個結構體卻可以正常補全.經過研究發現是,新定義的結構體變量類型uint32_t,vscode認為其是錯誤類型導致的.暫時改為int型,后發現問題消失.可以正常補全了.由于工程使用cubeide生成,uint32_t定義在軟件安裝目錄,并沒有和項目文…

JavaScript 數組核心操作實戰:最值獲取與排序實現(從基礎到優化)

在JavaScript開發中&#xff0c;數組的“最值獲取”和“排序”是高頻需求。本文將基于你的原始代碼&#xff0c;系統解析數組最值獲取、升序/降序排序的實現邏輯&#xff0c;通過“問題分析→代碼優化→原理講解”的流程&#xff0c;幫助你掌握更靈活、高效的數組操作方法&…

driver.js實現前端頁面引導

1.安裝 npm install driver.js2.實現代碼示例 <template><div class"home-container"><!-- 頁面內容 --><LeftPanel id"guide-left-panel" /><button id"guide-file-upload">文件上傳</button><button i…

技術速遞|使用 AI 應用模板擴展創建一個 .NET AI 應用與自定義數據進行對話

在本快速入門中&#xff0c;你將學習如何使用 .NET AI 應用模板創建一個 .NET AI 應用&#xff0c;與自定義數據進行對話。該模板旨在簡化 .NET 構建 AI 應用的上手體驗&#xff0c;幫助你處理常見的設置任務和配置。 先決條件 .NET 9.0 SDK 以下任一 IDE&#xff08;可選&am…

使用Cloudflare的AI Gateway代理Google AI Studio

1、說明詳見&#xff1a;詳見&#xff1a;https://developers.cloudflare.com/ai-gateway/usage/providers/google-ai-studio在"Google AI Studio"創建"API key" 在"Cloudflare"創建"AI Gateway"、獲取"Account ID"2、在“G…

Scrapy 框架實戰:構建高效的快看漫畫分布式爬蟲

一、Scrapy框架概述 Scrapy是一個為了爬取網站數據&#xff0c;提取結構性數據而編寫的應用框架&#xff0c;它提供了強大的數據提取能力、靈活的擴展機制以及高效的異步處理性能。其核心架構包括&#xff1a; Engine&#xff1a;控制所有組件之間的數據流&#xff0c;當某個…

數據結構(C語言篇):(六)單鏈表算法題(下)

目錄 前言 一、鏈表的回文結構 二、相交鏈表 三、環形鏈表?編輯 四、環形鏈表II 總結 前言 本篇博客將繼續介紹單鏈表相關的算法題&#xff0c;包括了鏈表的回文結構、相交鏈表、環形鏈表等。現在就讓我們正式開始吧&#xff01; 一、鏈表的回文結構 題目鏈接&#xff1a…