<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>

新聞中心

EEPW首頁(yè) > EDA/PCB > 設計應用 > FPGA 101:用Vivado HLS為軟件提速

FPGA 101:用Vivado HLS為軟件提速

作者: 時(shí)間:2016-10-18 來(lái)源:網(wǎng)絡(luò ) 收藏

在編寫(xiě)軟件時(shí),您有沒(méi)有遇到過(guò)無(wú)論怎么努力編碼,軟件都不能按您期望的速度運行?我遇到過(guò)。您有沒(méi)有想過(guò),“有沒(méi)有什么簡(jiǎn)單而且成本不高的方法可將一些代碼輸入多個(gè)定制處理器或定制硬件?”畢竟,您的應用只是眾多應用中的一個(gè),而且創(chuàng )建定制硬件需要花費時(shí)間和成本。是不是這樣?

本文引用地址:http://dyxdggzs.com/article/201610/308462.htm

最近聽(tīng)說(shuō)了賽靈思的高層次綜合工具Vivado®HLS后,我開(kāi)始重新思考這一問(wèn)題。高層次綜合工具與Zynq®-7000 All Programmable SoC的結合為設計開(kāi)辟了新的可能性,其中Zynq®-7000 All Programmable SoC結合了帶有FPGA架構的雙核ARM®CortexTM-A9處理器。這類(lèi)工具可以用C語(yǔ)言,C++語(yǔ)言或SystemC源代碼創(chuàng )建高度優(yōu)化的RTL。近年來(lái),出現很多這項技術(shù)的提供商,且其采用率也不斷提高。

如果我只用Vivado HLS便能完成要求更高的計算,那么將那些慢速代碼遷移到硬件中會(huì )有多難?畢竟我經(jīng)常用C++語(yǔ)言編寫(xiě)代碼,而Vivado HLS將C/C++語(yǔ)言作為輸入語(yǔ)言。ARM處理器內核意味著(zhù)我可以在常規環(huán)境下運行多數軟件。事實(shí)上賽靈思還提供了一款軟件開(kāi)發(fā)工具(SDK)以及PetaLinux來(lái)幫您實(shí)現這一目的。

架構問(wèn)題

從軟件角度思考這一轉變,我開(kāi)始更加擔心軟件接口問(wèn)題。畢竟,HLS創(chuàng )建的硬件專(zhuān)注于處理硬件接口。我需要一些易于訪(fǎng)問(wèn)的工具(如協(xié)處理器或硬件加速器)來(lái)加快軟件運行速度。而且,我不想編寫(xiě)新的編譯器。為了方便與軟件的其它部分交換數據,這個(gè)接口應該類(lèi)似于簡(jiǎn)單的存儲單元,我們可以在其中輸入信息并稍后讀取結果。

然后我有了新的發(fā)現。Vivado HLS支持以相對較小的努力輕松創(chuàng )建AXI從接口。這讓我開(kāi)始思考,創(chuàng )建加速器也許沒(méi)有那么難。于是,我編碼了一個(gè)簡(jiǎn)單的實(shí)例來(lái)探索這種可能性。探索的結果讓我驚喜不已。

下面看看我用了什么方法,并思考這種方法所得出的結果。

在我的實(shí)例中,我選擇了對一系列簡(jiǎn)單的矩陣運算(如加法和乘法)進(jìn)行建模。我不想將它限制在固定的大小,因此,我必須同時(shí)提供輸入陣列及各陣列的尺寸大小。理想的接口會(huì )將所有數值作為函數的自變量,例如圖1中的代碼。

硬件接口需要用一種簡(jiǎn)單的方法將函數自變量映射到存儲單元。圖2是支持這一映射的存儲器配置。寄存器中保存了有關(guān)矩陣的排列方式以及所需運算的信息。指令寄存器將指示執行何種運算。這樣我便可以將一些簡(jiǎn)單的運算融合到一個(gè)硬件中??梢杂脿顟B(tài)寄存器來(lái)查看是否正在進(jìn)行運算或是已經(jīng)成功完成運算。此外,器件最好還能提供中斷支持。

回到硬件設計,我了解到Vivado HLS為陣列自變量留出空間以指定小容量?jì)却?。這樣,圖3所示函數便說(shuō)明了這種函數性。

假設能夠綜合AXI從接口,怎樣將它用在軟件上?我將正常編碼環(huán)境假設為L(cháng)inux。還好賽靈思提供PetaLinux,而且PetaLinux提供一種叫做用戶(hù)I/O器件的機制。UIO可以用簡(jiǎn)單的方法將新硬件映射到用戶(hù)內存空間,并具備中斷等待能力。這意味著(zhù)您可以省去編寫(xiě)器件驅動(dòng)程序所耗費的的時(shí)間和流程。圖4顯示了這個(gè)系統。

這種方式當然也有缺陷。例如,無(wú)法在DMA中使用UIO器件,因此您必須在器件內存中構建矩陣,并在構建完成后手動(dòng)復制出來(lái)。如果需要,將來(lái)可以通過(guò)定制器件驅動(dòng)程序解決這個(gè)問(wèn)題。

用Vivado HLS綜合硬件

現在回到綜合AXI從接口的話(huà)題。它的綜合難度有多大?我發(fā)現這些編碼限制非常合理。除內存的動(dòng)態(tài)分配以外,大多數C ++語(yǔ)言都可以使用。

畢竟硬件在運行過(guò)程中不能生產(chǎn)其本身。這限制了標準模板庫(STL)功能的使用,因為這里大量使用了動(dòng)態(tài)分配。只要數據保持靜態(tài),多數功能都可以使用。起初這項任務(wù)似乎非常繁重,但我發(fā)現這并不是什么大事。另外,Vivado HLS允許C++類(lèi)、模板、函數和運算符重載。我的矩陣運算可輕易歸入定制矩陣分類(lèi)。

增加I/O來(lái)創(chuàng )建AXI從接口非常簡(jiǎn)單。只需增加一些能夠指示包含哪些端口以及使用哪些協(xié)議的編譯指示即可。

只要我不按下所有旋鈕,運行這款綜合工具非常簡(jiǎn)單。圖5展示了其中各個(gè)步驟,在此我不再詳細解釋。需要就目標技術(shù)和時(shí)鐘速度對Vivado HLS進(jìn)行一些引導。之后涉及的程序會(huì )密切關(guān)注違反政策的報告并研究分析報告以確保Vivado HLS按我所期望的方式運行。工具用戶(hù)必須對硬件方面有所了解,但有一些技術(shù)課程可以解決這個(gè)問(wèn)題。還存在綜合前后運行仿真以檢驗預期行為的問(wèn)題。

Vivado IP Integrator讓AXI從接口連接到Zynq SoC硬件變得輕而易舉,并打消了對信號連接錯誤的顧慮。賽靈思甚至擁有我所使用的ZedBoard開(kāi)發(fā)系統的系統概述,并用IP Integrator導出數據用于軟件開(kāi)發(fā)套件。

清除瓶頸

我對結果非常滿(mǎn)意,我希望能用這款芯片與工具集的組合做更多事情。我并沒(méi)有探索所有的可能性。例如,Vivado HLS還支持AXI主接口。AXI會(huì )允許加速器從外部存儲器復制矩陣(盡管這樣也可能存在安全問(wèn)題)。不過(guò)我強烈建議所有面臨代碼瓶頸的人都能考慮這個(gè)工具集。這里提供足夠的培訓課程、資源和材料以實(shí)現快速勻變,其中包括Doulos提供的課程、資源和材料。如需了解更多信息,敬請訪(fǎng)問(wèn):www.doulos.com。

image001.jpg

圖1 – 調用加速器示例

地址寄存器名稱(chēng)目錄位元

內容

0Matrix0_ptrRW32

Matrix 0數據地址

4Matrix0_shapeRW32Matrix 0行Matrix 0列
8Matrix1_ptrRW32

Matrix 1數據地址

12Matrix1_shapeRW32Matrix 1行Matrix 1列
16Matrix2-ptrRW32

Matrix 2數據地址

20Matrix2_shapeRW32Matrix 2行Matrix 2列
24Matrix3_ptrRW32

Matrix 3數據地址

28Matrix3_shapeRW32Matrix 3行Matrix 3列
32-reserved--32

 

36-reserved--32

 

40CommandRW320enum
44StatusRW320enum

8192 × 32存儲器

圖2 – 寄存器匯總表

image002.jpg

圖3 – 加速器函數API



關(guān)鍵詞: FPGA Vivado

評論


相關(guān)推薦

技術(shù)專(zhuān)區

關(guān)閉
国产精品自在自线亚洲|国产精品无圣光一区二区|国产日产欧洲无码视频|久久久一本精品99久久K精品66|欧美人与动牲交片免费播放
<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>