《電子技術(shù)應(yīng)用》
您所在的位置:首頁 > 通信與網(wǎng)絡(luò) > 設(shè)計應(yīng)用 > 一種基于MPC8260和FPGA的DMA接口設(shè)計與實現(xiàn)
一種基于MPC8260和FPGA的DMA接口設(shè)計與實現(xiàn)
EEworld
EEworld
摘要: 摘要以MPC8260通信處理器為硬件平臺,結(jié)合中斷處理和IDMA傳輸機制設(shè)計一種最高傳輸速率可達500Mbps的數(shù)據(jù)傳...
關(guān)鍵詞: MPC8260 DMA接口
Abstract:
Key words :

關(guān)鍵字:MPC8260 DMA接口

  引言

  在基于軟件無線電的某無線通信信號偵收平臺的設(shè)計中,天線接收到的信號經(jīng)過變頻器處理和A/D變換之后,,經(jīng)過高速通道把采集的信號送入主控板進行數(shù)據(jù)分發(fā)處理。系統(tǒng)的結(jié)構(gòu)框圖如圖1所示,。

  圖1 主控板的系統(tǒng)結(jié)構(gòu)框圖

  主控板的硬件核心是嵌入式微處理器MPC8260,負責系統(tǒng)軟件的加載,、數(shù)據(jù)的分發(fā)以及與外界命令控制的交互,。軟件上,采用高性能的VxWorks嵌入式實時操作系統(tǒng),。從天線接收到的射頻信號經(jīng)過變頻和A/D變換之后作為數(shù)據(jù)源連接到FPGA,,F(xiàn)PGA對接收到的數(shù)據(jù)進行中頻變換和信道估計等預處理后,在CPU的控制下將數(shù)據(jù)傳輸?shù)奖镜貎?nèi)存,,最后CPU對數(shù)據(jù)打包后進行快速分發(fā),。

  嵌入式微控制器的典型代表是單片機(Microcontroller Unit),這種8位(8根數(shù)據(jù)線,,8位指令)的電子器件目前在嵌入式設(shè)備中仍然有著極其廣泛的應(yīng)用,。微控制器的最大特點是單片化,體積大大減小,,從而使功耗和成本下降,、可靠性提高。

  嵌入式微處理器(Microprocessor Unit,,MPU)由通用計算機中的CPU演變而來,。與通用計算機中的CPU不同的是,在嵌入式應(yīng)用中,,將微處理器裝配在專門設(shè)計的電路板上,,只保留和嵌入式應(yīng)用緊密相關(guān)的功能硬件,去除其他的冗余功能部分,,這樣就以最低的功耗和資源實現(xiàn)嵌入式應(yīng)用的特殊要求,。此外,為了滿足嵌入式應(yīng)用的特殊要求,,嵌入式微處理器在工作溫度,、抗電磁干擾、可靠性等方面相對通過通用計算機中的CPU都做了各種增強,。

  如果每傳遞一個字節(jié)的數(shù)據(jù)都需要CPU的介入,,那么不論是采用中斷驅(qū)動還是采用程序查詢的方式,數(shù)據(jù)傳輸速率都會很低,,無法滿足系統(tǒng)需求,。MPC8260支持多種DMA實現(xiàn)方式,,分別適用于不同數(shù)據(jù)傳輸源/目的設(shè)備、不同傳輸數(shù)據(jù)塊大小和存儲模式的需要,,因此需要根據(jù)主控板的系統(tǒng)特點設(shè)計出合適的DMA傳輸接口,。

  1 MPC8260的 DMA系統(tǒng)結(jié)構(gòu)

  圖2 CPM原理框圖

  MPC8260是Freescale公司主要針對數(shù)據(jù)通信領(lǐng)域而設(shè)計的一種嵌入式PowerPC微處理器,,具有雙核結(jié)構(gòu):1個高性能的MPC603e 64位RISC微處理器內(nèi)核和1個專為通信設(shè)計的32位RISC通信處理模塊(Communication Processor Module,,CPM)。CPM的原理框圖如圖2所示,。除了PowerPC內(nèi)核和CPM之外,,MPC8260還包含一個靈活的系統(tǒng)接口單元(System Interface Unit,SIU)主要用于控制與外部總線的接口,。

  圖2中,, CPM內(nèi)除了SDMA模塊以外,還包括通信控制器(Communications Processor,,CP),、雙口RAM和一些串行外圍設(shè)備的控制接口等。SDMA和60x總線,、本地總線相連,,并且可以直接訪問CPM內(nèi)部的雙口RAM。同時,,CPM還用這2個物理的SDMA通道模擬4個可編程控制的,、獨立的DMA (Independent DMA,IDMA)通道,,用于存儲器—存儲器及外設(shè)—存儲器之間的數(shù)據(jù)傳輸,。

  主控板上的FPGA和SDRAM都是掛接在MPC8260的60x總線上的,所以只能利用IDMA來實現(xiàn)二者之間的DMA傳輸,。根據(jù)傳輸啟動的觸發(fā)方式不同,,IDMA可分為握手信號控制的IDMA傳輸和CP命令控制的IDMA傳輸兩種。下面分別介紹兩種方式的特點,。

  1.1 握手信號控制的IDMA傳輸

  握手信號控制的IDMA傳輸主要用于外設(shè)和內(nèi)存之間的數(shù)據(jù)傳輸,。每個IDMA通道都有3個握手信號用于傳輸握手控制:DMA請求信號DREQ[1~4]、DMA應(yīng)答信號DACK[1~4]和DMA結(jié)束信號DONE[1~4],。

  在這種方式下,,PowerPC內(nèi)核只需要參與IDMA通道初始化,之后的傳輸過程全部由CP按照通道參數(shù)設(shè)置和握手信號控制數(shù)據(jù)的收發(fā),,在最大程度上釋放內(nèi)核,。握手信號控制的缺點在于:① SDRAM中的數(shù)據(jù)和MPC8260的數(shù)據(jù)同步比較復雜。② 每次發(fā)出請求信號后都要進行總線仲裁,,并且在得到總線使用權(quán)之后一次只能夠傳輸外設(shè)端口大小或者32位的數(shù)據(jù),,總線利用率低,。③ 握手控制邏輯和時序比較復雜,加重了FPGA內(nèi)部控制邏輯設(shè)計的負擔,。

  雖然這種傳輸方式基本上不占用內(nèi)核資源,,但是由于總線帶寬有限且利用率較低,所以在連續(xù)高速的通信條件下會造成內(nèi)核長時間得不到總線使用權(quán)而一直處于等待狀態(tài),。因此,,握手信號控制的IDMA一般只適用于由外設(shè)發(fā)起的、數(shù)據(jù)不是太頻繁的傳輸使用,。

  1.2 CP命令控制的IDMA傳輸

  MPC8260的IDMA還可以通過向CP命令寄存器中寫入START_IDMA命令進行內(nèi)部觸發(fā),。每次啟動傳輸以后PowerPC內(nèi)核就被釋放,傳輸?shù)脑吹刂?、目的地址和傳輸?shù)據(jù)長度等參數(shù)由CP按照在IDMA通道初始化的信息控制執(zhí)行,。每次傳輸?shù)淖畲箝L度為4 GB。

  相比握手信號控制的IDMA傳輸,,在這種方式下,,PowerPC內(nèi)核除了需要初始化IDMA通道以外還要以命令的形式啟動每一次的傳輸,所以要占用多一些的內(nèi)核資源,。不過,,在一次傳輸啟動之后最多可以傳輸4 GB的數(shù)據(jù),所以只要每次傳輸?shù)臄?shù)據(jù)長度比較長,,內(nèi)核寫一個寄存器的額外開銷就完全可以忽略不計,。同時,由于內(nèi)部命令觸發(fā)方式不需要握手信號,,不需要頻繁地每幾個字節(jié)就競爭一次總線控制權(quán),,所以這種方式的傳輸效率更高、傳輸速度更快,。內(nèi)部命令觸發(fā)方式是以空間換時間——用前端大的緩沖區(qū)來換取傳輸速度的提升,。

  考慮到主控板上軟硬件系統(tǒng)的瓶頸都在于總線帶寬,而存儲資源相對比較豐富,,所以選擇CP命令控制的IDMA傳輸作為數(shù)據(jù)流從FPGA到SDRAM的傳輸方式,。

  2 DMA傳輸方案設(shè)計

  FPGA和MPC8260間的數(shù)據(jù)傳輸接口設(shè)計如圖3所示。圖中左側(cè)FPGA,,通過16位數(shù)據(jù)線,、10位地址線、2根中斷請求線和一些讀寫控制信號線連接到右側(cè)的MPC8260,。MPC8260通過64位數(shù)據(jù)線與本地內(nèi)存SDRAM相連,。

  圖3 IDMA傳輸設(shè)計框圖

  FPGA內(nèi)部分配有兩個大的存儲空間,用于輪流緩沖從數(shù)據(jù)源接收到的數(shù)據(jù)。任何一個緩沖區(qū)收滿后,,繼續(xù)接收的數(shù)據(jù)保存到下一個緩沖區(qū),,同時以中斷的方式觸發(fā)MPC8260啟動相應(yīng)的IDMA通道把數(shù)據(jù)傳到SDRAM中。IDMA控制,、數(shù)據(jù)同步和錯誤處理都由MPC8260完成,,F(xiàn)PGA只負責收發(fā)數(shù)據(jù)和觸發(fā)中斷。下面分別介紹二者的程序設(shè)計,。

  2.1 MPC8260程序設(shè)計

  MPC8260內(nèi)部的程序處理流程如圖4所示,。MPC8260預先初始化兩個IDMA通道:通道的源地址和傳輸數(shù)據(jù)長度等信息與FPGA中的緩沖區(qū)一一對應(yīng)。當收到FPGA的中斷信號之后,,如果此時對應(yīng)的IDMA通道空閑,,則在中斷處理程序中發(fā)出CP命令開始接收數(shù)據(jù),,同時將對應(yīng)的IDMA通道置忙狀態(tài),;否則,在FPGA中可能發(fā)生了未讀取的數(shù)據(jù)被覆蓋的情況,,MPC8260進入錯誤處理程序,。在數(shù)據(jù)傳輸結(jié)束時由DMA控制器發(fā)送CPM內(nèi)部中斷到內(nèi)核,在中斷處理程序中一方面要恢復IDMA通道的參數(shù)設(shè)置,,另一方面要把該IDMA通道置閑狀態(tài)等待下一次傳輸?shù)拈_始,。

  MPC8260程序的核心部分是IDMA通道設(shè)置和中斷處理。

  圖4 MPC8260傳輸處理流程

  2.1.1 IDMA通道設(shè)置

  與一般的DMA通道設(shè)置一樣,,IDMA通道設(shè)置的主要參數(shù)包括:源地址,、目的地址和傳輸數(shù)據(jù)長度。除此之外,,MPC8260的 IDMA通道設(shè)置還包括通道模式,、緩沖區(qū)和中斷配置等,所涉及的寄存器比較多,,配置比較復雜,。IDMA通道設(shè)置的邏輯結(jié)構(gòu)如圖5所示。

  圖5 IDMA通道設(shè)置的邏輯結(jié)構(gòu)框圖

  BD(Buffer Descriptors)表是用于指定傳輸方式,、源/目的地址和數(shù)據(jù)長度等基本信息的數(shù)據(jù)結(jié)構(gòu),。BD表的基地址由參數(shù)RAM中IBASE寄存器的值指定。IDMAx_BASE寄存器的地址是固定的,,如IDMA1_BASE在偏移RAM基地址0x87FE的位置,。CP就是通過IDMAx_BASE寄存器找到IDMA參數(shù)RAM,再通過IBASE找到BD表的順序初始化IDMA通道的,。具體的寄存器配置可以參考文獻[1]第19章的IDMA編程示例,。

  為了提高通道的傳輸速率,系統(tǒng)中IDMA通道初始化應(yīng)該注意以下幾點:

  ① 需要在SIU中為FPGA配置UPM模式控制MPC8260和FPGA之間的突發(fā)讀寫,。不要使用通用目的片選機(GeneralPurpose Chipselect Machine,GPCM)模式,。因為MPC8260內(nèi)存控制的GPCM模式不支持突發(fā)傳輸,IDMA工作在GPCM模式下一方不論傳輸數(shù)據(jù)的長度是否滿足突發(fā)的要求,,都只能以普通的單次讀寫進行,。

  ② 把FPGA當作存儲器操作,,IDMA工作在內(nèi)存到內(nèi)存的雙地址模式下,,緩沖區(qū)設(shè)為最大的2 KB。

 ?、?BD表的配置應(yīng)該與FPGA中的緩沖區(qū)一一對應(yīng),。BD表結(jié)構(gòu)中的CM(Continuous Mode)位應(yīng)該設(shè)置為緩沖鏈模式,在每一個BD表傳輸完之后,,清BD表的有效位,;同時,CP根據(jù)下一個BD表的值自動裝載IDMA寄存器進行后面的傳輸,。

  IDMA通道初始化以后等待CP發(fā)出START_IDMA命令開始傳輸,。在最后一個BD表傳輸結(jié)束時觸發(fā)中斷信號通知PowerPC內(nèi)核本次傳輸過程的完成。傳輸過程中會發(fā)生改變的通道設(shè)置寄存器包括IDMA BD表指針,、源地址,、目的地址和BD表有效位等,所以在BD表傳輸結(jié)束的中斷處理程序中需要恢復這些寄存器為下一次傳輸作準備,。

  2.1.2 中斷處理

  中斷處理是與計算機專業(yè)有關(guān)的術(shù)語,。引起中斷的事件稱為中斷源。中斷源向CPU提出處理的請求稱為中斷請求,。發(fā)生中斷時被打斷程序的暫停點成為斷點,。CPU暫停現(xiàn)行程序而轉(zhuǎn)為響應(yīng)中斷請求的過程稱為中斷響應(yīng),。處理中斷源的程序稱為中斷處理程序,。CPU執(zhí)行有關(guān)的中斷處理程序稱為中斷處理。

  與一般中斷處理過程的區(qū)別在于:MPC8260中斷處理控制器采用分級結(jié)構(gòu)來擴展中斷信號總數(shù),。CPM內(nèi)的中斷就是二級中斷,,需要通過CPM中斷控制器和SIU中斷控制器兩級中斷控制。本設(shè)計中用來通知內(nèi)核本次傳輸過程結(jié)束的中斷是CPM內(nèi)最后一個BD表傳送結(jié)束的信號BC(BD Completed),。BC信號和命令結(jié)束等幾個信號一起通過SIU中斷掛起寄存器中的IDMA位向內(nèi)核發(fā)出中斷信號,。所以在中斷初始化時要同時有效IDMA屏蔽寄存器和SIU中斷屏蔽寄存器對應(yīng)的比特位。具體的中斷初始化實例如下:

  void IDMAint(void) {

  *(long*)(IDMR1)=0x0F000000;/*使能IDMA1所有的二級中斷*/

  *(long*)(IDMR2)=0x0F000000;/*使能IDMA2所有的二級中斷*/

  *(long*)(SIMR_L)|=0x00000600;/*使能IDMA1和IDMA2在SIU中的中斷*/

  *(long*)(SIMR_H)|=0x00006000;/*使能外部中斷IRQ1和IRQ2*/

  *(long*)(SIEXR)|=0x00006000; /*設(shè)置IRQ1和IRQ2為下降沿觸發(fā)*/

  *(long*)(SIUMCR)=0x81210000;/*配置SIU模式配置寄存器*/

  /*連接中斷服務(wù)程序和中斷向量號*/

  if((intConnect(INUM_TO_IVEC(INUM_IRQ1),,(VOIDFUNCPTR)IRQ1Handler,0))==ERROR)

  logMsg("intConnectIRQ1failedn",0,0,0,0,0,0),;

  if((intConnect(INUM_TO_IVEC(INUM_IRQ2),(VOIDFUNCPTR)IRQ2Handler,0))==ERROR)

  logMsg("intConnectIRQ2failedn",0,0,0,0,0,0);

  if((intConnect(INUM_TO_IVEC(INUM_IDMA1),,(VOIDFUNCPTR)IDMA11Handler,0))==ERROR)

  logMsg("intConnectIDMA1failedn",0,0,0,0,0,0),;

  if((intConnect(INUM_TO_IVEC(INUM_IDMA2),(VOIDFUNCPTR)IDMA2Handler,0))==ERROR)

  logMsg("intConnectIDMA2failedn",0,0,0,0,0,0),;

  }

  尤其要注意的是,,中斷處理程序結(jié)束之前的清SIU中斷掛起寄存器,不能直接在SIU中斷掛起寄存器的IDMA位寫1,,而是要通過在IDMA事件寄存器的BC位寫1來間接地清SIU中斷掛起寄存器,。

  2.2 FPGA部分程序

  FPGA(Field-Programmable Gate Array),即現(xiàn)場可編程門陣列,,它是在PAL,、GAL、CPLD等可編程器件的基礎(chǔ)上進一步發(fā)展的產(chǎn)物,。它是作為專用集成電路(ASIC)領(lǐng)域中的一種半定制電路而出現(xiàn)的,,既解決了定制電路的不足,又克服了原有可編程器件門電路數(shù)有限的缺點

  系統(tǒng)中的FPGA芯片選用Xilinx公司的VirtexII 3000,。利用VirtexII內(nèi)嵌的大容量BlockRAM配置為單口RAM來做緩沖區(qū),,在程序中可以用Xilinx的集成開發(fā)環(huán)境ISE 7.1i內(nèi)部自帶的IP核生成。系統(tǒng)設(shè)計師可以根據(jù)需要通過可編輯的連接把FPGA內(nèi)部的邏輯塊連接起來,,就好像一個電路試驗板被放在了一個芯片里。一個出廠后的成品FPGA的邏輯塊和連接可以按照設(shè)計者而改變,,所以FPGA可以完成所需要的邏輯功能,。

  FPGA一般來說比ASIC(專用集成芯片)的速度要慢,無法完成復雜的設(shè)計,,而且消耗更多的電能,。但是他們也有很多的優(yōu)點比如可以快速成品,可以被修改來改正程序中的錯誤和更便宜的造價,。廠商也可能會提供便宜的但是編輯能力差的FPGA,。因為這些芯片有比較差的可編輯能力,所以這些設(shè)計的開發(fā)是在普通的FPGA上完成的,,然后將設(shè)計轉(zhuǎn)移到一個類似于ASIC的芯片上,。另外一種方法是用CPLD(復雜可編程邏輯器件備)。

  FPGA設(shè)計的關(guān)鍵部分是和MPC8260的總線接口設(shè)計,。通過適當選擇緩沖區(qū)的起始地址和長度,,可以使MPC8260讀FPGA都以突發(fā)的方式進行。設(shè)計中,,MPC8260對FPGA的突發(fā)讀寫遵循自己配置的UPM模式,,所以要綜合考慮UPM模式設(shè)計和FPGA讀寫邏輯設(shè)計。在設(shè)計UPM模式時,可以在每次MPC8260鎖定數(shù)據(jù)總線數(shù)據(jù)之前由通用功能信號線(General Purpose Line,,GPL)產(chǎn)生一個下降沿通知FPGA往數(shù)據(jù)總線上寫新數(shù)據(jù),;或者通過GPL把總線時鐘送到FPGA達到收發(fā)同步來完成MPC8260與FPGA之間的讀寫。

  3 總結(jié)

  結(jié)合MPC8260的中斷處理和IDMA傳輸機制,,設(shè)計了一種MPC8260和FPGA之間的高速數(shù)據(jù)傳輸接口,。測試結(jié)果顯示:采用循環(huán)讀的方式把FPGA中的數(shù)據(jù)復制到SDRAM中,數(shù)據(jù)傳輸速率只有11 Mbps左右,;而采用本文介紹的IDMA方式,,最高速率能夠達到500 Mbps,并且內(nèi)核占用率較低,,實驗結(jié)果完全能夠滿足系統(tǒng)設(shè)計需求,。本研究對于PowerPC系列CPU的接口設(shè)計有一定的參考價值。

此內(nèi)容為AET網(wǎng)站原創(chuàng),,未經(jīng)授權(quán)禁止轉(zhuǎn)載,。