雙MicroBlaze軟核處理器的SOPC系統(tǒng)設計(一)
引 言:隨著時代的發(fā)展,單核片上可編程系統(tǒng)SOPC(SystemOn a Programmable Chip)解決復雜問題的能力與處理速度已很難滿足用戶的需求,面向多處理器SOPC系統(tǒng)的設計成為片上系統(tǒng)發(fā)展的必然趨勢。具有高密度、大容量邏輯的FPGA(Field Programmable Gate Array)的出現(xiàn)使得高性能片上多處理器的設計成為現(xiàn)實。目前,片上多核系統(tǒng)的設計已有一定發(fā)展,但在處理器間通信和中斷方面仍需進一步的研究。本文在處理器間通信和中斷控制方面進行了深入的研究。
MicroBlaze是一個被優(yōu)化過的可以在Xilinx公司FPGA中運行的軟核處理器,可以和其他外設IP核一起完成可編程系統(tǒng)芯片的設計。它具有運行速度快、占用資源少、可配置性強等優(yōu)點,廣泛應用于通信、高端消費市場等領域。MicroBlaze處理器采用RISC(Reduced InstructionSet Computer)指令集結(jié)構和哈佛存儲結(jié)構,指令、數(shù)據(jù)總線位寬均為32位。本文MicroBlaze處理器采用面積優(yōu)化,流水線分為3級,即取指、譯碼和執(zhí)行,減少了硬件開銷。
1 系統(tǒng)設計
1.1 雙MicroBlaze SOPC系統(tǒng)結(jié)構
雙MicroBlaze SOPC系統(tǒng)結(jié)構圖如圖1所示。從圖1中可知,整個SOPC系統(tǒng)可以分為兩個處理器子系統(tǒng)。系統(tǒng)采用兩個PLB(Processor Local Bus)v46總線作為系統(tǒng)的通信結(jié)構,所有的模塊都是直接或間接地連接到這兩個總線上。兩個總線上均掛有用于處理器間通信和同步的核,即Mailbox和Mutex,因此兩個處理器并不是完全獨立的。表1列出了SOPC系統(tǒng)包含的主要模塊。
表1中的BRAM 有兩種用途:一是作為單個處理器的私有存儲器用來存儲指令和數(shù)據(jù),它通過存儲器局部總線LMB與處理器相連;二是作為兩個處理器之間的共享存儲器(Shared Memory)用作通信模塊進行數(shù)據(jù)傳輸。
它所傳輸?shù)臄?shù)據(jù)量比Mailbox大很多,特別是在傳輸信息量大于千字節(jié)時,共享存儲器是最常用的通信模塊。
圖1 雙MicroBlaze SOPC系統(tǒng)結(jié)構圖
表1 SOPC系統(tǒng)的主要模塊
1.2 硬件設計
1.2.1 硬件結(jié)構
圖1所示的SOPC系統(tǒng)的整體結(jié)構不僅和處理器的數(shù)目有關,還和系統(tǒng)中模塊的配置及功能有關,外部存儲器和外圍設備的不同配置都會影響系統(tǒng)的結(jié)構和功能。
具體如下:
①SOPC系統(tǒng)通過各自獨立的PLBv46總線隔離兩處理器子系統(tǒng),可以確保兩個處理器系統(tǒng)在執(zhí)行各自的處理器事務時不會相互干擾。
② 共享模塊(例如MPMC),采用多端口結(jié)構,這些多端口模塊使多個處理器在訪問共享模塊時可以并行進行。
③ 兩個獨立的MicroBlaze處理器Mb_0和Mb_1,通過共享部件連接在一起,這些共享部件使得兩個Micro-Blaze處理器之間以各種方式通信。
④ 此SOPC系統(tǒng)中有兩個MicroBlaze處理器軟核,其中任何一個MicroBlaze都可以靈活地被其他類型的處理器所代替,比如PowerPC,因此處理器的選擇是非常靈活的。
⑤ 兩個處理器可以共享互斥訪問設備,比如串口UART、串行外設接口SPI(Serial Periphieral Interface)等,這種情況需要在沒有直接連接此外設的總線和直接連接此外設的總線之間提供一個系統(tǒng)總線橋。