色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

在XPS作平臺實現雙MieroBlaze處理器片上系統的設計

電子設計 ? 來源:郭婷 ? 作者:電子設計 ? 2019-07-11 08:12 ? 次閱讀

隨著時代的發展,單核片上可編程系統SOPC(Systern On a Programmable Chip)解決復雜問題的能力與處理速度已很難滿足用戶的需求,面向多處理器SOPC系統的設計成為片上系統發展的必然趨勢。具有高密度、大容量邏輯的FPGA(Field Programmable Gate Array)的出現使得高性能片上多處理器的設計成為現實。目前,片上多核系統的設計已有一定發展,但在處理器間通信和中斷方面仍需進一步的研究。本文在處理器間通信和中斷控制方面進行了深入的研究。

MicroBlaze是一個被優化過的可以在Xilinx公司FPGA中運行的軟核處理器,可以和其他外設IP核一起完成可編程系統芯片的設計。它具有運行速度快、占用資源少、可配置性強等優點,廣泛應用于通信、高端消費市場等領域。MicroBlaze處理器采用RISC(ReducedInstruction Set Computer)指令集結構和哈佛存儲結構,指令、數據總線位寬均為32位。本文MicroBlaze處理器采用面積優化,流水線分為3級,即取指、譯碼和執行,減少了硬件開銷。

1系統設計

1.1雙MicroBlaze SOPC系統結構

雙MicroBlaze SOPC系統結構圖如圖1所示。從圖1中可知,整個SOPC系統可以分為兩個處理器子系統。系統采用兩個PLB(Processor Local Bus)v46總線作為系統的通信結構,所有的模塊都是直接或間接地連接到這兩個總線上。兩個總線上均掛有用于處理器間通信和同步的核,即Mailbox和Mutex,因此兩個處理器并不是完全獨立的。表1列出了SOPC系統包含的主要模塊。

在XPS作平臺實現雙MieroBlaze處理器片上系統的設計

表1中的BRAM有兩種用途:一是作為單個處理器的私有存儲器用來存儲指令和數據,它通過存儲器局部總線LMB與處理器相連;二是作為兩個處理器之間的共享存儲器(Shared Memory)用作通信模塊進行數據傳輸。它所傳輸的數據量比Mailbox大很多,特別是在傳輸信息量大于千字節時,共享存儲器是最常用的通信模塊。

1.2硬件設計

1.2.1硬件結構

圖1所示的SOPC系統的整體結構不僅和處理器的數目有關,還和系統中模塊的配置及功能有關,外部存儲器和外圍設備的不同配置都會影響系統的結構和功能。具體如下:

①SOPC系統通過各自獨立的PLBv46總線隔離兩處理器子系統,可以確保兩個處理器系統在執行各自的處理器事務時不會相互干擾。

②共享模塊(例如MPMC),采用多端口結構,這些多端口模塊使多個處理器在訪問共享模塊時可以并行進行。

③兩個獨立的MicroBlaze處理器Mb_0和Mb_1,通過共享部件連接在一起,這些共享部件使得兩個MicroBlaze處理器之間以各種方式通信。

④此SOPC系統中有兩個MicroBlaze處理器軟核,其中任何一個MicroBlaze都可以靈活地被其他類型的處理器所代替,比如PowerPC,因此處理器的選擇是非常靈活的。

⑤兩個處理器可以共享互斥訪問設備,比如串口UART、串行外設接口SPI(Serial Periphieral Interface)等,這種情況需要在沒有直接連接此外設的總線和直接連接此外設的總線之間提供一個系統總線橋。

⑥關鍵的外圍設備是外部存儲控制器MPMC,它最多提供8個端口,可以通過XCL(Xilinx Cache Link)連接處理器局部存儲器(BRAM),通過PLBv46總線連接到系統中,因此,可以將1~4個處理器同時連接到MPMC控制器上。

⑦兩個處理器之間的Mailbox和Mutex有簡單通信的功能,主要體現在處理器之間的通信和同步上。

1.2.2存儲器映像

當程序沒有被加載或者運行的時候,它以文件的形式存放在硬盤上。當它被下載到MPMC內存中的時候,系統會自動從MPMC內存中劃分出一段區域,用來將這個磁盤上的文件映射到內存相應的位置上。此時這塊內存中的數據就是磁盤文件的一個拷貝。存儲器映像就是指和被加載的磁盤文件相對應的一塊內存區域。由于MPMC存儲器和外圍設備是統一編址的,兩者的地址范圍不可能重疊,因此直接或者間接連接到處理器上的外圍設備地址的分配決定了外部存儲器的地址空間。

一般而言,當多個處理器共用一條總線時,存儲器、外圍設備和共享元素是密不可分的,在本文設計的處理器系統中,每一個處理器都有自己獨立的系統總線,因此,所有的存儲器和外圍設備與共享元素都是分開的。也就是說,不同總線上的相同外圍設備可以有相同的地址范圍。在每一個處理器子系統中,為了能夠運行可執行文件,對存儲器映像有一些要求。每個處理器都必須將自己的可執行文件加載到各自私有的MPMC地址空間中,可執行文件加載地址不能重疊。在私有存儲器里必須有各自的復位和中斷存儲器映像,這種私有存儲器可以通過本地存儲器接口(XCL)或者PLBv46總線接口連接起來。一旦私有存儲器與其他總線連接完畢,XPS的地址發生器會為每一個MieroBlaze處理器子系統(包括外圍設備和存儲器)生成適當地址范圍的存儲器映像。

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

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

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

①Mailbox可以認為是處理器之間的類似于TCP/IP的一個簡單的通信協議。

②處理器之間通過Mailbox通信有同步和異步之分:同步主要體現在處理器之間的通信上,接收者實時地讀取Mailbox中的數據;異步主要體現在處理器之間的中斷上,發送者通過Mailbox發送中斷信息給接收者,接收者收到中斷后反饋給發送者。

③每一個Mailbox核都有一個FIFO和一個雙端隊列,分別用來發送和接收信息,用戶可以根據自己的需要對它們的深度進行配置,主要通過分布式的RlAM或者BRAM來實現。

④Mailbox共有兩個端口分別連接到系統的兩個總線上來實現處理器之間的通信。

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

⑥處理器間的中斷是指一個處理器去中斷另一個處理器的行為,通過Mailbox的異步通信來實現,處理器發送中斷就是往Mailbox里寫入一個信息,然后Mailbox通過中斷控制器對接收者產生一個中斷,接收者收到中斷以后會反饋給發送者,當Mailbox中沒有新的信息時,中斷為無效狀態。

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

①存儲器映像以后,Mutex寄存器的數量可配置這些寄存器中有分別存儲數據和處理器ID的區域,Mutex寄存器中的數據和ID分別通過Mutex進行測試和設置。

②復位時,Mutex的值變為0,它表示Mutex處于開鎖狀態(UNLOCK),并且其中的處理器ID號沒有賦值,當Mutex處于鎖定狀態(LOCK)時,其中的值保持不變。

③處理器通過軟件賦值的方式將各自的處理器ID號寫入到相應的Mutex寄存器中,從而獲得Mutex的使用權,當兩個處理器同步訪問Mutex寄存器時,每個處理器都會讀取Mutex寄存器中的值,然后和自己的ID號進行比較,比較匹配的處理器才可訪問Mutex寄存器,修改其中的數據。

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

②MDM提供一個JTAG UART接口通向系統中的某個處理器,這個UART接口是通過PLBv46總線接口連接到處理器上的。

③MDM不會自動地調試每個處理器,用戶必須通過輸入調試命令來進行選擇性的調試。

1.3軟件設計

1.3.1存儲器映像

為了保證每個處理器在執行軟件部分時不發生沖突,必須對其存儲器進行存儲器映像。圖2是存儲器映像圖。

在XPS作平臺實現雙MieroBlaze處理器片上系統的設計

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

1.3.2通信與同步

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

2實驗結果

本設計采用調試模塊分別對兩個處理器進行調試,通過超級終端輸出測試結果。

2.1 Mailbox的測試結果

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

2.2 Mutex的測試結果

通過Mutex可以實現兩處理器的同步。當兩個MicroBlaze處理器訪問共享資源時,可以用Mutex核修改臨界區域里共享資源的值。臨界區域里的值是隨著處理器的訪問而更新的。在沒有輸出時處理器會鎖定Mutex核,有輸出時解鎖Mutex核。同步使得控制臺的輸出結果正確可用,不會出現混亂的狀態。

2.3 Shared Memory的測試結果

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

結語

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


聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 處理器
    +關注

    關注

    68

    文章

    19317

    瀏覽量

    230101
  • 芯片
    +關注

    關注

    456

    文章

    50892

    瀏覽量

    424347
  • 存儲器
    +關注

    關注

    38

    文章

    7502

    瀏覽量

    163939
收藏 人收藏

    評論

    相關推薦

    SoPC實現的波形發生

    ,最大限度地實現系統的集成化。關鍵詞:SoPC IPCore EDK MicroBlaze DDS 波形發生引 言  SoPC可編程
    發表于 06-25 08:12

    怎么設計集軟核處理器的嵌入式設計平臺

    編程接口共用或并存,可能包含部分可編程模擬電路,單芯片、低功耗。本文主要研究的是應用嵌入式系統開發的軟硬件協同設計方法來實現一個集軟核處理器的嵌入式設計平臺,在此基礎
    發表于 03-13 07:03

    SHARC處理器的評估系統

    用于SHARC處理器的ADZS-21489-EZLITE,ADSP-2148x EZ-KIT Lite評估系統。 SHARC處理器基于32位超級哈佛架構,包括一個獨特的內存架構,由兩個大型
    發表于 03-16 10:19

    求一款MicroBlaze軟核處理器的SOPC系統設計

    隨著時代的發展,單核可編程系統SOPC(Systern On a Programmable Chip)解決復雜問題的能力與處理速度已很難滿足用戶的需求,面向多
    發表于 03-16 07:44

    請問如何實現嵌入式Nios Ⅱ軟核六處理器系統的設計?

    Nios Ⅱ嵌入式軟核多處理器系統具有哪些優勢?如何實現
    發表于 04-19 08:17

    Linux/ARM嵌入式平臺屬于系統

    Linux/ARM 嵌入式平臺是《ARM 嵌入式系統編程與優化》的第一章。好好學學硬件,然后深入一下 Linux,修煉好自己的內功。ARM 處理器不是獨立芯片產品,而是具有多樣性和異質性嵌入式
    發表于 12-14 09:25

    基于處理器TMS320DM6446的圖像壓縮系統

    高速核信號處理器 TMS320DM6446 芯片實現了JPEG2000 標準的嵌入式圖
    發表于 11-27 15:46 ?21次下載

    什么是處理器

    什么是處理器 什么是處理器呢?處理器背后的概念蘊涵著什么意義呢?簡而言之,
    發表于 10-12 09:47 ?1.7w次閱讀

    什么是處理器

      簡單來說,處理器就是一個硅片上集成兩個CPU。那么什么是處理器呢?
    發表于 10-08 18:21 ?987次閱讀

    嵌入式處理器調試功能的設計

    以 龍芯1號 處理器為研究對象,探討了嵌入式處理器調試功能的設計實現方法。大大方便了軟件開發與系統
    發表于 06-29 17:45 ?48次下載
    嵌入式<b class='flag-5'>處理器</b><b class='flag-5'>在</b><b class='flag-5'>片</b>調試功能的設計

    多核處理器存儲系統研究

    針對 多核處理器 計算能力和訪存速度間差異不斷增大對多核系統性能提升的制約問題,分析幾款典型多核處理器存儲系統的設計特點,探討多核處理器
    發表于 07-27 15:49 ?29次下載
    多核<b class='flag-5'>處理器</b><b class='flag-5'>片</b><b class='flag-5'>上</b>存儲<b class='flag-5'>系統</b>研究

    8位處理器實現高效文件系統

    8位處理器實現fat fat12 fat16 fat32的高效文件系統
    發表于 12-30 15:37 ?0次下載

    多核系統上網絡的發展

    第一款被大眾所熟知的商用化多核系統是著名處理器芯片提供商之一的AMD公司面向個人電腦推出的ATHLON X2核中央
    的頭像 發表于 10-01 16:43 ?3374次閱讀
    <b class='flag-5'>片</b><b class='flag-5'>上</b>多核<b class='flag-5'>系統</b>與<b class='flag-5'>片</b>上網絡的發展

    EE-346:模擬器件處理器使用熱二極管

    EE-346:模擬器件處理器使用熱二極管
    發表于 04-17 15:38 ?6次下載
    EE-346:<b class='flag-5'>在</b>模擬器件<b class='flag-5'>處理器</b><b class='flag-5'>上</b>使用<b class='flag-5'>片</b><b class='flag-5'>上</b>熱二極管

    基于LEON開源微處理器IP軟核實現SoC系統基本平臺的構建

    SoC芯片的核心是實現運算和控制功能的微處理器。LEON是一款基于SPARC V8架構的開源微處理器IP軟核,VHDL源代碼基礎,結合具
    的頭像 發表于 06-17 14:32 ?2848次閱讀
    基于LEON開源微<b class='flag-5'>處理器</b>IP軟核<b class='flag-5'>實現</b>SoC<b class='flag-5'>系統</b>基本<b class='flag-5'>平臺</b>的構建
    主站蜘蛛池模板: 青青草原网址| 琪琪SEE色原网色原网站18| 免费国产黄线在线播放| 午夜福利院电影| 芳草地在线观看免费观看| 蜜臀色欲AV无人A片一区| 伊人久久影院大香线蕉| 国产精品亚洲AV色欲在线观看| 日本工口生肉全彩大全| 97资源总站(中文字幕)| 么公在浴室了我的奶| 最近中文字幕2019免费版| 久久精品亚洲AV中文2区金莲| 亚洲精品一二三| 国产一区二区三区国产精品| 亚洲国产夜色在线观看| 韩国甜性涩爱| 夜夜穞狠狠穞| 么么哒日本影院| 99无人区码一码二码三| 秋霞伦理电影在线看| 成人亚洲视频在线观看| 偷拍亚洲制服另类无码专区| 国产三级在线免费| 亚洲中文字幕日产乱码2020| 久久久无码AV精品亚洲A片软件| 正在播放国产精品| 女教师杨雪的性荡生活| 大屁股国产白浆一二区| 乌克兰女人与动ZOZO| 狠狠色色综合站| 13一18TV处流血TV| 日操夜操天天操| 国产一区在线观看免费| 永久免费在线看mv| 欧美高清xxx| 国产精品99久久久久久AV | 久久视频这里只精品99re8久| 99国产精品白浆在线观看免费| 日本久久精品毛片一区随边看| 国产老师开裆丝袜喷水漫画|