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