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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

VPI step by step(1)

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

本文主要參考”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(); endmodule

2. 實現(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為例:

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); }

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

$hello call=PLIbook_hello_calltf

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

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