在Ubuntu上安裝2024.2版本AMD FPGA工具集的參考指南
在FPGA工具的軟件世界中,用于在FPGA上開(kāi)發(fā)設(shè)計(jì)的ide似乎每年都在加速,我在這里使用“加速”是一個(gè)雙關(guān)語(yǔ)。這就意味著不缺少安裝技巧和技巧。所以我在這里再次使用AMD FPGA工具版本2024.2,因?yàn)槲以谶@個(gè)安裝過(guò)程中發(fā)現(xiàn)了一些新的東西(甚至不要問(wèn)我專(zhuān)門(mén)用于Vivado/Vitis安裝的硬盤(pán)空間的絕對(duì)數(shù)量)。
像往常一樣,我在Ubuntu主機(jī)環(huán)境中工作。以下說(shuō)明已經(jīng)在Ubuntu版本20.04 LTS, 22.04 LTS和24.04 LTS中進(jìn)行了測(cè)試和驗(yàn)證,沒(méi)有啟用Ubuntu Pro。然而,我無(wú)法預(yù)見(jiàn)任何理由Ubuntu Pro會(huì)對(duì)這個(gè)安裝流程產(chǎn)生任何影響,除非給定的防火墻連接最終阻止后端訪(fǎng)問(wèn)PetaLinux鏡像或Vivado訪(fǎng)問(wèn)在線(xiàn)板定義文件存儲(chǔ)庫(kù)。這是我在公司配發(fā)的電腦和我的個(gè)人電腦上遇到的最常見(jiàn)的問(wèn)題。
Ubuntu環(huán)境準(zhǔn)備
如果從新安裝的Ubuntu或以前版本的AMD FPGA工具開(kāi)始,請(qǐng)檢查使用的是哪個(gè)系統(tǒng)shell。如果當(dāng)前設(shè)置為破折號(hào),則需要更改為功能完整的shell, bash:
Vivado和PetaLinux也有幾個(gè)32位包依賴(lài),所以32位架構(gòu)也需要添加到環(huán)境中,以允許安裝這些庫(kù):
下面的Vivado、Vitis(以前的XSDK)和PetaLinux的軟件包依賴(lài)列表是我在過(guò)去幾年里為Ubuntu主機(jī)策劃的一些東西。
在大多數(shù)情況下,它是相當(dāng)一致的(除了一些額外的東西,比如為PetaLinux內(nèi)置的嵌入式Linux映像格式化SD卡的gparted),但是當(dāng)有新的軟件包彈出時(shí),我發(fā)現(xiàn)它很有趣,因?yàn)樗梢蕴崾疚谊P(guān)于Vivado/Vitis ide的不同之處。
我確實(shí)通過(guò)運(yùn)行內(nèi)置到Vitis安裝目錄中的腳本來(lái)驗(yàn)證該列表,該腳本每次安裝后都會(huì)檢查缺少的包依賴(lài)項(xiàng),這就是我捕獲需要添加到此列表中的內(nèi)容的方式。
還值得注意的是,我特意將這些包拆分為多個(gè)apt安裝命令。這是由于過(guò)去的經(jīng)驗(yàn),我發(fā)現(xiàn)試圖一次安裝太多的軟件包似乎會(huì)使Ubuntu崩潰,并導(dǎo)致“不可能條件”錯(cuò)誤。
然后,為了使Vivado和Vitis ide能夠通過(guò)串行連接與FPGA硬件通信,需要將Ubuntu上的用戶(hù)配置文件添加到dialout組中,以便能夠訪(fǎng)問(wèn)/dev/ttyUSB串行端口設(shè)備:
下載安裝文件
準(zhǔn)備好Linux環(huán)境之后,就可以下載Vitis/Vivado的安裝文件/安裝程序了。這里的AMD下載頁(yè)面默認(rèn)為最新版本,但如果需要,也可以鏈接所有過(guò)去的版本。
安裝程序有兩個(gè)版本:基于web的自解壓安裝程序和單個(gè)文件下載安裝程序。自解壓縮安裝程序在安裝過(guò)程中下載所需的安裝文件,這樣它就不會(huì)在安裝過(guò)程中占用額外的硬盤(pán)空間。
單文件下載(SFD)安裝程序包含安裝程序目錄中的所有安裝文件,因此顧名思義,您只需等待從包含所有內(nèi)容的AMD網(wǎng)站下載一個(gè)壓縮文件。
現(xiàn)在,雖然web安裝程序在安裝過(guò)程中節(jié)省了硬盤(pán)空間,但無(wú)論使用哪個(gè)安裝程序,Vivado/Vitis安裝本身所消耗的實(shí)際硬盤(pán)空間都是相同的(大約150GB)。
我在一些AMD文檔中看到,強(qiáng)烈建議使用web安裝程序,以避免等待整個(gè)124GB的SFD安裝程序被下載,但從個(gè)人經(jīng)驗(yàn)來(lái)看,我發(fā)現(xiàn)企業(yè)防火墻往往不喜歡web安裝程序使用任何代理訪(fǎng)問(wèn)AMD服務(wù)器來(lái)下載安裝文件。所以我個(gè)人總是使用/更喜歡SFD安裝程序。
值得一提的是,鏈接在Vivado (HW Developer)選項(xiàng)卡和Vitis (SW Developer)選項(xiàng)卡下的安裝程序是相同的安裝程序,因?yàn)楫?dāng)您運(yùn)行它時(shí),它在安裝程序中,您可以選擇安裝Vivado、Vitis或兩者都安裝。
運(yùn)行Vitis安裝程序
如果使用SFD安裝程序,使用類(lèi)似tar的命令解壓縮壓縮文件,然后更改目錄并運(yùn)行安裝程序xsetup:
否則,使用chmod命令使web安裝文件可執(zhí)行,然后運(yùn)行它:
安裝程序確實(shí)需要超級(jí)用戶(hù)/根權(quán)限才能運(yùn)行。
安裝程序的第一頁(yè)只是一個(gè)歡迎頁(yè)面,但如果主機(jī)平臺(tái)操作系統(tǒng)的版本沒(méi)有得到官方支持,它也會(huì)警告您。在我的例子中,我使用的是Ubuntu 22.04,但我已經(jīng)更新了小版本到22.04.5,由于最后一個(gè)官方支持的版本是22.04.4,安裝程序拋出了警告。
然而,我個(gè)人從來(lái)沒(méi)有發(fā)現(xiàn)使用像這樣“不受支持”的Ubuntu LTS小版本有問(wèn)題。只要支持的專(zhuān)業(yè)(即- 20.04,22.04等),你應(yīng)該很好。
正如我前面提到的,在運(yùn)行安裝程序時(shí),您可以在安裝程序中選擇安裝Vivado、Vitis或兩者都安裝。頂部標(biāo)記為“Vitis”的選項(xiàng)是安裝Vivado和Vitis以及所有附帶工具的超集,然后列表的其余部分顯示安裝單個(gè)工具的選項(xiàng)。
關(guān)于這一點(diǎn),有幾點(diǎn)需要注意:
1 -安裝程序可以在任何時(shí)候重新運(yùn)行,即使當(dāng)前安裝的相同版本已經(jīng)存在,所以你可以回來(lái)安裝任何你可能已經(jīng)放棄了在以前的安裝過(guò)程。
2 - PetaLinux選項(xiàng)實(shí)際上不會(huì)經(jīng)歷安裝PetaLinux的過(guò)程。它只是為您下載PetaLinux安裝程序。
絕大多數(shù)應(yīng)用程序都需要完整安裝,包括Vivado和Vitis,所以在選擇Vitis之后,下一頁(yè)將提供更多細(xì)節(jié)選項(xiàng)。
就我個(gè)人而言,我還沒(méi)有需要改變這個(gè)屏幕上的任何默認(rèn)安裝選項(xiàng)。取消勾選一些選項(xiàng),比如您可能不使用的不同類(lèi)型的部件,將在最終安裝中節(jié)省一些硬盤(pán)空間,但我認(rèn)為它沒(méi)有足夠的影響,不需要冒險(xiǎn)稍后返回并在安裝程序中重新運(yùn)行。
下一頁(yè)是大家最喜歡的同意使用AMD FPGA工具的服務(wù)條款。為了啟用“下一步”按鈕,必須選中每個(gè)“我同意”框:
如果需要在默認(rèn)的/tools/Xilinx目錄之外的其他位置,那么最后的選項(xiàng)屏幕允許您指定自定義安裝目錄。
如果指定的安裝目錄當(dāng)前不存在,那么安裝程序?qū)⑻崾灸?yàn)證是否可以創(chuàng)建它。
確認(rèn)安裝目錄后,在開(kāi)始實(shí)際安裝之前,最后一個(gè)窗口將顯示安裝摘要。
安裝時(shí)間將根據(jù)所選擇的選項(xiàng)和所使用的安裝程序而變化。SFD確實(shí)運(yùn)行得更快,因?yàn)樗恍枰却魏卧次募螺d,但有多快取決于您的互聯(lián)網(wǎng)速度(我強(qiáng)烈建議在下載SFD安裝程序時(shí)使用硬連線(xiàn)連接,或者在下載源文件時(shí)運(yùn)行web安裝程序)。
在我32GB內(nèi)存的英特爾酷睿i9上,SFD安裝程序花了大約30分鐘來(lái)安裝Vivado和Vitis。
完成后,將出現(xiàn)一個(gè)提示符,告訴您檢查缺失庫(kù)/包依賴(lài)項(xiàng)的腳本的位置。
雖然我已經(jīng)在上面的列表中包含了這個(gè)腳本中的所有內(nèi)容,但我仍然建議始終運(yùn)行這個(gè)腳本作為完整性檢查:
在驗(yàn)證了所有的庫(kù)/包依賴(lài)關(guān)系安裝之后,需要安裝通過(guò)USB和JTAG與AMD fpga通信的電纜驅(qū)動(dòng)程序。安裝這些驅(qū)動(dòng)程序的腳本位于//data/xicom/cable_drivers/lin64/install_script/install_drivers/目錄下。
在安裝線(xiàn)纜驅(qū)動(dòng)程序時(shí),請(qǐng)確保主機(jī)PC上沒(méi)有連接FPGA JTAG線(xiàn)纜。
作為最后的完整性檢查,我喜歡啟動(dòng)Vivado和Vitis ide,以確保它們至少在我開(kāi)始安裝PetaLinux之前是打開(kāi)的。
將設(shè)置腳本源到環(huán)境中,并按名稱(chēng)啟動(dòng)所需的IDE:
值得注意的是,在Vitis和Vivado安裝目錄中,settings64.sh腳本是相同的,因此啟動(dòng)IDE時(shí)只需要對(duì)其進(jìn)行一次源代碼獲取。
準(zhǔn)備安裝PetaLinux
現(xiàn)在,基于python的PetaLinux工具還需要最后一點(diǎn)Linux環(huán)境,因?yàn)樗枰粋€(gè)TFTP服務(wù),并且需要手動(dòng)創(chuàng)建它的安裝目錄并賦予適當(dāng)?shù)臋?quán)限。
首先為T(mén)FTP服務(wù)創(chuàng)建規(guī)則文件:
使用以下配置:
保存并關(guān)閉TFTP規(guī)則文件后,為T(mén)FTP服務(wù)器創(chuàng)建一個(gè)目錄,并賦予相應(yīng)的權(quán)限和所有權(quán):
最后,重新啟動(dòng)xinetd網(wǎng)絡(luò)服務(wù),使對(duì)系統(tǒng)的更改生效。
然后創(chuàng)建所需的安裝目錄,并賦予它適當(dāng)?shù)臋?quán)限。我個(gè)人喜歡將PetaLinux安裝在具有相應(yīng)版本Vivado/Vitis的安裝目錄中,遵循相同的目錄命名約定:
PetaLinux安裝
雖然安裝目錄權(quán)限需要設(shè)置為755,但實(shí)際的PetaLinux安裝程序本身需要777的完全讀/寫(xiě)權(quán)限。
一旦安裝程序具有所需的權(quán)限,使用——dir標(biāo)志運(yùn)行它以指定目標(biāo)安裝目錄:
安裝程序?qū)⑻崾灸榭床㈨憫?yīng)用戶(hù)許可協(xié)議:
按enter鍵查看許可協(xié)議,然后按Q鍵退出,系統(tǒng)將提示您輸入Y或N以同意或不同意使用PetaLinux工具的服務(wù)條款。
然后檢查PetaLinux工具到環(huán)境的安裝源,并驗(yàn)證PetaLinux命令現(xiàn)在可用:
下一個(gè)步驟
隨著完整的2024.2安裝完成,我將繼續(xù)介紹一些新的入門(mén)教程,因?yàn)閷?duì)整個(gè)工作流程進(jìn)行了更改,例如用于為PetaLinux設(shè)計(jì)生成設(shè)備樹(shù)的新系統(tǒng)設(shè)備樹(shù)(SDT)。
本文編譯自hackster.io