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

          新聞中心

          EEPW首頁 > EDA/PCB > 設(shè)計(jì)應(yīng)用 > 基于LEON3處理器和Speed協(xié)處理器的復(fù)雜SoC設(shè)計(jì)

          基于LEON3處理器和Speed協(xié)處理器的復(fù)雜SoC設(shè)計(jì)

          作者: 時(shí)間:2009-07-16 來源:網(wǎng)絡(luò) 收藏

            利用AHB實(shí)現(xiàn)通信

            為了實(shí)現(xiàn)可編程,需要將C/C++程序表達(dá)的信息經(jīng)過編譯器、、AHB總線、DMA控制器和必要的HDL代碼,轉(zhuǎn)化成能夠識(shí)別的信息,進(jìn)入模塊中,如圖2。其中AHB總線是 Core和 Core結(jié)合的關(guān)鍵。

          實(shí)現(xiàn)軟件可編程的過程

          圖2 實(shí)現(xiàn)軟件可編程的過程

            AHB總線及AHB控制器

            AMBA總線是一種應(yīng)用廣泛的層次化總線結(jié)構(gòu),有高速的AHB和低速APB之分,其中AHB是一種流水式高速總線結(jié)構(gòu),地址和數(shù)據(jù)總線相互獨(dú)立,可掛載16個(gè)Master和Slaver設(shè)備,常用來組織和連接高性能模塊,如、DMA控制器、協(xié)等[5~7]。AHB總線的核心是AHB控制器,主要包括仲裁器,譯碼器和多路復(fù)用器,其中仲裁器選擇AHB Master,而譯碼器選擇AHB Slave,實(shí)現(xiàn)寫數(shù)據(jù)WDATA和讀數(shù)據(jù)RDATA分開,如圖3所示。

          AHB總線的組成結(jié)構(gòu)

            DMA控制器

            DMA是指設(shè)備直接對(duì)計(jì)算機(jī)存儲(chǔ)器進(jìn)行讀寫操作的方式。這種方式下數(shù)據(jù)的讀寫無需CPU執(zhí)行指令,也不經(jīng)過CPU內(nèi)部寄存器,而是利用系統(tǒng)的數(shù)據(jù)總線直接在源地址和目的地址之間傳送數(shù)據(jù),達(dá)到極高的傳輸速率。DMA控制器一方面可以接管總線,即可以像CPU一樣視為總線的主設(shè)備,這是DMA與其它外設(shè)最根本的區(qū)別;另一方面,作為一個(gè)I/O器件,其DMA控制功能正式通過初始化編程來設(shè)置。當(dāng)CPU對(duì)其寫入或讀出時(shí),它又和其它的外設(shè)一樣成為總線的從屬設(shè)備。

            本文中為了實(shí)現(xiàn)DMA和AHB密切配合,即啟動(dòng)DMA后大量原始數(shù)據(jù)通過AHB總線從數(shù)據(jù)存儲(chǔ)器進(jìn)入Speed模塊,需要DMA控制器內(nèi)部包含AHB Master模塊,如圖4所示。另外需要說明的是,為了實(shí)現(xiàn)AHB上設(shè)備的plugplay需要在0xFFFFF000-0xFFFFF800地址空間添加設(shè)備信息[8~9],所以DMA 控制器和Speed協(xié)處理器亦要如此,以便LEON3的軟硬件協(xié)調(diào)一致。在C語言實(shí)現(xiàn)DMA時(shí),向DMA的控制寄存器寫入相應(yīng)的信息,即可啟動(dòng)DMA傳輸,如圖5所示。

          DMA與AHB Master的關(guān)系

          啟動(dòng)DMA的C代碼示意
          圖5 啟動(dòng)DMA的C代碼示意

            Speed的AHB接口



          關(guān)鍵詞: LEON3 Speed SoC 處理器

          評(píng)論


          相關(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); })();