0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

Verilog編程語言界面入門知識(shí)簡介

PCB線路板打樣 ? 來源:LONG ? 2019-08-13 17:31 ? 次閱讀

設(shè)計(jì)師使用HDL已超過十年,用它們?nèi)〈谠韴D的設(shè)計(jì)方法并傳達(dá)設(shè)計(jì)理念。 Verilog和VHDL是電子設(shè)計(jì)中使用最廣泛的兩種HDL。 Verilog擁有約35,000名活躍的設(shè)計(jì)師,他們使用Cadence的Verilog軟件套件完成了超過50,000個(gè)設(shè)計(jì)。

即使Verilog成功,許多經(jīng)驗(yàn)豐富的Verilog用戶仍然認(rèn)為其編程語言界面( PLI)作為“軟件任務(wù)”。一步一步的方法可以幫助您在編寫PLI函數(shù)時(shí)“打破僵局”。通過學(xué)習(xí)PLI設(shè)計(jì)的基本知識(shí)而不會(huì)被太多細(xì)節(jié)困擾,您將獲得可以立即使用的PLI基礎(chǔ)知識(shí)。

為什么要使用PLI?

PLI為Verilog提供了應(yīng)用程序接口(API)。本質(zhì)上,PLI是一種從Verilog代碼調(diào)用C函數(shù)的機(jī)制。人們通常會(huì)調(diào)用在Verilog中調(diào)用PLI例程的構(gòu)造,如果它是模擬器的一部分,則調(diào)用“系統(tǒng)任務(wù)”或“系統(tǒng)函數(shù)”,如果用戶編寫它,則調(diào)用“用戶定義的任務(wù)”或“用戶定義的函數(shù)”。由于PLI的基本機(jī)制在兩種情況下都保持不變,因此本文使用術(shù)語“系統(tǒng)調(diào)用”來表示這兩種結(jié)構(gòu)。大多數(shù)Verilog模擬器包含的常見系統(tǒng)調(diào)用示例是$ display,$ monitor和$ finish。

您使用PLI主要用于執(zhí)行使用Verilog語法無法執(zhí)行的任務(wù)。例如,IEEE Standard1364-1995 Verilog有一個(gè)用于執(zhí)行文件寫入的預(yù)定義構(gòu)造($ fwrite,這是使用PLI編寫的另一個(gè)內(nèi)置系統(tǒng)調(diào)用),但它沒有用于直接從a讀取寄存器值的構(gòu)造。文件(參考文獻(xiàn)2)。更常見的任務(wù)是PLI是實(shí)現(xiàn)預(yù)期結(jié)果的唯一方法,包括編寫功能模型,計(jì)算延遲和獲取設(shè)計(jì)信息。 (例如,沒有Verilog構(gòu)造在設(shè)計(jì)層次結(jié)構(gòu)中給出當(dāng)前模塊的父實(shí)例名稱。)

為了說明創(chuàng)建PLI例程的基本步驟,請(qǐng)考慮清單1中的問題。問題比使用PLI解決的現(xiàn)實(shí)問題簡單得多,但它顯示了許多用于構(gòu)建PLI例程的基本步驟。當(dāng)您在列表中運(yùn)行Verilog時(shí),它應(yīng)該在時(shí)間100打印寄存器的值為10,在時(shí)間300打印3.您可以考慮創(chuàng)建一個(gè)PLI例程作為兩個(gè)步驟:首先,編寫PLI例程在C;然后,編譯并將此例程鏈接到模擬器的二進(jìn)制代碼。

編寫PLI例程

PLI例程與模擬器接口的方式因模擬器而異,盡管主要功能保持不變。本文討論兩種最流行的商業(yè)模擬器的接口機(jī)制,Cadence的Verilog-XL(參考文獻(xiàn)3)和Synopsys的VCS(參考文獻(xiàn)4)。雖然其他商業(yè)模擬器支持PLI,但它們的接口機(jī)制與這兩者沒有顯著差異。多年來,Verilog PLI已發(fā)展為PLI 1.0和Verilog程序接口(VPI)(參見側(cè)欄“Verilog PLI的簡史”)。本文僅涉及PLI 1.0。盡管接口部件和版本存在差異,但您可以將PLI例程的創(chuàng)建分解為四個(gè)主要步驟。

步驟1:包含頭文件

按照慣例,C程序在文件veriuser.c中實(shí)現(xiàn)PLI例程。雖然您可以更改此名稱,但在Verilog-XL環(huán)境中生成編譯腳本時(shí),vconfig工具會(huì)采用此默認(rèn)名稱。現(xiàn)在,假設(shè)您將PLI例程保留在文件veriuser.c中。

在Verilog-XL環(huán)境中,文件veriuser.c必須以以下行開頭:

在VCS環(huán)境中,文件必須以:

開頭

這些頭文件包含程序?qū)⑹褂玫腣erilog PLI的最基本數(shù)據(jù)結(jié)構(gòu)。

步驟2:聲明函數(shù)原型和變量

PLI例程由幾個(gè)函數(shù)組成。正如您對(duì)普通C程序所做的那樣,您應(yīng)該在函數(shù)定義之前放置函數(shù)的原型聲明。對(duì)于這種情況,函數(shù)顯示為:

在上面的函數(shù)中,int原型聲明意味著這些函數(shù)在它們結(jié)束時(shí)返回一個(gè)整數(shù)執(zhí)行。如果沒有錯(cuò)誤,則正常返回值為0.但是,如果函數(shù)位于單獨(dú)的文件中,則應(yīng)將它們聲明為外部函數(shù):

與任何其他C程序一樣,典型的PLI例程可能需要一些其他管家變量。

步驟3:設(shè)置基本數(shù)據(jù)結(jié)構(gòu)

您必須定義一個(gè)數(shù)字PLI程序中的數(shù)據(jù)結(jié)構(gòu)。 Verilog模擬器通過這些變量與C代碼通信。 Open Verilog International(OVI)(www.ovi.org/pubs.html)是一個(gè)標(biāo)準(zhǔn)化Verilog的組織,它只推薦一個(gè)強(qiáng)制數(shù)據(jù)結(jié)構(gòu)veriusertfs。但是,這些數(shù)據(jù)結(jié)構(gòu)的確切數(shù)量和語法因模擬器而異。例如,Verilog-XL需要四個(gè)這樣的數(shù)據(jù)結(jié)構(gòu)及其功能,以便任何PLI例程工作; VCS不需要它們,而是使用單獨(dú)的輸入文件。

Verilog-XL的主要接口數(shù)據(jù)結(jié)構(gòu)是一個(gè)結(jié)構(gòu)數(shù)組或一個(gè)名為veriusertfs的表。 Verilog-XL使用此表來確定與此PLI例程對(duì)應(yīng)的系統(tǒng)調(diào)用關(guān)聯(lián)的屬性。模擬器無法識(shí)別除veriusertfs之外的任何名稱。 veriusertfs的每個(gè)元素都有一個(gè)獨(dú)特的函數(shù),你需要所有這些函數(shù)來實(shí)現(xiàn)正確編寫PLI例程的總體目標(biāo)。 veriusertfs中的行數(shù)與用戶定義的系統(tǒng)調(diào)用數(shù)加上最后一個(gè)條目的行數(shù)相同,這是強(qiáng)制性的0.在這種情況下,veriusertfs數(shù)組應(yīng)如下所示:

第一個(gè)條目usertask表示系統(tǒng)調(diào)用沒有返回任何內(nèi)容。它等同于Pascal中的過程或函數(shù)返回C中的void。

在前面的數(shù)據(jù)結(jié)構(gòu)中,my_ checktf和my_calltf是用于實(shí)現(xiàn)系統(tǒng)調(diào)用$ print_reg的兩個(gè)函數(shù)的名稱。這些名稱是任意的,您可以用其他名稱替換它們。函數(shù)my_checktf通常稱為checktf例程。它檢查傳遞的參數(shù)的有效性。同樣,my_calltf(通常稱為calltf例程)執(zhí)行系統(tǒng)調(diào)用的主要任務(wù)。這些名稱在veriusertfs中的位置非常重要。例如,如果要將my_checkt用作任何其他名稱作為檢查函數(shù),則它必須是第三個(gè)元素。函數(shù)veriusertfs為您在此例程中不會(huì)使用的一些其他用戶定義函數(shù)提供選項(xiàng)。零替換任何您不使用的函數(shù)。因此,條目中的第二,第四和第六個(gè)元素是零。表1總結(jié)了veriusertfs行中每個(gè)條目的目標(biāo)。如果有其他系統(tǒng)調(diào)用,則需要在veriusertfs中為每個(gè)系統(tǒng)調(diào)用單獨(dú)的條目。

Verilog-XL還需要以下變量或函數(shù):

第一個(gè)變量veriuser_version_str是一個(gè)字符串,表示應(yīng)用程序的用戶定義 - 版本信息。 bool(布爾)變量是一個(gè)整數(shù)子類型,允許值為0和1.在大多數(shù)情況下,您可以使用Cadence為這些變量或函數(shù)提供的默認(rèn)值。

在VCS中,而不是表,您在單獨(dú)的文件中使用等效信息,通常稱為pli.tab。該名稱也是用戶定義的。在使用$ print_reg的當(dāng)前示例中,此文件的內(nèi)容為:

步驟4:組成函數(shù)

原型聲明到位后,您就可以編寫兩個(gè)函數(shù)my_checktf()和my_calltf(),它們構(gòu)成了PLI應(yīng)用程序的主體。

如前所述,checktf例程檢查傳遞參數(shù)的有效性。最好檢查參數(shù)總數(shù)是否與預(yù)期相同,以及是否需要每個(gè)參數(shù)。例如,在這種情況下,您希望程序只傳遞一個(gè)類型為register的參數(shù)。您可以在函數(shù)my_checktf()中執(zhí)行此任務(wù)(清單2)。

以tf_開頭的函數(shù)是庫函數(shù),通常稱為實(shí)用程序例程。庫函數(shù)在前一個(gè)函數(shù)中使用,它們的用法是tf_nump(),它確定傳遞的參數(shù)數(shù)量,以及tf_typep(),它根據(jù)Verilog代碼中系統(tǒng)調(diào)用中的位置確定參數(shù)類型。在這種情況下,系統(tǒng)調(diào)用是$ print_reg。

因此,tf_typep(1)給出第一個(gè)參數(shù)的類型,tf_typep(2)給出第二個(gè)參數(shù)的類型,依此類推。如果參數(shù)不存在,則tf_typep()返回錯(cuò)誤。 (在這種情況下,tf_typep(2)不存在。)在當(dāng)前示例中,您希望程序?qū)⒓拇嫫髦底鳛閰?shù)傳遞。因此,類型應(yīng)該是tf_readwrite。如果導(dǎo)線是預(yù)期參數(shù),則類型應(yīng)為tf_readonly。為了便于錯(cuò)誤條件檢查,最好首先檢查參數(shù)的數(shù)量,然后檢查它們的類型。 tf_error()函數(shù)輸出錯(cuò)誤消息并通知模擬器增加其錯(cuò)誤計(jì)數(shù)。這些庫函數(shù)和常量是您在步驟1中包含在文件頂部的頭文件的一部分。

calltf函數(shù)是PLI例程的核心。它通常包含PLI例程的主體。在這種情況下,它應(yīng)該讀取寄存器的值,然后打印該值。以下代碼顯示了如何完成此任務(wù):

在上面的代碼中,io_printf()與C中的printf()執(zhí)行相同的工作,在標(biāo)準(zhǔn)輸出中打印值。此外,該函數(shù)在Verilog日志文件中打印相同的信息。函數(shù)tf_getp()獲取寄存器的整數(shù)值。函數(shù)tf_gettime()返回當(dāng)前模擬時(shí)間,不需要輸入?yún)?shù)。 Calltf是PLI例程中最復(fù)雜的函數(shù)。它經(jīng)常運(yùn)行幾百行。

現(xiàn)在你已經(jīng)創(chuàng)建了兩個(gè)主要功能,你需要把它們放在一個(gè)地方。清單3顯示了如何在Verilog-XL環(huán)境中實(shí)現(xiàn)$ print_reg。

接下來的任務(wù)是讓Verilog模擬器了解新系統(tǒng)調(diào)用的存在。要完成此任務(wù),您必須編譯PLI例程,然后將其鏈接到模擬器的二進(jìn)制文件。雖然您可以通過運(yùn)行C編譯器并合并目標(biāo)文件來手動(dòng)將PLI代碼與Verilog二進(jìn)制文件集成,但使用腳本更方便。在Verilog-XL中,一個(gè)名為vconfig的程序會(huì)生成此腳本。此腳本的默認(rèn)名稱是cr_vlog。在生成此腳本時(shí),程序vconfig會(huì)詢問您喜歡的已編譯Verilog的名稱。它還詢問是否包含來自標(biāo)準(zhǔn)供應(yīng)商的模型庫,它們是PLI代碼。對(duì)于大多數(shù)這些問題,如果您在不輸入任何內(nèi)容的情況下按回車鍵輸入的默認(rèn)答案就足夠了,除非您有自定義環(huán)境。最后,vconfig會(huì)詢問您的veriuser.c文件的路徑。一旦生成腳本cr_vlog,您只需要運(yùn)行腳本來生成可以執(zhí)行新系統(tǒng)調(diào)用的自定義Verilog模擬器。

使用此PLI例程編譯的Verilog示例運(yùn)行生成輸出Verilog-XL模擬器(清單4)。

修改寄存器的值

使用PLI是讀取設(shè)計(jì)信息并在設(shè)計(jì)數(shù)據(jù)庫中修改此信息。以下示例顯示了如何進(jìn)行此修改。創(chuàng)建系統(tǒng)調(diào)用$ invert,以打印寄存器的值(如上例所示),按位反轉(zhuǎn)內(nèi)容,并打印此更新值。存在許多方法來反轉(zhuǎn)二進(jìn)制數(shù)的值。通過使用簡單的算法進(jìn)行反演,如下面的列表所示,可以幫助您更深入地了解PLI機(jī)制和庫函數(shù):

將寄存器的內(nèi)容讀取為string;

將字符串中的所有字符串轉(zhuǎn)換為twos,將所有零轉(zhuǎn)換為1,將所有二進(jìn)制轉(zhuǎn)換為零,將所有Z轉(zhuǎn)換為X,并使X保持不變;和

將修改后的字符串放回寄存器。

第二步將所有1轉(zhuǎn)換為零和0。請(qǐng)注意,在這種情況下,checktf函數(shù)與前一個(gè)函數(shù)沒有區(qū)別,因?yàn)樵谶@兩種情況下輸入?yún)?shù)的數(shù)量和類型都是相同的。

創(chuàng)建PLI例程

列表圖5顯示了VCS環(huán)境中$ invert例程的實(shí)現(xiàn)。該程序使用以下庫函數(shù):

tf_strgetp()以字符串形式返回寄存器的內(nèi)容。只需liketf_getp(),它將寄存器的內(nèi)容讀作十進(jìn)制。在清單5中,tf_strgetp(1,b)以二進(jìn)制格式讀取第一個(gè)參數(shù)的內(nèi)容。 (h或o代替b,分別以十六進(jìn)制或八進(jìn)制格式讀?。@倘缓髮?nèi)容復(fù)制到字符串val_string。

tf_strdelputp()將值從字符串值規(guī)范寫入?yún)?shù)。該函數(shù)有許多參數(shù),包括參數(shù)索引號(hào)(系統(tǒng)調(diào)用中參數(shù)的相對(duì)位置,最左邊的參數(shù)從1開始);參數(shù)包含其值的字符串的大?。ㄔ谶@種情況下,它應(yīng)與寄存器的大小相同);編碼基數(shù);實(shí)際的字符串;和另外兩個(gè)與延遲相關(guān)的參數(shù),你可以通過為它們傳遞零來忽略它們。雖然在當(dāng)前示例中沒有顯示,但是tf_strdelputp()的更簡單的十進(jìn)制對(duì)應(yīng)是tf_putp()。

重要的是要記住程序只能更改或覆蓋來自PLI例程的某些對(duì)象的值。任何嘗試更改無法放在Verilog中的過程賦值左側(cè)的變量(例如連線)都會(huì)導(dǎo)致錯(cuò)誤。通常,您可以修改tf_readwrite類型的變量的內(nèi)容。 checktf函數(shù)my_checktf()檢查此功能。

清單5使用的另一個(gè)用戶定義函數(shù)是move(),它有三個(gè)參數(shù)。在第三個(gè)參數(shù)中,第二個(gè)參數(shù)替換第一個(gè)參數(shù)的每個(gè)匹配項(xiàng)。在當(dāng)前情況下,對(duì)move()的一系列調(diào)用將零更改為1和1更改為零。但是,一旦程序?qū)⒘戕D(zhuǎn)換為1,您必須將字符串中的轉(zhuǎn)換元素與原始元素區(qū)分開來。為了做出這種區(qū)分,程序首先將所有初始的更改為兩個(gè)。二是二進(jìn)制邏輯的無效值,但您可以在此示例的中間步驟中使用它。最后,程序?qū)⑺袃蓚€(gè)轉(zhuǎn)換為零。程序通過使用tf_strdelputp()函數(shù)將反轉(zhuǎn)的值放回寄存器來完成其任務(wù)。

清單6顯示了一個(gè)包含調(diào)用$ invert的Verilog程序示例。在VCS環(huán)境中,文件列出與PLI例程關(guān)聯(lián)的功能。雖然這個(gè)文件可以有任何名稱,但通常稱之為pli.tab。該文件等同于Verilog-XL中的veriusertfs []結(jié)構(gòu)。當(dāng)前示例中此文件的內(nèi)容為:

通過將此程序保存在test.v文件中,可以生成可執(zhí)行二進(jìn)制文件pli_invert命令:

執(zhí)行pli_invert,你得到:

你現(xiàn)在了解PLI例程的基本結(jié)構(gòu)以及將其鏈接到構(gòu)建Verilog自定義版本的機(jī)制。您還可以通過PLI例程讀取,轉(zhuǎn)換和修改Verilog中設(shè)計(jì)數(shù)據(jù)庫的基本組件的值,并讀取例程的模擬時(shí)間。這些任務(wù)是PLI例程執(zhí)行的基本任務(wù),也是最常用的任務(wù)??紤]到PLI提供的所有信息,這些信息只是冰山一角。您還可以使用PLI訪問寄存器內(nèi)容以外的設(shè)計(jì)信息。 (有關(guān)Verilog和C建模的更多信息,請(qǐng)參閱參考文獻(xiàn)5和6。)

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 編程
    +關(guān)注

    關(guān)注

    88

    文章

    3631

    瀏覽量

    93844
  • PCB打樣
    +關(guān)注

    關(guān)注

    17

    文章

    2968

    瀏覽量

    21758
  • 華強(qiáng)PCB
    +關(guān)注

    關(guān)注

    8

    文章

    1831

    瀏覽量

    27844
  • 華強(qiáng)pcb線路板打樣

    關(guān)注

    5

    文章

    14629

    瀏覽量

    43108
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    哪有FPGA的verilog編程基礎(chǔ)知識(shí)?

    沒接觸過FPGA開發(fā),那個(gè)verilog編程有什么入門基礎(chǔ)知識(shí)學(xué)習(xí)的?
    發(fā)表于 04-29 23:09

    Verilog語言入門

    Verilog語言入門,,
    發(fā)表于 09-30 08:56

    Verilog HDL華為入門教程

    Verilog HDL 華為入門教程 本文主要介紹了Verilog HDL 語言的一些基本知識(shí),目的是使初學(xué)者能夠迅速掌握HDL設(shè)計(jì)方法,
    發(fā)表于 02-11 08:35 ?140次下載

    Verilog HDL入門教程(華為絕密資料)

    Verilog HDL入門教程(華為絕密資料) 本文主要介紹了Verilog HDL 語言的一些基本知識(shí),目的是使初學(xué)者能夠迅速掌握HDL
    發(fā)表于 04-02 11:52 ?0次下載

    Verilog HDL語言簡介

    Verilog HDL語言簡介 1.什么是Verilog HDLVerilog HDL是硬件描述語言的一種,用于數(shù)
    發(fā)表于 02-09 08:59 ?3916次閱讀

    OpenCV_編程簡介(入門必讀)

    opencv編程簡介,入門必讀,適合新手簡單了解opencv的相關(guān)知識(shí)。
    發(fā)表于 03-21 13:49 ?12次下載

    C語言編程開發(fā)入門基礎(chǔ)教程

    電子專業(yè)單片機(jī)相關(guān)知識(shí)學(xué)習(xí)教材資料——C語言編程開發(fā)入門基礎(chǔ)教程
    發(fā)表于 08-23 15:23 ?0次下載

    MFC圖形界面編程入門教程

    計(jì)算機(jī)上的上位機(jī)制作工具語言之MFC圖形界面編程入門教程
    發(fā)表于 09-01 14:55 ?0次下載

    Verilog語言入門

    Verilog語言入門,感興趣的小伙伴們可以瞧一瞧。
    發(fā)表于 11-10 15:29 ?5次下載

    Verilog HDL作為現(xiàn)在最流行的FPGA開發(fā)語言入門的基礎(chǔ)

    Verilog HDL作為現(xiàn)在最流行的FPGA開發(fā)語言,當(dāng)然是入門基礎(chǔ)。
    發(fā)表于 02-18 14:47 ?1.1w次閱讀

    Linux下C語言編程入門教程詳細(xì)說明

    本文是Linux 下C 語言編程入門教程。主要介紹了Linux 的發(fā)展與特點(diǎn)、C語言的基礎(chǔ)知識(shí)、Linux 程序設(shè)計(jì)基礎(chǔ)
    發(fā)表于 08-25 18:05 ?39次下載
    Linux下C<b class='flag-5'>語言</b><b class='flag-5'>編程</b><b class='flag-5'>入門</b>教程詳細(xì)說明

    verilog中端口類型有哪三種_verilog語言入門教程

    本文主要闡述了verilog中端口的三種類型及verilog語言入門教程。
    發(fā)表于 08-27 09:29 ?1.1w次閱讀

    Verilog編程語言

    知乎上刷到一個(gè)問題,問性能最強(qiáng)的編程語言是什么?看到高贊回答到是Verilog,然后在評(píng)論區(qū)就引發(fā)了一場Verilog到底算不算編程
    的頭像 發(fā)表于 08-23 14:30 ?6233次閱讀

    verilog與其他編程語言的接口機(jī)制

    Verilog是一種硬件描述語言,用于描述數(shù)字電路的行為和結(jié)構(gòu)。與其他編程語言相比,Verilog具有與硬件緊密結(jié)合的特點(diǎn),因此其接口機(jī)制也
    的頭像 發(fā)表于 02-23 10:22 ?734次閱讀

    FPGA編程語言入門教程

    FPGA(現(xiàn)場可編程邏輯門陣列)的編程涉及特定的硬件描述語言(HDL),其中Verilog和VHDL是最常用的兩種。以下是一個(gè)FPGA編程
    的頭像 發(fā)表于 10-25 09:21 ?363次閱讀