<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>

新聞中心

EEPW首頁(yè) > 嵌入式系統 > 設計應用 > 基于MicroBlaze的SOPC系統設計

基于MicroBlaze的SOPC系統設計

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

  1.2.3處理器之間的通信與同步

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

  在Xilinx 系統設計中,常用的處理器之間的通信模塊是Shared Memory和Mailbox,同步控制模塊是Mutex,調試模塊是MDM. Shared Memory共有兩個(gè)通信端口,它通過(guò)存儲器控制端口分別連接到系統的兩條PLBy46總線(xiàn)上。系統通過(guò)處理器對Slhared Memory模塊進(jìn)行讀寫(xiě)操作完成通信。Shared Memory可以由片上本地存儲器或者外部存儲器構成。當信息傳輸量比較大時(shí),Shared Memory的異步傳輸效率比較高,它支持零拷貝或者原狀信息隊列拷貝。

  利用Mailbox也可以進(jìn)行處理器之間的通信。關(guān)于Mailbox,有如下一些特征描述:

 ?、費ailbox可以認為是處理器之間的類(lèi)似于TCP/IP的一個(gè)簡(jiǎn)單的通信協(xié)議。

 ?、谔幚砥髦g通過(guò)Mailbox通信有同步和異步之分:同步主要體現在處理器之間的通信上,接收者實(shí)時(shí)地讀取Mailbox中的數據;異步主要體現在處理器之間的中斷上,發(fā)送者通過(guò)Mailbox發(fā)送中斷信息給接收者,接收者收到中斷后反饋給發(fā)送者。

 ?、勖恳粋€(gè)Mailbox核都有一個(gè)FIFO和一個(gè)雙端隊列,分別用來(lái)發(fā)送和接收信息,用戶(hù)可以根據自己的需要對它們的深度進(jìn)行配置,主要通過(guò)分布式的RlAM或者BRAM來(lái)實(shí)現。

 ?、躆ailbox共有兩個(gè)端口分別連接到系統的兩個(gè)總線(xiàn)上來(lái)實(shí)現處理器之間的通信。

 ?、軲ailbox軟核比較適合傳輸信息量小于100字節的信息,發(fā)送者需要從本地或者外部存儲器拷貝整個(gè)信息到FIFO,然后,接收者同步地拷貝整個(gè)信息到自己的存儲器中,因此,Mailbox不適合傳輸信息量較大的信息,這些將會(huì )耗費掉處理器的一些時(shí)鐘周期。

 ?、尢幚砥鏖g的中斷是指一個(gè)處理器去中斷另一個(gè)處理器的行為,通過(guò)Mailbox的異步通信來(lái)實(shí)現,處理器發(fā)送中斷就是往Mailbox里寫(xiě)入一個(gè)信息,然后Mailbox通過(guò)中斷控制器對接收者產(chǎn)生一個(gè)中斷,接收者收到中斷以后會(huì )反饋給發(fā)送者,當Mailbox中沒(méi)有新的信息時(shí),中斷為無(wú)效狀態(tài)。

  本文在系統設計中,用到的同步控制模塊是Mutex.此模塊主要有以下特點(diǎn):

 ?、俅鎯ζ饔诚褚院?,Mutex寄存器的數量可配置這些寄存器中有分別存儲數據和處理器ID的區域,Mutex寄存器中的數據和ID分別通過(guò)Mutex進(jìn)行測試和設置。

 ?、趶臀粫r(shí),Mutex的值變?yōu)?,它表示Mutex處于開(kāi)鎖狀態(tài)(UNLOCK),并且其中的處理器ID號沒(méi)有賦值,當Mutex處于鎖定狀態(tài)(LOCK)時(shí),其中的值保持不變。

 ?、厶幚砥魍ㄟ^(guò)軟件賦值的方式將各自的處理器ID號寫(xiě)入到相應的Mutex寄存器中,從而獲得Mutex的使用權,當兩個(gè)處理器同步訪(fǎng)問(wèn)Mutex寄存器時(shí),每個(gè)處理器都會(huì )讀取Mutex寄存器中的值,然后和自己的ID號進(jìn)行比較,比較匹配的處理器才可訪(fǎng)問(wèn)Mutex寄存器,修改其中的數據。

  核通過(guò)處理器調試口與MDM(Microprocessor Debug Module)調試模塊相連。調試模塊MDM可以調試系統中的每一個(gè)處理器。MDM的特點(diǎn)如下:①MDM的調試端口數目是可配置的,最多可以達到8個(gè)。

 ?、贛DM提供一個(gè)JTAG UART接口通向系統中的某個(gè)處理器,這個(gè)UART接口是通過(guò)PLBv46總線(xiàn)接口連接到處理器上的。

 ?、跰DM不會(huì )自動(dòng)地調試每個(gè)處理器,用戶(hù)必須通過(guò)輸入調試命令來(lái)進(jìn)行選擇性的調試。

  1.3軟件設計

  1.3.1存儲器映像

  為了保證每個(gè)處理器在執行軟件部分時(shí)不發(fā)生沖突,必須對其存儲器進(jìn)行存儲器映像。圖2是存儲器映像圖。

  

 

  從圖2中可以看出,用戶(hù)可以靈活地為兩個(gè)ELF文件分配適當大小的存儲器空間作為ELF文件的映射地址范圍。由于boot(引導)存儲器不可以共享,所以ELF文件的boot部分(。vectors*)被映射到私有存儲器中,它可以實(shí)現處理器隨時(shí)調用,也可以引導ELF文件加載到DDR中。Heap和stack的范圍表示ELF文件在DDR中映像的存儲器大小。boot存儲器的大小表示boot部分所能引導的DDR的范圍。ELF文件的位置和輸出鏈接腳本的位置可以根據用戶(hù)的需求選擇。每個(gè)可執行文件的存儲器映像地址都是通過(guò)編譯器來(lái)實(shí)現的,實(shí)現以后被傳到鏈接器,生成鏈接腳本。

  1.3.2通信與同步

  利用Shared Memory模塊通信是處理器之間最常用的通信方式。其通信接口函數如下:SHM_WRITEAREA();/*向Shared Memory中寫(xiě)數據*/ SHM_READAREA();/*從Shared Memory中讀數據*/利用Mailbox模塊可以實(shí)現處理器之間的信息傳遞和中斷。這在軟件設計中主要體現在以下代碼行中:XMbox_WriteBloeking();/*向Mailbox中寫(xiě)數據*/ XMbox_ReadBlocking();/*從Mailbox中讀數據*/在軟件應用設計中,兩個(gè)處理器之間的同步是通過(guò)Mutex Locks實(shí)現的,它的狀態(tài)有LOCK和UNLOCK之分。Mutex狀態(tài)的操作主要體現在以下命令行中:MLOCK();/*使用之前LOCK*/ MUNLOCK();/*使用之后UNLOCK*/軟件的調試(debug)需要手工地選擇處理器,兩個(gè)處理器不可以同時(shí)調試。在XMD Console中的調試命令主要有:debugconfig-reset_on_run disable/*下載時(shí)避免復位*/ dow executable.elf/*下載ELF文件*/run/*運行*/

  2實(shí)驗結果

  本設計采用調試模塊分別對兩個(gè)處理器進(jìn)行調試,通過(guò)超級終端輸出測試結果。

  2.1 Mailbox的測試結果

  通過(guò)Mailbox可以實(shí)現處理器之間的中斷和通信。兩處理器首先通過(guò)交換字符串“helo BOY”的形式匯合(rendezvous),以此來(lái)證明兩個(gè)處理器的連接情況。在這里,每次發(fā)送的數據包為2 044字節,共發(fā)送了3個(gè)數據包,都能成功地發(fā)送。經(jīng)驗證,每次發(fā)送的信息量最大為4 096字節,可以重復發(fā)送。

  2.2 Mutex的測試結果

  通過(guò)Mutex可以實(shí)現兩處理器的同步。當兩個(gè)處理器訪(fǎng)問(wèn)共享資源時(shí),可以用Mutex核修改臨界區域里共享資源的值。臨界區域里的值是隨著(zhù)處理器的訪(fǎng)問(wèn)而更新的。在沒(méi)有輸出時(shí)處理器會(huì )鎖定Mutex核,有輸出時(shí)解鎖Mutex核。同步使得控制臺的輸出結果正確可用,不會(huì )出現混亂的狀態(tài)。

  2.3 Shared Memory的測試結果

  通過(guò)Shared Memory實(shí)現處理器之間的通信。處理器O首先向共享存儲器中寫(xiě)入一個(gè)32位的數據并設置一個(gè)共享flag表明數據可用,等待處理器1讀取這個(gè)數據。然后,處理器1從共享存儲器中讀取處理器0寫(xiě)入的數據并設置一個(gè)共享flag表明它已經(jīng)讀取了這個(gè)數據。雙處理器會(huì )重復這樣的過(guò)程,直到達到所設置的最大數目12.

  結語(yǔ)

  本文以MieroBlaze軟核為基礎,利用XPS作平臺來(lái)設計雙MieroBlaze處理器片上系統,此片上系統可以很好地實(shí)現兩軟核處理器間的通信和中斷功能,該系統在Xilinx公司的XUPV5-LX110T開(kāi)發(fā)板上得到實(shí)現,在超級終端中得到驗證。本設計的優(yōu)點(diǎn)是把處理器核之間的通信、中斷、同步放在了同一系統中進(jìn)行研究,深入研究了處理器之間的中斷控制。下一步要做的工作是更多核的片上系統設計和操作系統移植。


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

關(guān)鍵詞: MicroBlaze SOPC

評論


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