《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 設計應用 > 具有X86到ARM二進制翻譯的SoC系統設計
具有X86到ARM二進制翻譯的SoC系統設計
摘要: 這里給出了一種具有X86到ARM二進制翻譯和執行功能的SoC系統。利用Multi-layer bus SWitch(BusMatrix)模塊實現Multi-layer。總線結構,在多個核不訪問同一個Slave時,可以同時執行各自功能,有效提高系統的性能,且該總線結構的可擴展性強。同時根據系統工作的特點,對總線結構進行了優化,減小了總線的復雜度。
關鍵詞: SOC X86 ARM 二進制翻譯
Abstract:
Key words :

二進制翻譯也是一種編譯技術,它與傳統編譯器的差別在于其編譯處理對象不同。傳統編譯器處理的是某一種高級語言,經過編譯處理生成某種機器的目標代碼。

二進制翻譯是一種直接翻譯可執行二進制程序的技術,能夠把一種處理器上的二進制程序翻譯到另外一種處理器上執行。它使得不同處理器之間的二進制程序可以很容易的相互移植,擴大了硬件/軟件的適用范圍,有助于打破處理器和支持軟件之間的相互扼制的局面。二進制翻譯技術的優點為:不需要重編譯源碼就可以實現軟件從舊平臺到新平臺的移植;快速為新機器提供軟件,包括移植操作系統和編譯器;充分利用新機器的特性優化代碼;減少培訓費用,因為使用的是相同的軟件,所以不必在新平臺上重新培訓員工;降低了多平臺軟件的費用。

1 SOC架構設計

1.1 處理器的確定

通用處理器與硬件邏輯是SoC設計的主流架構。在一些需要大量數據處理的應用中,這樣的架構并不能滿足要求。實際上,由于不同的任務在很大程度上互相獨立運行,可以將具有內在執行并行性的任務分解為緊密聯系的子任務,不同的內核可以執行不同的子任務,多核架構在1個周期內可以執行多個指令。這種并行處理使得整個系統的性能與使用單核處理器串行處理相同任務相比,有了很大改進。另外,多核架構設計可以復用現有的單核處理器作為處理器核心,從而可以縮短設計和驗證周期,節省開發成本,符合SoC設計的基本思路。多核架構是未來SoC發展的一個趨勢。

該設計采用雙核架構,采用當代流行的處理能力較好的ARM處理器ARM7TDMI-S和ARM926EJ-S,ARM內核最大的優勢在于高速度、低功耗。

ARM7TDMl-s具有3級流水線結構,支持Win-dows CE,Linux等操作系統。ARM926EJ-S是ARM公司在2000年推出的功能最強大的ARM9處理器,實現5級流水,它與外部通信接口為雙AHB總線結構,即指令AHB總線和數據AHB總線。該設計中ARMTDMI-S主要負責控制、操作系統平臺和任務的調度。ARM926EJ-S則主要負責各種任務的執行。

1.2 使用的總線標準

由于SoC中集成了大量的IP核,設計的關鍵在于如何實現各IP模塊之間的互連。目前,SoC中IP核的互連一般采用總線結構,通過消息通信。

采用ARM公司的AHB與APB為片上總線。AMBA總線體系結構是當前SoC體系設計結構設計的開放標準,由于AMBA被越來越多的公司采用,已迅速成為SoC結構和IP庫開發的標準。

在具體實現時,采用AHB加APB的兩級總線結構。AHB用來支持高速設備,支持多主從設備。多個主設備之間通過仲裁機制保證優先級,從設備通過地址譯碼機制被選中,并響應主設備發起的總線事務。APB用支持基于寄存器訪問的低速設備。AHB與APB兩條總線通過總線橋連接在一起,實現兩條總線之間的協議轉換。圖1為SoC的系統結構框圖。

1.3 各IP在系統中的功能

除了兩個處理器外,SoC中各IP核功能如下:翻譯模塊:實現將X86指令翻譯成為ARM指令的功能。

SMI:外部存儲與微處理器之間的橋梁,支持RoM作為系統的非易失性存儲介質,支持片外SRAM作為系統的外圍高速存儲。

中斷控制器:用來支持系統內部與外部的中斷控制,如中斷電平/邊沿觸發、中斷電平極性與中斷使能等。

Internal Memory:片內SRAM,大小為1 KB,但可以通過修改Verilog的描述來改變其大小。

Default Slave:用于當master訪問未定義的地址空間時,給出一個應答信號。

Retry Slave:是一個可以產生重試回應及等待命令的slave范例,若需要類似的模組,可以利用它來完成。

Watchdog:保證系統安全的監控模塊,軟件需在預定的時間內訪問相應的寄存器,否則硬件將產生內部信號自動復位。

GPIO控制器:用來支持擴展外設,拓寬SoC的使用范圍。

Remap&Pause:主要分成兩個處理單元,前者負責控管地址是否重新對應的機制,后者負責管理系統的省電模式。

Timer:定時器,支持捕獲、Matchout輸出、外部時鐘驅動。

2 X86到ARM二進制翻譯模塊

該設計使用的翻譯模塊通過編寫Verilog HDL實現,能將部分X86指令翻譯成ARM指令,實現了某些X86應用程序到ARM架構的移植。圖2為解碼器內部結構圖。

該翻譯模塊首先從ROM中取出X86指令,翻譯成ARM指令后存人RAM中,所有指令翻譯完成后,翻譯模塊產生一個終端,使處理器執行RAM中的指令。即所有指令先翻譯完成,處理器才執行,該翻譯過程屬于靜態二進制翻譯。其中Decoder是整個解碼模塊的核心,負責翻譯指令。Decoder模塊采用有限狀態機控制數據通路的方式實現.根據指令的功能和尋址方式進行狀態分類,然后輸出ARM指令。例如,把寄存器尋址的算術指令可分為一類:

ADD EAX,EBX

SUB EAX,EBX

因為這些指令的尋址方式一樣,功能近似,只是操作碼不一樣,可以歸并為一個狀態,在某一狀態內建立映射關系翻譯成為ARM指令。

考慮到AHB總線可能處于比較忙碌的狀態,對于X86指令和翻譯出的ARM指令分別設置2個FIFO。FIFO1和FIFO2各自有2個存儲器,其中一個存儲指令,另一個存儲與指令對應的地址。對FIFO進行操作會同時對指令和地址進行操作,以保持指令和地址的對應。

此外,ARM核需要向解碼模塊發送信號,通過設置Communicate模塊中的寄存器控制指令譯碼器的工作:

設置X86指令的起始地址;設置X86指令的終止地址;設置ARM指令的初始存放地址;設置ARM指令復雜指令段的初始地址;設置使指令解碼器開始工作的標志寄存器,高電平表示工作;判斷指令解碼是否結束,結束后向ARM核發送中斷;ARM核接收中斷信號后,將標志寄存器置低,翻譯模塊結束本次工作。

本文的SoC系統中沒有使用DMA對X86指令和ARM指令進行存取,而是由翻譯模塊主動進行讀和寫。因而有2個Master總線接口,通過AHB _1_1interface讀取X86指令,由AHB_2_1 interface將ARM指令寫入RAM中。Communicate模塊與總線的通信接口為Slave口,用于接收ARM核發送的4個地址,一旦接收到這4個地址,翻譯模塊中的start_flag信號置高,表示開始工作。

3 片上總線結構

在ARM SoC體系結構中,有Master和Slave這兩個重要的概念。Master是ARM SoC體系結構中的主單元,他可以向總線發出請求并且對傳輸進行初始化,例如對存儲器進行讀/寫操作,典型的Master可以是CPU,DSP,DMA。Slave是ARM SoC體系結構中的從單元,典型的Slave為片上或者片外存儲器,它們都有自己惟一的地址范圍。Master發起讀/寫操作時,在初始化中會給出讀/寫操作的地址,而地址譯碼器則根據這個地址決定哪個Slave被Master選中,然后相應的Slave做出相應。

在AHB系統中,若有2個Master常需要AccessBus,則系統的Performance必定會下降。為了解決這個問題。ARM提出了Multi-layer AHB,其基本構想是2個Master走不同的Bus去訪問Slave,如果訪問的Slave不同,則兩個Master可以同步的進行Transfer。若彼此訪問一個Slave,則根據優先級去判斷要先處理誰的Transfer。

該總線結構使用了Multi_layerbus switch(BusMatrix)模塊。AHB BusMatrix的設計可以分為3個部分:輸入級、譯碼級和輸出級。圖3為該設計所使用的結構,其中,輸入和輸出的個數可以根據系統的Master和Slave靈活調整。

可以看出,每個Layer都有一個譯碼器來決定Master要訪問哪一個Slave,通過多路選擇器實Master和Slave之間的Transfer。。每個Slave口都有自己的仲裁器,該仲裁器使用固定優先級,最高優先級的Layer可以優先訪問對應的Slave。

隨著系統中Master和Slave的增多,Busmatrix模塊的復雜度也會明顯增加,如果按照系統所有的Mas-ter和Slave的個數來確定輸入/輸出口的個數,Busma-trix將會非常復雜,因此對系統結構進行優化變得非常必要。根據系統工作情況可以發現,翻譯模塊的Slave端口僅被ARM7核訪問,即向翻譯模塊存取指令所需的地址,控制其工作,該Slave可以看作是ARM7核私有的,而不被其他Master訪問。有些Slave只有在特殊情況下才被訪問,因此可以將多個Slave看作一個Slave掛在BusMatrix上。優化后的SoC硬件架構如圖4所示。

4 結 語

這里給出了一種具有X86到ARM二進制翻譯和執行功能的SoC系統。利用Multi-layer bus SWitch(BusMatrix)模塊實現Multi-layer。總線結構,在多個核不訪問同一個Slave時,可以同時執行各自功能,有效提高系統的性能,且該總線結構的可擴展性強。同時根據系統工作的特點,對總線結構進行了優化,減小了總線的復雜度。

此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
欧美~级网站不卡| 国内精品亚洲| 久久最新视频| 久久av在线看| 欧美亚洲网站| 亚洲一区二区三区高清| 99国产精品99久久久久久| 亚洲国产精品尤物yw在线观看| 欧美亚洲视频一区二区| 亚洲在线国产日韩欧美| 一区二区三区高清在线| 一本一道久久综合狠狠老精东影业| 亚洲人午夜精品| 亚洲人成免费| 亚洲另类在线视频| 亚洲精品一区二区三区婷婷月| 亚洲人成在线观看网站高清| 亚洲国产欧美日韩精品| 亚洲高清免费在线| 亚洲国产专区| 日韩系列欧美系列| 在线一区亚洲| 午夜精品区一区二区三| 欧美一区二区三区在线观看| 欧美一级网站| 亚洲国产1区| 亚洲欧洲一区| 一本色道久久88精品综合| 国产精品99久久久久久www| 亚洲天堂网在线观看| 亚洲午夜高清视频| 亚洲综合第一页| 欧美在线视频播放| 久久婷婷影院| 欧美精品v日韩精品v国产精品| 欧美日韩免费高清一区色橹橹| 欧美手机在线| 国产亚洲a∨片在线观看| 极品中文字幕一区| 亚洲精品久久7777| 亚洲一区日本| 久久精品人人做人人综合| 亚洲美女精品久久| 亚洲综合三区| 久久久久久午夜| 欧美好骚综合网| 国产精品成人一区二区三区吃奶 | 日韩一二三在线视频播| 亚洲影音一区| 亚洲国产一区二区三区在线播| 一区二区三区 在线观看视| 午夜精品视频在线观看一区二区 | 樱桃成人精品视频在线播放| 亚洲精品一二区| 亚洲综合第一页| 91久久久久久| 亚洲女爱视频在线| 久久综合精品一区| 欧美午夜在线| 有码中文亚洲精品| 一本大道av伊人久久综合| 午夜日韩在线| 99re热精品| 久久国产精品久久w女人spa| 欧美成人午夜激情视频| 国产精品三级久久久久久电影| 一区二区三区在线观看国产| 一区二区三区精品在线| 久久精品国产91精品亚洲| 亚洲无线一线二线三线区别av| 久久精品亚洲| 欧美日韩中文字幕精品| 韩国福利一区| 在线一区视频| 亚洲精品一二三| 久久精品一区二区国产| 欧美日韩综合一区| 亚洲丰满在线| 午夜在线精品偷拍| 一区二区三区四区国产| 久久天堂av综合合色| 国产精品久久久久秋霞鲁丝| 亚洲成人在线观看视频| 亚洲免费在线播放| 夜夜爽www精品| 美日韩精品视频| 国产一区二区三区电影在线观看| 亚洲免费观看高清在线观看| 亚洲国产高清aⅴ视频| 欧美一区二区在线免费播放| 欧美日韩国产精品专区| 在线日韩日本国产亚洲| 午夜亚洲影视| 亚洲欧美在线免费观看| 欧美日韩另类在线| 亚洲韩国精品一区| 亚洲国产精品传媒在线观看 | 国产精品美女在线观看| 亚洲精品黄网在线观看| 亚洲国产清纯| 久久久国产精品一区二区中文| 国产精品青草综合久久久久99| 洋洋av久久久久久久一区| 亚洲精品在线一区二区| 久久亚洲色图| 国产一区二区丝袜高跟鞋图片| 亚洲欧美国产另类| 亚洲图中文字幕| 欧美日韩福利| 亚洲美女中文字幕| 99视频一区二区三区| 欧美成人一区二区| 1769国内精品视频在线播放| 久久疯狂做爰流白浆xx| 久久久久国产精品一区二区| 国产精品自在欧美一区| 亚洲一区二区视频| 亚洲欧美视频在线| 国产精品久久影院| 一区二区欧美精品| 亚洲永久字幕| 国产精品视频一区二区三区| 亚洲一区二区免费看| 亚洲欧美日韩国产成人| 欧美色视频在线| 一本色道久久88综合亚洲精品ⅰ | 宅男在线国产精品| 亚洲欧美成人一区二区三区| 国产精品久久久久久久久久ktv| 亚洲视频图片小说| 亚洲欧美成人在线| 国产精品自拍一区| 欧美一级网站| 久久综合久久88| 亚洲国产美女久久久久| 亚洲精品综合久久中文字幕| 欧美激情1区2区| 夜夜夜久久久| 午夜一区二区三视频在线观看| 国产精品久久夜| 香蕉亚洲视频| 蜜臀av国产精品久久久久| 91久久久亚洲精品| 在线性视频日韩欧美| 国产精品国产三级国产aⅴ入口 | 久久久伊人欧美| 亚洲国产精品123| 在线视频一区二区| 国产精品捆绑调教| 亚洲欧美色一区| 鲁大师成人一区二区三区| 亚洲黄色免费电影| 亚洲一区二区三区精品在线观看| 国产毛片一区二区| 最新国产の精品合集bt伙计| 欧美日韩中文字幕在线视频| 亚洲欧美日本视频在线观看| 久久频这里精品99香蕉| 亚洲激情网站免费观看| 亚洲永久免费精品| 国产在线成人| 99热精品在线观看| 国产精品视频免费一区| 亚洲福利免费| 欧美日韩精品在线视频| 亚洲欧美日韩一区二区在线| 免费观看成人www动漫视频| 洋洋av久久久久久久一区| 久久爱www久久做| 亚洲二区视频在线| 亚洲欧美日韩另类精品一区二区三区| 国语自产在线不卡| 一区二区三区欧美激情| 国产精品有限公司| 亚洲欧洲偷拍精品| 国产精品一二三视频| 亚洲人成人一区二区三区| 国产精品久久国产愉拍| 亚洲国产精品久久久久久女王| 欧美日韩一区二区免费视频| 久久国产精品99久久久久久老狼 | 在线综合亚洲欧美在线视频| 久久三级视频| 在线一区二区三区四区五区| 久久午夜电影网| 一区二区三区成人精品| 美女精品在线观看| 亚洲一区二区三区免费在线观看| 你懂的一区二区| 亚洲欧美另类在线观看| 欧美久久成人| 久久国产精品久久国产精品| 国产精品草草| 亚洲人成网站影音先锋播放| 国产女优一区| 一区二区高清在线观看| 国内精品久久久久久久影视麻豆| 亚洲午夜国产成人av电影男同| 在线观看日韩av| 欧美一区二区三区免费在线看|