當(dāng)前位置:首頁(yè) > 嵌入式 > 嵌入式軟件
[導(dǎo)讀]解決SoC FPGA設(shè)計(jì)難題

主要FPGA供應(yīng)商已經(jīng)開(kāi)始銷售集成了硬核處理器內(nèi)核的低成本FPGA器件,SoC類FPGA器件最終會(huì)成為主流。為能夠充分發(fā)揮所有重要FPGA的靈活性,這些器件提供了FPGA設(shè)計(jì)人員和軟件工程師還不熟悉的新特性。設(shè)計(jì)人員需要考慮怎樣在FPGA和處理器之間初始化這些資源并進(jìn)行分配,管理復(fù)雜的連接,以及處理器外設(shè)的各種設(shè)置。

 

I/O限制

 

您可能會(huì)說(shuō),“I/O有什么問(wèn)題?FPGA有很多I/O!”然而,F(xiàn)PGA現(xiàn)在采用了功能強(qiáng)大的雙核Cortex-A9處理器,需要高性能存儲(chǔ)器系統(tǒng)。如果您不需要處理器,您不用購(gòu)買(mǎi)器件,因此,連接DDR2/3存儲(chǔ)器來(lái)提高性能是最重要的。這需要72個(gè)專用引腳。這里不僅有功能強(qiáng)大的處理器,而且還有多種有用的標(biāo)準(zhǔn)外設(shè)(例如USB、以太網(wǎng)等)—這就需要更多的引腳。增加一系列電源和地引腳以實(shí)現(xiàn)良好的信號(hào)完整性,這會(huì)使得以前足夠用的BGA引腳開(kāi)始顯得捉襟見(jiàn)肘。對(duì)于硬件外設(shè),好在這些器件具有復(fù)用功能,因此,您可以簡(jiǎn)單地選擇并引出您需要的外設(shè)。

 

引腳配置

 

對(duì)FPGA器件進(jìn)行編程的比特流含有怎樣配置I/O引腳的信息。實(shí)際上,SoC FPGA器件的工作方式相似,但是有兩種不同的引腳配置過(guò)程—一種用于FPGA I/O,一種用于處理器專用I/O(這也包括配置硬件外設(shè)復(fù)用、I/O引腳和DDR控制器設(shè)置),如圖1。之所以需要DDR控制器設(shè)置,是因?yàn)樾枰獮槟承┢骷碗娐钒宀季终{(diào)整高性能存儲(chǔ)器控制器,以實(shí)現(xiàn)最優(yōu)存儲(chǔ)器性能。在FPGA硬件開(kāi)發(fā)工具中進(jìn)行處理器專用I/O和存儲(chǔ)器控制器設(shè)置,其方式與FPGA引腳相似。如果您不對(duì)FPGA進(jìn)行編程,所有這些配置數(shù)據(jù)是怎樣進(jìn)入器件中的呢?

 

 


圖1,Altera SoC FPGA系統(tǒng),顯示了專用處理器和FPGA I/O引腳(右側(cè))

 

處理器啟動(dòng)

 

低成本微控制器簡(jiǎn)化了從片內(nèi)ROM的啟動(dòng),而高端處理器從外部ROM(例如x86 BIOS)啟動(dòng),然后,裝入第二個(gè)啟動(dòng)加載程序。與微控制器相似,SoC FPGA器件有硬線片內(nèi)啟動(dòng)ROM,含有啟動(dòng)處理器的啟動(dòng)代碼,但是這些代碼也配置I/O引腳,這些引腳用于從FPGA、閃存或者SD卡中讀取數(shù)據(jù)。這樣,系統(tǒng)將第二個(gè)啟動(dòng)加載程序鏡像裝入片內(nèi)RAM。 [!--empirenews.page--]

 

第二個(gè)啟動(dòng)加載程序二進(jìn)制代碼和專用I/O引腳配置設(shè)置內(nèi)置在一個(gè)鏡像文件中,這一鏡像也含有FPGA配置數(shù)據(jù)、處理器軟件(操作系統(tǒng)(OS)啟動(dòng)加載程序、OS以及應(yīng)用軟件)。這一鏡像文件存儲(chǔ)在介質(zhì)中,成為處理器的啟動(dòng)源。當(dāng)處理器從片內(nèi)ROM啟動(dòng)時(shí),它讀取外部引腳的狀態(tài),選擇啟動(dòng)源,將第二個(gè)啟動(dòng)加載程序裝入片內(nèi)RAM,然后運(yùn)行它。這些代碼設(shè)置處理器,配置外部存儲(chǔ)器控制器和專用外設(shè)I/O引腳,允許用戶應(yīng)用程序代碼(可以是OS的啟動(dòng)加載程序)從啟動(dòng)源裝入到DDR存儲(chǔ)器中。在這一階段,配置處理器和所有處理器專用I/O—因此,OS啟動(dòng)加載程序(例如U-Boot)甚至可以通過(guò)外設(shè)(例如通過(guò)以太網(wǎng))來(lái)裝入OS二進(jìn)制代碼。

 

 


圖2,典型的SoC FPGA啟動(dòng)過(guò)程
[!--empirenews.page--]

 

軟外設(shè)

 

最后,我們有經(jīng)過(guò)全面配置的芯片,可以啟動(dòng)OS或者應(yīng)用程序—而有可能還沒(méi)有配置FPGA。OS/應(yīng)用程序一般會(huì)在啟動(dòng)時(shí)初始化所有外設(shè),但是在這一例子中,可能還沒(méi)有外設(shè)!一種簡(jiǎn)單的方法是,在出現(xiàn)這種情況之前對(duì)FPGA進(jìn)行配置,但是,如果您需要軟件從一組不同的配置中進(jìn)行選擇,會(huì)怎樣呢?您甚至可能希望隨時(shí)重新配置FPGA,改變外設(shè)。

 

開(kāi)發(fā)基于FPGA的外設(shè)系統(tǒng)相對(duì)簡(jiǎn)單,F(xiàn)PGA供應(yīng)商提供IP庫(kù)以及基于GUI的設(shè)計(jì)工具,使您很容易連接外設(shè)IP和硬核處理器。對(duì)此,設(shè)計(jì)流程與使用Nios II處理器等軟核CPU的流程完全相同。一般不能修改硬核處理器系統(tǒng)的特性,您需要做的是在基于GUI的工具中配置專用引腳復(fù)用功能,連接外設(shè)IP。

 

FPGA設(shè)計(jì)工具以頭文件的形式實(shí)現(xiàn)了軟件開(kāi)發(fā)工具鏈的所有硬件相關(guān)數(shù)據(jù)(基本地址等),這一頭文件可以用于生成預(yù)構(gòu)建應(yīng)用程序,從而匹配每一FPGA配置和外設(shè)。但是,如果您使用OS,這可能帶來(lái)問(wèn)題,理想情況下,您需要外設(shè)驅(qū)動(dòng)軟件應(yīng)用程序。

 

好在大部分OS支持動(dòng)態(tài)驅(qū)動(dòng)裝入和卸載,因此,可以讀取外設(shè),讓OS裝入相應(yīng)的驅(qū)動(dòng)。如果您重新配置FPGA,只需要卸載驅(qū)動(dòng),然后重新裝入含有新配置的驅(qū)動(dòng)。這看起來(lái)是一項(xiàng)很難的工作,但是,大部分OS支持這樣做,Linux甚至提供一種名為器件樹(shù)的功能,實(shí)際專門(mén)用于在Linux文件系統(tǒng)中存儲(chǔ)外設(shè)相關(guān)數(shù)據(jù)。每一FPGA配置會(huì)有一個(gè)匹配器件樹(shù)文件,因此,對(duì)于Linux,您需要做的是,裝入正確的器件樹(shù),Linux就會(huì)裝入正確的驅(qū)動(dòng)。圖2是一個(gè)典型的SoC FPGA啟動(dòng)過(guò)程。

 

結(jié)論

 

由于處理器和FPGA緊密集成到一個(gè)器件中,與標(biāo)準(zhǔn)FPGA相比,開(kāi)發(fā)這些新器件會(huì)稍微復(fù)雜一些,而SoCFPGA器件供應(yīng)商提供支持工具流和機(jī)制,管理所需的功能要相對(duì)簡(jiǎn)單—即使您以前從未使用過(guò)FPGA中的處理器。

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國(guó)汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開(kāi)發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來(lái)越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來(lái)越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開(kāi)幕式在貴陽(yáng)舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語(yǔ)權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營(yíng)業(yè)績(jī)穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤(rùn)率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長(zhǎng) 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭(zhēng)力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭(zhēng)優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營(yíng)商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國(guó)電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長(zhǎng)三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡(jiǎn)稱"軟通動(dòng)力")與長(zhǎng)三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉