VPI step by step(1)
本文主要參考”The Verilog PLI Handbook(Second Edition)”, 權(quán)當讀書筆記。主要針對VCS flow, 也許會穿插其他兩大家工具的flow.
說在最前面
到今天為止,SV對C/Cpp的主要接口支持大多改用DPI, 也推薦使用DPI。或者直接使用UVM自帶現(xiàn)成的DPI lib, 已經(jīng)可以滿足不少需求。然后類似C與匯編的關(guān)系,VPI更接近與底層Verilog與C的交互,可以很容易的取得各種仿真時的資源和狀態(tài)。所以可以說因為迫不得已,有時候還得上VPI.
Hello World!
A “Hello, World!” program is traditionally used to introduce novice programmers to a programming language. —— [ wiki ]
讓我們遵循傳統(tǒng),從hello world開始。
Hello world需要四步, 這里直接把原文例子搬運過來:
1. 定義系統(tǒng)task/function
第一步很簡單, 起個名字,你希望在TB里怎么調(diào)用它?這里就叫$hello了:
module test;initial$hello(); endmodule2. 實現(xiàn)系統(tǒng)task/function
看到“實現(xiàn)“兩個字就知道這一步是核心。這一步主要完成的是Verilog里調(diào)用C的內(nèi)容,因此也可以說是C的部分怎樣去實現(xiàn)。另外,書中把這稱之為calltf, 感覺這個tf是task/function的合體.下面給出具體實現(xiàn):
#include <stdlib.h> #include <stdio.h> #include “vpi_user.h” /* ANSI C standard library */ /* ANSI C standard input/output library */ /* IEEE 1364 PLI VPI routine library */ PLI_INT32 PLIbook_hello_calltf(PLI_BYTE8 *user_data) {vpi_printf(“\nHello World!\n\n”);return(0); }首先值得一提的是vpi_user.h. 這個頭文件里包含了vpi的各種數(shù)據(jù)結(jié)構(gòu)體,參數(shù)類型,屬性以及函數(shù)原型。這部分內(nèi)容可以在IEEE 1800(SV標準)的附錄里找到。可以說這是每一個vpi程序必備的頭文件,EDA廠商據(jù)此實現(xiàn)API供用戶使用,具體實現(xiàn)就內(nèi)部保密了。正因為是自定義,御三家對這個文件具體處理是不一樣的,比如synopsys就沒有實現(xiàn)vpi_get_data()這個API,理由是他們覺得不會有很多人用。但是大體上說,三家都實現(xiàn)了絕大部分規(guī)定的VPI,以及自己還提供擴展的API.基于vpi_user.h的實現(xiàn),一般可以認為是通用的。
第二點新鮮的是PLI_INT32與PLI_BYTE8,其實就是C里的int和char類型,這里認為int是32位而char是8位。
再往下看,vpi_printf()這個函數(shù)是第一個接觸到的VPI函數(shù),和C里的printf的用法是一致的。
3.注冊系統(tǒng)task/function
說白了就是建立VPI和Verilog之間的關(guān)聯(lián),這樣TB才知道調(diào)用哪個tf. 注冊內(nèi)容主要包括三個方面:
- API類型:task還是function(熟悉Verilog的你知道這句話在說什么)
- Verilog側(cè)API名
- VPI側(cè)API名
可以看出,verilog側(cè)完全可以不叫VPI那邊的名字。
在VPI中注冊信息包含在s_vpi_register_systf這個結(jié)構(gòu)體中,vpi_register_systf()函數(shù)使用這個結(jié)構(gòu)體去注冊。注冊的函數(shù)都保存在VPI側(cè)一個叫vlog_startup_routines的數(shù)組里。下面以$hello為例:
以上是注冊的細節(jié),在實際操作中往往不用這么麻煩–其實至今沒有實驗出vcs走這個flow怎樣才能走通。
vcs中通常使用的方法是pli.tab文件,在這個例子里很簡單:
nc中有類似的文件plimap.
萬事俱備, 開始編譯:
vcs hello_test.v +vpi -P pli.tab hello_vpi.c -full64運行simv輸出
Hello World!參考資料
[1]: Stuart Sutherland. The Verilog PLI Handbook(Second Edition), 2002
總結(jié)
以上是生活随笔為你收集整理的VPI step by step(1)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 记账APP、家庭记账、分享下自己以前做的
- 下一篇: 关于流量套利你需要知道的一切