NiosII多核處理器之間通信技術(shù)的研究
引言
本文引用地址:http://butianyuan.cn/article/81623.htm隨著應(yīng)用領(lǐng)域的擴大,人們對微處理器系統(tǒng)的性能、功耗和成本提出了越來越嚴(yán)格的要求。單純依靠提升時鐘的方法已經(jīng)不能滿足需要,在移動通信、軍事應(yīng)用、消費電子、智能控制設(shè)備等領(lǐng)域,多核處理器的解決方案成為一種主流趨勢。
Altera公司在其FPGA中實現(xiàn)的NiosII處理器是一個用戶可配置的通用32位RISC軟核微處理器,Nios II 5.0及其以上版本支持多處理器系統(tǒng)的創(chuàng)建和調(diào)試。Nios II多處理器,除了軟核本身超過200DMIPS的高性能之外,Altera開發(fā)用于Nios/NiosII處理器的Avalon參數(shù)化接口總線具有友好的多主從仲裁能力,可以有效地實現(xiàn)系統(tǒng)資源共享。在清華-Altera聯(lián)合實驗室的支持下,筆者對NiosII多核處理器之間共享通信的幾種可行方案進行研究,并且在自行設(shè)計的NiosII開發(fā)板上完成設(shè)計測試驗證,分析比較各種方案的技術(shù)特點、優(yōu)勢與不足,提供給不同系統(tǒng)的應(yīng)用者參考。
NiosII多核間幾種可行的通信方案
雙口RAM和PIO核的多核中斷通信方案
雙處理器可采用一個雙口RAM和中斷信號通過定義某種信息數(shù)據(jù)結(jié)構(gòu)來進行通信。在NiosII雙處理器系統(tǒng),可以采用FPGA中實現(xiàn)的片上雙口RAM和通用IO組件PIO核來實現(xiàn)多核中斷通信。通信的中斷信號使用PIO組件產(chǎn)生和接收,雙核通信的連接如圖1所示。由于Avalon總線具有多主從仲裁能力,同一外設(shè)可以同時掛載在不同軟核上,有訪問競爭時由總線自己仲裁決定哪個主方取得從設(shè)備訪問權(quán),雙口RAM和單口RAM均可以通過Avalon總線掛載在多個NiosII軟核上,二者的區(qū)別在于:雙口RAM設(shè)備有兩套從端口被Avalon總線當(dāng)作兩個設(shè)備,雙核可以同時對其進行讀操作;單口RAM只有一套從端口被Avalon總線當(dāng)作一個設(shè)備,多核對其的讀寫操作是分時進行的。
這里設(shè)計雙核通過雙口RAM和PIO中斷進行通信的例程。設(shè)計信息交換的數(shù)據(jù)結(jié)構(gòu)share_msg_buf如表1所示。安裝中斷程序及終端服務(wù)例程如圖2所示。
通信的關(guān)鍵在于消息標(biāo)志flag狀態(tài)的定義:NO_DATA-內(nèi)存空閑、DATA_IN-有新消息寫入、DATA_OUT-新消息已送出,單個軟核處理器在存儲器空閑(NO_DATA狀態(tài))或者有消息進入(DATA_IN狀態(tài))將新消息讀走之后才能在存儲區(qū)寫入新的消息數(shù)據(jù);在自己發(fā)的消息還未被對方接收(DATA_OUT狀態(tài))時,不做處理,返回繼續(xù)等待對方接收消息。標(biāo)志狀態(tài)的定義從軟件上實現(xiàn)了雙核對雙口RAM的互斥訪問,有效防止雙核對共享數(shù)據(jù)的破壞。這種通信方案經(jīng)過筆者的NiosII雙核系統(tǒng)驗證測試,消息接收正確。
互斥硬核和共享存儲的多核查詢通信方案
Altera在SOPC Builder工具箱中提供具有Avalon接口的互斥硬核Mutex組件來協(xié)調(diào)共享資源的訪問。Mutex核提供一個基于硬件的原子測試和置位(test-and-set)操作,允許多處理器環(huán)境下決定軟核對Mutex核的使用權(quán),使用Mutex核就可實現(xiàn)多核對相應(yīng)共享資源(如存儲器)的互斥訪問。這樣多核的通信就可以舍棄雙口RAM,使用片上RAM或者片外存儲器作為共享存儲器,采用查詢方式實現(xiàn)。雙核通信的設(shè)備連接如圖3所示,與雙口RAM不同,這里的片上RAM僅作為一個設(shè)備掛載到Avalon總線上。
Altera提供NiosII HAL環(huán)境下對Mutex核訪問的函數(shù):打開、加鎖、解鎖、判斷Mutex屬主等。使用Mutex核控制片上RAM,單個軟核每次對片上RAM操作之前都要首先取得Mutex核所有權(quán),操作完之后應(yīng)立即放棄對Mutex核的所有權(quán),避免單個軟核對Mutex核及共享資源的獨占。采用前面表所定義的數(shù)據(jù)結(jié)構(gòu)作為通信的消息,在查詢方式下,單個軟核需要有任務(wù)通過循環(huán)不斷檢查共享數(shù)據(jù)區(qū)標(biāo)志位flag,等待其它軟核送來消息,以便激活自身系統(tǒng)掛起的任務(wù),執(zhí)行下一步工作。整個流程如圖4所示。
在循環(huán)中使用等待延時,避免了多核對Mutex核資源的不停爭用,同時留給處理器一定的消息處理時間,但缺點是延長了通信呼叫和應(yīng)答的時間,在實時設(shè)計中應(yīng)考慮到延時時長對多核通信的影響。此方案在筆者的NiosII雙核系統(tǒng)工程中通過驗證。
郵箱內(nèi)核和共享存儲的多核阻塞通信方案
Altera還提供帶Avalon接口的郵箱內(nèi)核mailbox組件在多核處理器之間發(fā)送消息。郵箱內(nèi)核含有兩個互斥體:一個保證對共享存儲器的唯一寫訪問;另一個保證對共享存儲器的唯一讀訪問,它與獨立共享存儲器一起使用實現(xiàn)多核處理器間的消息隊列通信。郵箱內(nèi)核適于雙核間單方向的消息通信,功能相當(dāng)于FIFO緩沖隊列,其傳送的消息往往是指向共享內(nèi)存塊結(jié)構(gòu)體的指針,代替實際的數(shù)據(jù)傳輸,提高數(shù)據(jù)交換效率。該系統(tǒng)連接如圖5所示。
在NiosII HAL環(huán)境下對郵箱內(nèi)核訪問的函數(shù)有:打開、關(guān)閉、獲取消息、等待消息、發(fā)送消息。在構(gòu)建郵箱內(nèi)核組件時,選擇可用的共享存儲器作為消息隊列內(nèi)存,指定消息隊列長度size(不超過存儲器容量)及其在存儲器中的偏移量Offset。這里選擇片上RAM作為共享存儲器,將其分為兩部分:一部分作為消息隊列內(nèi)存;一部分作為消息指針指向的內(nèi)存數(shù)據(jù)結(jié)構(gòu)塊。定義內(nèi)存數(shù)據(jù)結(jié)構(gòu)如表2所示,頭信息info可以作為數(shù)據(jù)幀的序號,保證數(shù)據(jù)的按序接收。使用郵箱內(nèi)核消息隊列完成雙核間大量數(shù)據(jù)傳輸?shù)牧鞒倘鐖D6時進行等待;數(shù)據(jù)接受方處理器處于等待消息的狀態(tài),一有消息就接收進來。可以在實時操作系統(tǒng)中單獨建立發(fā)送數(shù)據(jù)和接收數(shù)據(jù)的任務(wù),由于沒有中斷和查詢過程,此方案可以達到單方向很高的數(shù)據(jù)傳輸率,在筆者的NiosII系統(tǒng)工程中得到了驗證測試。
通用串行接口總線的多核通信方案
在NiosII多核處理器中可以使用通用串行接口總線如UART、SPI、I2C等進行相互間的通信。這些總線有的是NiosII的通用組件在SOPC Builder中直接添加使用,有的可成熟的第三方組件在SOPC Builder中使用。目前NiosII中可用的幾種串行總線如表3所示。
幾種總線各有優(yōu)缺點和使用限制,例如UART總線比較通用、工作在異步方式,使用方便,但針對一對一的通信,數(shù)據(jù)率稍低;SPI總線工作在同步方式,一個主設(shè)備可以掛多個從設(shè)備,數(shù)據(jù)率較高,但控制比UART復(fù)雜、數(shù)據(jù)線較多。應(yīng)根據(jù)具體應(yīng)用選擇合適總線。這里以UART總線說明和驗證通用串行接口總線完成多核間通信的方案。UART核是Altera提供的NiosII通用組件,實現(xiàn)了一個簡單的寄存器映像的Avalon從接口,可以很容易集成到NiosII處理器中,允許主外設(shè)(如NiosII軟核)通過讀寫寄存器與其進行通信。UART核至少創(chuàng)建Rxd輸入和Txd輸出兩個IO端口,可根據(jù)需要創(chuàng)建CTS輸入和RTS輸出兩個流控信號。這里為每個NiosII軟核創(chuàng)建一個無流控波特率為1.152Mbps的UART組件,其發(fā)送端口Txd與另外一方的接收Rxd連接。NiosII HAL提供UART系統(tǒng)庫驅(qū)動程序,可使用ANSC C標(biāo)準(zhǔn)函數(shù)或者UNIX風(fēng)格IO函數(shù)訪問UART,雙核通信流程如圖7所示。
雙核中的數(shù)據(jù)發(fā)送方查詢監(jiān)測輸入字符,出現(xiàn)關(guān)鍵字時發(fā)送數(shù)據(jù),并以結(jié)束符結(jié)束發(fā)送;數(shù)據(jù)接收方等待用戶輸入字符命令,如果是關(guān)鍵字則開始接收數(shù)據(jù),在收到結(jié)束符時結(jié)束接收,處理數(shù)據(jù)。這個方案實現(xiàn)的是數(shù)據(jù)接收方請求發(fā)送,在筆者NiosII系統(tǒng)工程中以1.152Mbps傳輸大數(shù)據(jù)量,驗證測試沒有問題。也可以根據(jù)實際需要使用其它方案。
PIO核自定義協(xié)議的多核通信方案
Altera為NiosII提供并行輸入/輸出PIO核,在Avalon從端口和通用I/O端口之間建立存儲器映像接口,PIO組件可配置為輸入、輸出、輸入輸出、雙向三態(tài)四種類型,其中后三種類型可提供信號邊沿捕獲(Edge Capture)和中斷請求。利用PIO并口可將雙核連接起來,定義自己的接口形式和通信訪問協(xié)議進行通信。雙核間的互連使用的是FPGA片上邏輯,不占用FPGA的IO引腳,寬度最高32位,同等數(shù)據(jù)率下效率大大高于串行總線,可使用中斷、查詢或者二者相結(jié)合方式進行通信。這里定義一種PIO通信接口和時序如圖8所示。
在中斷信號PIO_irq的上升沿提出中斷申請,啟動一次通信,數(shù)據(jù)傳輸方將讀寫標(biāo)志信號PIO_R/W置高,同時向數(shù)據(jù)線PIO_D寫入數(shù)據(jù);數(shù)據(jù)接收方在相應(yīng)中斷信號后,檢測到PIO_R/W信號變高,則讀數(shù)據(jù)線PIO_D獲取數(shù)據(jù),同時將PIO_R/W置低表明數(shù)據(jù)已讀,可以進行下次數(shù)據(jù)傳送。數(shù)據(jù)傳輸方通過將PIO_irq信號置低表明完成一次通信,數(shù)據(jù)接收方檢測到PIO_irq信號為低時停止本次通信。這種中斷和查詢相結(jié)合的方案效率很高,任意一方都可以發(fā)起通信,通信的速率取決于NiosII軟核對端口讀寫延時和數(shù)據(jù)的處理速度或者寫數(shù)據(jù)緩沖區(qū)的速度。軟件通信流程如圖9所示。
結(jié)語
表4對上述各種方案進行了一下比較,分析了每種方案的特點和適用范圍。
筆者的PDA考評系統(tǒng)項目采用了NiosII雙核設(shè)計,使用方案三(郵箱內(nèi)核和共享存儲的多核阻塞通信方案)完成雙核間的通信。PDA設(shè)備作為實驗考評系統(tǒng)的客戶端,通過藍牙無線通信與建有學(xué)生課程成績數(shù)據(jù)庫的服務(wù)器進行通信,實現(xiàn)實驗現(xiàn)場學(xué)生成績的查詢、修改、數(shù)據(jù)文件的傳輸?shù)裙δ?,系統(tǒng)的功能結(jié)構(gòu)如圖10所示。NiosII雙核分為兩個系統(tǒng):(1)NiosII人機界面系統(tǒng)。負(fù)責(zé)管理矩陣鍵盤按鍵和LCD顯示界面的驅(qū)動;(2)NiosII通信主機系統(tǒng)。實現(xiàn)完整的藍牙協(xié)議棧,完成與數(shù)據(jù)庫服務(wù)器進行通信的任務(wù)。雙核之間鍵盤操作指令和LCD顯示數(shù)據(jù)的交換通過上文所述的方案三——郵箱內(nèi)核和共享存儲的方式實現(xiàn)。
NiosII多核處理器在FPGA中易于實現(xiàn),并且多核之間通信可選方案較多,適應(yīng)范圍廣,相信會在越來越多的系統(tǒng)中采用。
參考文獻:
1. Altera Corp. QuartusII Version6.1 Handbook. Altera. 2006
2. Altera Corp. Creating Multiprocessor NiosII System Tutorial. Altera. 2005
3. Altera Corp. NiosII Processor Reference Handbook. Altera. 2005
4. Altera Corp. NiosII Software Developer’s Handbook. Altera. 2005
5. Altera Corp. Avalon Interface Specification. Altera. 2005
數(shù)字通信相關(guān)文章:數(shù)字通信原理
通信相關(guān)文章:通信原理
存儲器相關(guān)文章:存儲器原理
加速度計相關(guān)文章:加速度計原理
評論