新聞中心

        EEPW首頁 > 嵌入式系統(tǒng) > 設計應用 > 基于ARM嵌入式平臺的X86譯碼SOC架構設計

        基于ARM嵌入式平臺的X86譯碼SOC架構設計

        作者: 時間:2009-06-16 來源:網絡 收藏

        1.3 各IP在系統(tǒng)中的功能
        除了兩個處理器外,SoC中各IP核功能如下:翻譯模塊:實現將指令翻譯成為指令的功能。
        SMI:外部存儲與微處理器之間的橋梁,支持RoM作為系統(tǒng)的非易失性存儲介質,支持片外SRAM作為系統(tǒng)的外圍高速存儲。
        中斷控制器:用來支持系統(tǒng)內部與外部的中斷控制,如中斷電平/邊沿觸發(fā)、中斷電平極性與中斷使能等。
        Internal Memory:片內SRAM,大小為1 KB,但可以通過修改Verilog的描述來改變其大小。
        Default Slave:用于當master訪問未定義的地址空間時,給出一個應答信號。
        Retry Slave:是一個可以產生重試回應及等待命令的slave范例,若需要類似的模組,可以利用它來完成。
        Watchdog:保證系統(tǒng)安全的監(jiān)控模塊,軟件需在預定的時間內訪問相應的寄存器,否則硬件將產生內部信號自動復位。
        GPIO控制器:用來支持擴展外設,拓寬SoC的使用范圍。
        RemapPause:主要分成兩個處理單元,前者負責控管地址是否重新對應的機制,后者負責管理系統(tǒng)的省電模式。
        Timer:定時器,支持捕獲、Matchout輸出、外部時鐘驅動。


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

        該翻譯模塊首先從ROM中取出X86指令,翻譯成ARM指令后存人RAM中,所有指令翻譯完成后,翻譯模塊產生一個終端,使處理器執(zhí)行RAM中的指令。即所有指令先翻譯完成,處理器才執(zhí)行,該翻譯過程屬于靜態(tài)二進制翻譯。其中Decoder是整個解碼模塊的核心,負責翻譯指令。Decoder模塊采用有限狀態(tài)機控制數據通路的方式實現.根據指令的功能和尋址方式進行狀態(tài)分類,然后輸出ARM指令。例如,把寄存器尋址的算術指令可分為一類:
        ADD EAX,EBX
        SUB EAX,EBX
        因為這些指令的尋址方式一樣,功能近似,只是操作碼不一樣,可以歸并為一個狀態(tài),在某一狀態(tài)內建立映射關系翻譯成為ARM指令。
        考慮到AHB總線可能處于比較忙碌的狀態(tài),對于X86指令和翻譯出的ARM指令分別設置2個FIFO。FIFO1和FIFO2各自有2個存儲器,其中一個存儲指令,另一個存儲與指令對應的地址。對FIFO進行操作會同時對指令和地址進行操作,以保持指令和地址的對應。
        此外,ARM核需要向解碼模塊發(fā)送信號,通過設置Communicate模塊中的寄存器控制指令器的工作:
        設置X86指令的起始地址;設置X86指令的終止地址;設置ARM指令的初始存放地址;設置ARM指令復雜指令段的初始地址;設置使指令解碼器開始工作的標志寄存器,高電平表示工作;判斷指令解碼是否結束,結束后向ARM核發(fā)送中斷;ARM核接收中斷信號后,將標志寄存器置低,翻譯模塊結束本次工作。
        本文的SoC系統(tǒng)中沒有使用DMA對X86指令和ARM指令進行存取,而是由翻譯模塊主動進行讀和寫。因而有2個Master總線接口,通過AHB _1_1interface讀取X86指令,由AHB_2_1 interface將ARM指令寫入RAM中。Communicate模塊與總線的通信接口為Slave口,用于接收ARM核發(fā)送的4個地址,一旦接收到這4個地址,翻譯模塊中的start_flag信號置高,表示開始工作。

        linux操作系統(tǒng)文章專題:linux操作系統(tǒng)詳解(linux不再難懂)


        評論


        相關推薦

        技術專區(qū)

        關閉
        主站蜘蛛池模板: 钟山县| 梁河县| 浦城县| 泸西县| 罗甸县| 西乌珠穆沁旗| 淳化县| 龙江县| 石渠县| 阜城县| 新田县| 贺州市| 饶平县| 同仁县| 青冈县| 吉林市| 德惠市| 枞阳县| 鱼台县| 岱山县| 扶余县| 水富县| 年辖:市辖区| 小金县| 浠水县| 左权县| 新营市| 宜都市| 阿拉善左旗| 三江| 通许县| 伊吾县| 徐闻县| 杭锦旗| 冕宁县| 左贡县| 张家川| 定兴县| 凌源市| 三门峡市| 慈利县|