ARM處理器架構(gòu)處理器的工作狀態(tài)
從編程人員的視角來看,arm核是由數(shù)據(jù)總線連接的功能單元組成,如下圖所示:
本文引用地址:http://m.butianyuan.cn/article/201611/317948.htm
數(shù)據(jù)通過數(shù)據(jù)總線流向處理器核心,這里的數(shù)據(jù)可以是將要執(zhí)行的指令,也可以是數(shù)據(jù)項(xiàng).上面的圖是Von Neumann體系的arm核,數(shù)據(jù)項(xiàng)和指令共用同一總線.而哈佛結(jié)構(gòu)體系的arm核就會(huì)用兩個(gè)不同的總線.就像所有的RISC處理器,arm采用load-store體系結(jié)構(gòu).也就是說它含有兩條不同的指令類型來出入處理器.load指令將數(shù)據(jù)從內(nèi)存拷貝到寄存器,store指令是將數(shù)據(jù)從寄存器拷貝到內(nèi)存.沒有直接操作內(nèi)存中數(shù)據(jù)的數(shù)據(jù)處理指令.數(shù)據(jù)的處理離不開寄存器.
ARM指令一般有兩個(gè)源寄存器,Rn和Rm,和一個(gè)目的寄存器,Rd. ARM的一個(gè)重要特性是Rm可以在送入ALU之前被桶型移位器做預(yù)處理,這樣就會(huì)有很多形式的表達(dá)式和尋址方式. 后面再寫博客記錄一下arm中的指令集。
下面介紹ARM處理器的幾個(gè)關(guān)鍵分量:寄存器,當(dāng)前程序狀態(tài)寄存器和流水線
一、寄存器。
arm核一共有37個(gè)寄存器,有7種工作模式。其中在任一種工作模式下,可見的寄存器通常有18個(gè)(在user/system模式下可見的是17個(gè))。另外,某幾個(gè)寄存器(sp、lr、spsr)在不同的模式下對應(yīng)的是不同的寄存器,所以總數(shù)加起來共有37個(gè)。所有的寄存器都是32bit大小.
18個(gè)活動(dòng)的寄存器包括:16個(gè)數(shù)據(jù)寄存器和2個(gè)程序狀態(tài)寄存器.
(1)數(shù)據(jù)寄存器由r0--r15表示. 其中r0-r12是通用寄存器,r13-r15是三個(gè)特殊的寄存器。
r13通常用作棧指針(sp),存儲(chǔ)當(dāng)前處理器工作模式下的棧頂;
r14被稱作鏈接寄存器(lr),當(dāng)發(fā)生函數(shù)調(diào)用時(shí)存放當(dāng)前的pc指針,作為子程序的返回地址;
r15被稱作程序計(jì)數(shù)器(pc),保存被處理器預(yù)取的下一條指令的地址.
這三個(gè)寄存器,在寫匯編語句的時(shí)候都不用r13這種來表示,都是用sp、lr、pc來表示的。
(2)兩個(gè)程序狀態(tài)寄存器:cpsr和spsr. 處理器的當(dāng)前工作模式?jīng)Q定了哪些寄存器是可見的.
cpsr:當(dāng)前程序狀態(tài)寄存器。ARM核使用cpsr來顯示和控制內(nèi)部的操作.通用程序狀態(tài)寄存器的內(nèi)部如下:
cpsr分為四個(gè)域,每個(gè)域有8位的寬度:flags,status,extension和control.control域包含處理器模式和狀態(tài)以及中斷屏蔽位.flags域包含condition flags.處理器模式?jīng)Q定了當(dāng)前哪些寄存器是可用的以及cpsr本身的訪問權(quán)限.
當(dāng)發(fā)生異常時(shí),arm會(huì)自動(dòng)將cpsr保存到spsr寄存器中。
二、 處理器模式
處理器模式分為特權(quán)模式和非特權(quán)模式:特權(quán)模式對cpsr有完全的讀寫控制.而非特權(quán)模式只能讀cpsr的control域但是仍可以讀寫condition flags.一共有7種處理器模式:六種特權(quán)模式(abort,fiq,irq,svc,system和undefined)和一種非特權(quán)模式(user).
abort:當(dāng)試圖訪問內(nèi)存失敗時(shí)處理器會(huì)進(jìn)入abort模式;
fiq和irq對應(yīng)ARM處理器的兩種中斷級別, irq是普通的中斷模式,fiq是快速中斷模式。
svc是系統(tǒng)reset后進(jìn)入的默認(rèn)模式,也是os kernel工作的模式;
system模式是user模式的特殊版本,它有對cpsr的讀寫控制.
undefined模式在處理器遇到未定以的指令或者不支持的操作時(shí)使用.
user模式在應(yīng)用程序下使用.
在不同的模式下,有不同的Banked registers。所謂的banked register 就是說 這個(gè)寄存器是該模式所獨(dú)有的,不與其他模式共享。
除了user模式,其它模式都可以通過直接寫cpsr的模式位來改變處理器模式.當(dāng)然,在異?;蛘咧袛嗟絹頃r(shí),硬件會(huì)自動(dòng)切換模式.
下列異常和中斷會(huì)引起模式切換:reset,irq,fiq,swi,data abort,prefetch abort和undefined instruction.
三、cpsr寄存器。
下面接著講cpsr寄存器。處理器模式對應(yīng)的cpsr寄存器:
需要注意的是:通過直接寫cpsr來改變模式的方法不會(huì)將cpsr拷貝到spsr.只有在異常或中斷發(fā)生時(shí)cpsr的值才會(huì)保存到spsr。
當(dāng)ARM核上電時(shí),處于svc特權(quán)模式.從特權(quán)模式開始是有用的:初始化代碼完全控制cpsr來建立其他模式的堆棧.
cpsr中的bit T是表明指令簇用的是ARM指令集還是thumb指令集.T為1表示thumb指令集,T為0表示ARM指令集.
ARM指令集和thumb指令集的特性:
中斷屏蔽位:中斷屏蔽位用來屏蔽處理器的特殊中斷請求.在ARM核中有兩種級別的中斷請求:irq和fiq.
cpsr中的中斷屏蔽位是第7位和第6位(I和F),當(dāng)I或F設(shè)為1時(shí)irq或fiq就被屏蔽了.
condtion flags:condition flags可以被比較操作和帶S后綴的ALU操作來更新.
四、異常 中斷和向量表
當(dāng)異常發(fā)生時(shí),處理器會(huì)將pc指向一個(gè)特殊的內(nèi)存地址.該地址所在的地址范圍稱為向量表.向量表的入口是跳轉(zhuǎn)指令,跳轉(zhuǎn)到專門處理某個(gè)異常或中斷的子程序.
存儲(chǔ)器映射地址0x00000000是為向量表預(yù)留的.在某些處理器中向量表可以放在更高的地址,從0xffff0000開始.linux等操作系統(tǒng)可以利用這個(gè)特性.
當(dāng)異常發(fā)生時(shí),處理器掛起正常的處理然后從向量表中加載指令.每個(gè)向量表的入口都包含指向特殊處理例程的跳轉(zhuǎn)指令.
reset向量是處理器上電后執(zhí)行的第一條指令,這條指令跳轉(zhuǎn)到初始化代碼處.
undefined instruction向量是當(dāng)處理器不能對指令譯碼時(shí)使用的.
software interrupt向量執(zhí)行SWI指令時(shí)使用的.SWI可以用來系統(tǒng)調(diào)用的實(shí)現(xiàn).
prefetch abort向量發(fā)生在當(dāng)沒有訪問權(quán)限的條件下試圖獲取該地址的指令時(shí),異常發(fā)生在譯碼階段.
data abort向量與prefetch abort類似,只不過是訪問數(shù)據(jù)發(fā)生的異常.
interrupt request向量被外部硬件用來中斷處理器的正常執(zhí)行.只有在cpsr的相應(yīng)位為0時(shí)才能發(fā)生.
fast interrupt request向量與irq類似,是為要求更短的中斷響應(yīng)時(shí)間的硬件保留的.只有在cpsr的相應(yīng)位為0時(shí)才能發(fā)生.
五、流水線
RISC處理器用流水線機(jī)制來執(zhí)行指令.ARM流水線中的指令只有在完全通過執(zhí)行階段才被處理.
上面這張圖標(biāo)明了流水線的使用和程序計(jì)數(shù)器pc.在執(zhí)行階段,pc總是指向該指令地址加上8字節(jié).也就是說pc總是指向當(dāng)前指令的下下條指令.當(dāng)用pc來計(jì)算
相對偏移量時(shí)這點(diǎn)是很重要的,并且它也是所有流水線的特征.
六、條件執(zhí)行:
條件執(zhí)行控制指令是否被ARM核執(zhí)行.處理器會(huì)比較指令的條件屬性和cpsr中的condition flags,如果匹配,該指令執(zhí)行;否則該指令被忽略.
評論