新聞中心

        EEPW首頁 > 嵌入式系統 > 設計應用 > 基于SoC的X86到ARM二進制翻譯和執行功能的系統設計

        基于SoC的X86到ARM二進制翻譯和執行功能的系統設計

        作者: 時間:2012-08-11 來源:網絡 收藏

         ADD EAX,EBX

        本文引用地址:http://www.104case.com/article/148618.htm

          SUB EAX,EBX

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

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

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

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

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

          3 片上總線結構

          在ARM 體系結構中,有Master和Slave這兩個重要的概念。Master是ARM 體系結構中的主單元,他可以向總線發出請求并且對傳輸進行初始化,例如對存儲器進行讀/寫操作,典型的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時,可以同時各自,有效提高系統的性能,且該總線結構的可擴展性強。同時根據系統工作的特點,對總線結構進行了優化,減小了總線的復雜度。


        上一頁 1 2 下一頁

        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 乌鲁木齐县| 北辰区| 怀化市| 临汾市| 饶阳县| 区。| 孙吴县| 旅游| 靖江市| 昂仁县| 乌拉特后旗| 得荣县| 论坛| 都安| 额尔古纳市| 股票| 永和县| 泾源县| 绥德县| 石屏县| 富顺县| 肥东县| 浙江省| 隆化县| 西吉县| 曲阜市| 北安市| 岳普湖县| 施甸县| 武汉市| 敦煌市| 永城市| 丰台区| 肥西县| 礼泉县| 秦皇岛市| 应城市| 永州市| 成都市| 工布江达县| 化隆|