<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          關(guān) 閉

          新聞中心

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

          如何實現(xiàn)微控制器與FPGA的接口設(shè)計

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

          本文引用地址:http://www.ex-cimer.com/article/161161.htm

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

            通過外部總線連接(EIB)

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

          EBI-SMC接口

          圖4 EBI-SMC接口

            圖5顯示了EBI讀SMC存儲器接口的標準時間,而圖6顯示了其標準寫周期。

          EBI-SMC讀周期

          圖5 EBI-SMC讀周期

          EBI-SMC寫周期

          圖6 EBI-SMC寫周期

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

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

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


          上一頁 1 2 下一頁

          評論


          相關(guān)推薦

          技術(shù)專區(qū)

          關(guān)閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();