新聞中心

        EEPW首頁 > 嵌入式系統 > 設計應用 > ARM處理器體系結構簡要總結

        ARM處理器體系結構簡要總結

        作者: 時間:2011-06-15 來源:網絡 收藏

          irq用于普通中斷處理,速度慢,進irq后默認關普通中斷,但開fiq.fiq用于快速中斷處理,有專用的r8-r14寄存器,一般不需要保存現場,進fiq后所有中斷標記都關掉.

          除用戶模式外其他模式都有特權,可以為所欲為.

          r13默認用來作為堆棧寄存器,r14用于保存返回地址.

          用戶模式和管理模式只有cpsr,沒有spsr。cpsr是當前狀態寄存器,內含算數運行標記位,irq和fiq標記,模式位,保留位。spsr是cpsr的備份。

          arm處理器支持arm指令集和thumb指令集,arm指令集是32位,thumb指令集是16位,具有arm指令集的子集功能,實現同樣的功能用thumb指令集所需空間較小,但執行時間有可能變長。arm代碼向thumb代碼跳轉通過BX指令完成。BX指令通過判斷數據項的最后一位來確定是否轉入thumb或arm模式,跳轉后會設置cpsr中的模式位。

          這里我不打算描述arm或thumb指令集,因為那需要太大的篇幅,但arm和x86相比有一些很大的特殊之處就是它的堆棧可以向上或向下增長,而且存數與累加誰在先都可,這樣就有四種堆棧方式;另外每條arm指令都帶有執行條件,像溢出,進位等,只有在滿足特定條件下指令才會得到執行;當然arm指令集不存在像x86指令集那樣的向下兼容性,386支持16位實模式,兼容8086,但32位arm卻沒法識別16位arm指令集。

          這是我對arm處理器內部的一些了解。

          下面談談philips公司出的一款lpc2214處理器,內含arm7tdmi-s處理器核,支持jtag調試和跟蹤。lpc2214一共有三條內部總線,一條是內部局部總線,用來連接內部ram和rom,rom有256kb,ram16k。另一條是amba總線ahb,主要連接向量中斷控制器和外部存儲器接口,第三條是vpb,通過vpb橋橋接到ahb,用于低速外設,有點x86主板的味道,不過它把這三個總線都集成在一個處理器里面。vpb上連接了好多外設,像uart,i2c,spi,timer,pwm,a/d,rtc,hot dog,系統控制,外部中斷。這些外設通常以主頻的1/2,1/4,1倍速度運行,這里我不會講這些外設如何控制,如何設定寄存器,那楊可以寫一本數據手冊了。我只講我覺得這個處理器里我覺得比較有意思的東西。

          這個處理器內含振蕩器,可以外接晶振也可直接接時鐘,還含有pll,我們使用時通常讓它在振蕩器模式下啟動運行,然后切換到pll模式,可以提高運行速度。這個處理器有掉電模式和空閑模式,空閑模式只禁止cpu的時鐘,但是外設時鐘繼續運行,在掉電模式pll停止運行,掉電模式通過reset可復位,空閑模式通過reset或外部中斷可復位。lpc2214可以外接各類接口芯片,它一共有四個外接設備地址空間,每個空間有16M,可以按8,16,32位模式訪問。lpc2214有一個存儲器加速模塊,可以設定是否預取,可以設定不預取,連續指令預取,所有指令數據都預取,開機默認是不預取。其實第三個情況就類似x86中的二級cache,因為目前的家用x86處理器cache設計都是兩極結構,第一級是哈佛結構,第二級就是指令數據共享一個cache。其實即使在不預取的情況下因為lpc2214是三級流水線結構,也會預取兩條指令,當前指令地址為pc+2,這只是層次和說法上的問題。最后就是處理器的地址空間布局,lpc2214不存在io空間,它是內存空間統一編址,0地址開始是rom,256k,1G以上是ram,16k,2G以上是外部地址空間,64M,2.5G以上是vpb和ahb地址空間;其中rom空間的頂端是boot block塊,8k,這8k還映射到2G的頂端。最低64字節是中斷向量表,可以映射到boot block,內部rom,內部ram,外部空間,具體映射可以設定memmap寄存器。


        上一頁 1 2 下一頁

        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 江津市| 阿拉尔市| 探索| 伊宁县| 湟源县| 威海市| 板桥市| 庄浪县| 玛沁县| 潼南县| 称多县| 区。| 鄢陵县| 九龙坡区| 崇信县| 佛冈县| 获嘉县| 太谷县| 沙坪坝区| 平南县| 闸北区| 横山县| 洛阳市| 石城县| 麻阳| 普兰店市| 扎囊县| 唐海县| 肇东市| 曲水县| 安泽县| 北安市| 西华县| 荔浦县| 监利县| 江口县| 茂名市| 长沙市| 高唐县| 泰兴市| 大洼县|