當(dāng)前位置:首頁(yè) > 工業(yè)控制 > 工業(yè)控制
[導(dǎo)讀] 將近一半的嵌入式設(shè)計(jì)用到FPGA,僅次于微控制器。FPGA可用于執(zhí)行任何膠合邏輯、自定義IP 、計(jì)算密集型算法加速器。通過(guò)采取一些處理任務(wù), FPGA可以幫助提高系統(tǒng)性能,從而使單片機(jī)從周期密集的任務(wù)中騰出部分時(shí)間

 將近一半的嵌入式設(shè)計(jì)用到FPGA,僅次于微控制器。FPGA可用于執(zhí)行任何膠合邏輯、自定義IP 、計(jì)算密集型算法加速器。通過(guò)采取一些處理任務(wù), FPGA可以幫助提高系統(tǒng)性能,從而使單片機(jī)從周期密集的任務(wù)中騰出部分時(shí)間。FPGA還提供優(yōu)良的性能特點(diǎn)和更的靈活性,以適應(yīng)不斷變化的標(biāo)準(zhǔn)。

  基于FPGA的MCU設(shè)計(jì)有兩種基本實(shí)現(xiàn)方式:一種是在FPGA邏輯結(jié)構(gòu)中內(nèi)置MCU軟核;一種是使用基于離散FPGA的標(biāo)準(zhǔn)MCU產(chǎn)品。FPGA內(nèi)置軟核有效果,但與標(biāo)準(zhǔn)MCU相比,該方式實(shí)現(xiàn)一個(gè)微控制器是比較昂貴和耗電的。尤其是使用基于32位ARM的內(nèi)核。結(jié)果,基于FPGA內(nèi)置軟核的FPGA MCU設(shè)計(jì)只占三分之一。其余的三分之二是基于離散FPGA的標(biāo)準(zhǔn)微控制器產(chǎn)品。

  標(biāo)準(zhǔn)微控制器產(chǎn)品和FPGA都沒(méi)有有效的發(fā)展兩者之間的通信,甚至使用不同的語(yǔ)言。因此,它們之間的接口將是一種挑戰(zhàn)。FPGA的沒(méi)有任何專(zhuān)門(mén)的邏輯電路來(lái)與微控制器通訊。首先,這種邏輯模塊的設(shè)計(jì)必須從零開(kāi)始。其次,微控制器和FPGA之間的通信是異步的。特別是需要使單片機(jī)與FPGA時(shí)鐘域同步。最后,無(wú)論是接口,還是微控制器總線,都存在瓶頸問(wèn)題。MCU和FPGA之間的信息傳遞通常需要在MCU總線上循環(huán),且通常占用資源(PIO or EBI)影響傳遞速度。因此必須注意避免與外部SRAM或閃存和微控制器總線的瓶頸問(wèn)題。

  MCU的FPGA接口基本上有三種硬件選擇:可編程的I / O(PIO);外部總線接口( EBI的),如果有的話;最后,MCU之間的一個(gè)專(zhuān)門(mén)的接口,先進(jìn)的高速總線( AHB )和FPGA 。該方法的使用依賴(lài)于高端應(yīng)用和市場(chǎng)期望。

  PIO接口

  通過(guò)PIO 連接MCU和FPGA相對(duì)簡(jiǎn)單數(shù)據(jù)傳輸來(lái)說(shuō)比較簡(jiǎn)單,包括傳輸32位的地址, 32位數(shù)據(jù),還有一些控制信號(hào)的控制。這就需要一個(gè)32位的PIO和一個(gè)2位PIO(圖1) 。

圖1 PIO連接FPGA

  為了將數(shù)據(jù)傳輸?shù)紽PGA,PIO中的雙向緩沖器方向必須設(shè)置為輸出。數(shù)據(jù)傳輸?shù)紽PGA的軟件算法實(shí)現(xiàn)如下:

  從FPGA讀取數(shù)據(jù)的方法相似。同樣,PIO中的緩沖區(qū)首先必須設(shè)置為輸出,然后改變方向?yàn)檩斎霃腇PGA讀取數(shù)據(jù),下面是執(zhí)行代碼:

  上述算法是一個(gè)基本的傳輸,更先進(jìn)的算法是必要在ARM微控制器和FPGA之間建立適當(dāng)?shù)耐ㄐ?。特別要注意的是,確保數(shù)據(jù)的可靠性,例如沒(méi)有因高速或等待周期造成資料遺失等。

  訪問(wèn)時(shí)間計(jì)算的總和:

T訪問(wèn)-PIO=t1+處理階段+t2+數(shù)據(jù)階段

  使用最大優(yōu)化的GCC編譯器,系統(tǒng)大約需要55個(gè)AHB周期向FPGA執(zhí)行寫(xiě)操作(圖2)。

 

 

圖2 PIO向FPGA 寫(xiě)數(shù)據(jù)

  假設(shè)t2(FPGA的等待響應(yīng)時(shí)間)也大約是25個(gè) AHB周期,系統(tǒng)大約需要85個(gè)AHB周期從FPGA進(jìn)行讀操作(圖3)。

 

 

圖3 PIO從FPGA讀取數(shù)據(jù)

  MCU自身接口連接非常簡(jiǎn)單和直截了當(dāng)。然而,在FPGA里必須用特殊的邏輯來(lái)解碼所有的由PIO生成的業(yè)務(wù)流。在大多數(shù)情況下,微控制器的業(yè)務(wù)流是完全異步。因此,F(xiàn)PGA必須能夠從微控制器中過(guò)采樣控制信號(hào);否則,F(xiàn)PGA將錯(cuò)過(guò)時(shí)間窗口且業(yè)務(wù)流將不會(huì)最終到達(dá)FPGA內(nèi)。

  因?yàn)樘幚砥鲗?zhuān)門(mén)負(fù)責(zé)維持PIO工作,所以處理時(shí)間消耗很大。雖然CPU是從事數(shù)據(jù)傳輸,它還是不能做別的事了。因此,這一解決方案有可能使系統(tǒng)處理陷入癱瘓。DMA不可能使用的PIO接口,所以程序員必須限制的數(shù)據(jù)帶寬,以便其他任務(wù)能夠與MCU進(jìn)行通訊。例如,如果有一個(gè)常規(guī)的進(jìn)程要求100 %的處理器運(yùn)行周期,同時(shí)又要與FPGA進(jìn)行串行(SPI,USART或TWI)通信(讀或?qū)懀?,那么這兩個(gè)進(jìn)程必須有一個(gè)要等待。如果發(fā)送到或接受來(lái)自FPGA的數(shù)據(jù)沒(méi)有及時(shí)的存進(jìn)緩沖區(qū),那么到下一個(gè)字節(jié)/字?jǐn)?shù)據(jù)時(shí)可能會(huì)溢出。從本質(zhì)上講,嵌入式處理器成為受??賴(lài)的數(shù)據(jù)移動(dòng)硬盤(pán)。

  通過(guò)外部總線接口連接(EIB)

  許多32位微控制器有一個(gè)外部總線接口(EBI)模塊,它是為外部設(shè)備和基于ARM設(shè)備的存儲(chǔ)控制器之間傳輸數(shù)據(jù)而設(shè)計(jì)的。這些外部存儲(chǔ)控制器能夠處理幾種類(lèi)型的外部存儲(chǔ)器和外圍設(shè)備,如SRAM,PROM,EPROM,EEPROM,flash和SDRAM。只要FPGA可以處理預(yù)定義存儲(chǔ)器接口,EBI也可用于FPGA的接口。在EBI中使用靜態(tài)存儲(chǔ)器接口(SRAM)對(duì)于FPGA通信來(lái)說(shuō)是最好的,因?yàn)樗O(shè)計(jì)簡(jiǎn)單,且大多數(shù)設(shè)計(jì)者都熟悉它。至于PIO接口, FPGA不得不包含一個(gè)模塊,用來(lái)理解SRAM時(shí)間,并能產(chǎn)生一個(gè)響應(yīng)返回微控制器(圖4)。

圖4 EBI-SMC接口

  圖5顯示了EBI讀SMC存儲(chǔ)器接口的標(biāo)準(zhǔn)時(shí)間,而圖6顯示了其標(biāo)準(zhǔn)寫(xiě)周期。

 

 

 

圖5 EBI-SMC讀周期

 

 

圖6 EBI-SMC寫(xiě)周期

  注意:這些時(shí)間波形是默認(rèn)的SMC規(guī)格。所有可編程參數(shù)顯示都基于外部設(shè)備的速度。

  EBI的接口速度比PIO塊,是因?yàn)镋BI有其自己的I / O,且大部分的信號(hào)是并行的。但是,如果外部設(shè)備很慢或引入等待狀態(tài), EBI的速度優(yōu)勢(shì)可能會(huì)受到損害。

  跟PIO接口一樣, EBI接口必須由處理器或其他的主AHB來(lái)驅(qū)動(dòng)。因此,實(shí)現(xiàn)帶寬的EBI的還依賴(lài)于軟件,并取決于它可以利用多少處理器時(shí)間。當(dāng)然,可能受到帶寬的限制。這又可能限制了嵌入式處理器旨在實(shí)現(xiàn)的其他系統(tǒng)功能。

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

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

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

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

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

北京2024年8月28日 /美通社/ -- 越來(lái)越多用戶(hù)希望企業(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ā)表演講稱(chēng),數(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)稱(chēng)"軟通動(dòng)力")與長(zhǎng)三角投資(上海)有限...

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