日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

VPI step by step(1)

發(fā)布時(shí)間:2024/1/1 编程问答 37 豆豆
生活随笔 收集整理的這篇文章主要介紹了 VPI step by step(1) 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

本文主要參考”The Verilog PLI Handbook(Second Edition)”, 權(quán)當(dāng)讀書筆記。主要針對(duì)VCS flow, 也許會(huì)穿插其他兩大家工具的flow.


說(shuō)在最前面

到今天為止,SV對(duì)C/Cpp的主要接口支持大多改用DPI, 也推薦使用DPI。或者直接使用UVM自帶現(xiàn)成的DPI lib, 已經(jīng)可以滿足不少需求。然后類似C與匯編的關(guān)系,VPI更接近與底層Verilog與C的交互,可以很容易的取得各種仿真時(shí)的資源和狀態(tài)。所以可以說(shuō)因?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)過(guò)來(lái):

1. 定義系統(tǒng)task/function

第一步很簡(jiǎn)單, 起個(gè)名字,你希望在TB里怎么調(diào)用它?這里就叫$hello了:

module test;initial$hello(); endmodule

2. 實(shí)現(xiàn)系統(tǒng)task/function

看到“實(shí)現(xiàn)“兩個(gè)字就知道這一步是核心。這一步主要完成的是Verilog里調(diào)用C的內(nèi)容,因此也可以說(shuō)是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))的附錄里找到。可以說(shuō)這是每一個(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ì)有很多人用。但是大體上說(shuō),三家都實(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

說(shuō)白了就是建立VPI和Verilog之間的關(guān)聯(lián),這樣TB才知道調(diào)用哪個(gè)tf. 注冊(cè)內(nèi)容主要包括三個(gè)方面:

  • API類型:task還是function(熟悉Verilog的你知道這句話在說(shuō)什么)
  • 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為例:

void PLIbook_hello_register() {s_vpi_systf_data tf_data;tf_data.type = vpiSysTask;tf_data.sysfunctype = 0;tf_data.tfname = "$hello";tf_data.calltf = PLIbook_hello_calltf;tf_data.compiletf = NULL;tf_data.sizetf = NULL;tf_data.user_data = NULL;vpi_register_systf(&tf_data); }

以上是注冊(cè)的細(xì)節(jié),在實(shí)際操作中往往不用這么麻煩–其實(shí)至今沒有實(shí)驗(yàn)出vcs走這個(gè)flow怎樣才能走通。
vcs中通常使用的方法是pli.tab文件,在這個(gè)例子里很簡(jiǎn)單:

$hello call=PLIbook_hello_calltf

nc中有類似的文件plimap.


萬(wàn)事俱備, 開始編譯:

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)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。