色婷婷AⅤ一区二区三区|亚洲精品第一国产综合亚AV|久久精品官方网视频|日本28视频香蕉

          新聞中心

          EEPW首頁(yè) > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > ARM 內(nèi)核SP,LR,PC寄存器

          ARM 內(nèi)核SP,LR,PC寄存器

          作者: 時(shí)間:2016-11-21 來(lái)源:網(wǎng)絡(luò) 收藏
          深入理解ARM的這三個(gè)寄存器,對(duì)編程以及操作系統(tǒng)的移植都有很大的裨益。

          1、堆棧指針r13(SP):每一種異常模式都有其自己獨(dú)立的r13,它通常指向異常模式所專(zhuān)用的堆棧,也就是說(shuō)五種異常模式、非異常模式(用戶(hù)模式和系統(tǒng)模式),都有各自獨(dú)立的堆棧,用不同的堆棧指針來(lái)索引。這樣當(dāng)ARM進(jìn)入異常模式的時(shí)候,程序就可以把一般通用寄存器壓入堆棧,返回時(shí)再出棧,保證了各種模式下程序的狀態(tài)的完整性。

          本文引用地址:http://cafeforensic.com/article/201611/319531.htm

          2、連接寄存器r14(LR):每種模式下r14都有自身版組,它有兩個(gè)特殊功能。

          (1)保存子程序返回地址。使用BL或BLX時(shí),跳轉(zhuǎn)指令自動(dòng)把返回地址放入r14中;子程序通過(guò)把r14復(fù)制到PC來(lái)實(shí)現(xiàn)返回,通常用下列指令之一:
          MOV PC, LR
          BX LR

          通常子程序這樣寫(xiě),保證了子程序中還可以調(diào)用子程序。
          stmfd sp!, {lr}
          ……
          ldmfd sp!, {pc}

          (2)當(dāng)異常發(fā)生時(shí),異常模式的r14用來(lái)保存異常返回地址,將r14如??梢蕴幚砬短字袛?。

          3、程序計(jì)數(shù)器r15(PC):PC是有讀寫(xiě)限制的。當(dāng)沒(méi)有超過(guò)讀取限制的時(shí)候,讀取的值是指令的地址加上8個(gè)字節(jié),由于ARM指令總是以字對(duì)齊的,故bit[1:0]總是00。當(dāng)用str或stm存儲(chǔ)PC的時(shí)候,偏移量有可能是8或12等其它值。在V3及以下版本中,寫(xiě)入bit[1:0]的值將被忽略,而在V4及以上版本寫(xiě)入r15的bit[1:0]必須為00,否則后果不可預(yù)測(cè)。



          關(guān)鍵詞: ARM內(nèi)核SPLRPC寄存

          評(píng)論


          技術(shù)專(zhuān)區(qū)

          關(guān)閉