新聞中心

EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > ARM指令中的函數(shù)調(diào)用

ARM指令中的函數(shù)調(diào)用

作者: 時(shí)間:2016-11-20 來源:網(wǎng)絡(luò) 收藏
1. 重要寄存器

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

本文引用地址:http://m.butianyuan.cn/article/201611/318730.htm

LR 鏈接寄存器,一般用來存儲(chǔ)返回地址;在執(zhí)行BL或BLX等指令時(shí),會(huì)自動(dòng)存儲(chǔ)下一條指令地址,即返回地址

PC 程序計(jì)數(shù)器,存儲(chǔ)將要執(zhí)行的指令

2. 程序跳轉(zhuǎn)

B

BL

BX Rm ;指令集的切換,跳轉(zhuǎn)到另一指令集的label;

BLX Rm ;將當(dāng)前指令的下一條指令的地址存儲(chǔ)到LR,然后跳轉(zhuǎn)到另一指令集的地址處label

--

看到這里,我們需要注意不是所以的函數(shù)調(diào)用都遵循AAPCS調(diào)用方式,相反,部分ARM c編譯器可能強(qiáng)制將返回地址存放在棧上,然后使用B或BX這樣的強(qiáng)制調(diào)轉(zhuǎn)指令進(jìn)行跳轉(zhuǎn)。

Note that, in practice, not all function calls follow the AAPCS calling conventions: Instead of transferring the return address to lr register, the ARM C compiler may enforce the return address to be push onto the stack and afterwards performs a direct branch to the function through a B or BX instruction.



關(guān)鍵詞: ARM指令函數(shù)調(diào)

評論


技術(shù)專區(qū)

關(guān)閉