<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>
關(guān) 閉

新聞中心

EEPW首頁(yè) > 工控自動(dòng)化 > 設計應用 > 如何實(shí)現微控制器與FPGA的接口設計

如何實(shí)現微控制器與FPGA的接口設計

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

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

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

  基于FPGA的MCU有兩種基本方式:一種是在FPGA邏輯結構中內置MCU軟核;一種是使用基于離散FPGA的標準MCU產(chǎn)品。FPGA內置軟核有效果,但與標準MCU相比,該方式一個(gè)微是比較昂貴和耗電的。尤其是使用基于32位ARM的內核。結果,基于FPGA內置軟核的FPGA MCU只占三分之一。其余的三分之二是基于離散FPGA的標準微產(chǎn)品。

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

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

  PIO接口

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

PIO連接FPGA

圖1 PIO連接FPGA

  為了將數據傳輸到FPGA,PIO中的雙向緩沖器方向必須設置為輸出。數據傳輸到FPGA的軟件算法如下:

程序

  從FPGA讀取數據的方法相似。同樣,PIO中的緩沖區首先必須設置為輸出,然后改變方向為輸入從FPGA讀取數據,下面是執行代碼:

程序

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

  訪(fǎng)問(wèn)時(shí)間計算的總和:

T訪(fǎng)問(wèn)-PIO=t1+處理階段+t2+數據階段

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

PIO向FPGA 寫(xiě)數據

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

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

PIO從FPGA讀取數據

圖3 PIO從FPGA讀取數據

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


上一頁(yè) 1 2 下一頁(yè)

評論


相關(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>