[思考]-ARM LR寄存器的思考
2023-09-27 14:26:31 时间
快速链接:
.
👉👉👉 个人博客笔记导读目录(全部) 👈👈👈
在armv7上,我们知道sp是R13,lr是R14, PC是R15;
到了ARMV8上,lr是x30,sp和pc不再是单独的通用的寄存器. 这样设计的原因是啥?
1、为什么sp和pc不能map到通用寄存器上?
pc这么做的原因,应该是防止用户随意更高pc指针,分离出来之后,不能使用mov pc,#temp 来修改pc了
2、lr为什么依然map到通用寄存器上呢
lr是链接返回寄存器,它有它的特殊性, 我们可以看到在此架构下c语言翻译成的汇编函数:
基本是在函数的开头,都有类似stp x29, x30, [sp,#-48]的语句,目的就是保存x29和x30,而x30恰好就是LR
0000000000203e94 <image_verify>:
203e94: a9bd7bfd stp x29, x30, [sp,#-48]! // 这里保存LR
203e98: 910003fd mov x29, sp
203e9c: a9025bf5 stp x21, x22, [sp,#32]
203ea0: 2a0103f5 mov w21, w1
..... // 这里可能会跳转到别的函数中去,LR的值将会改变
204074: a8c37bfd ldp x29, x30, [sp],#48 //在此函数返回之前,恢复之前保存的LR的值
204078: d65f03c0 ret
![](http://assets.processon.com/chart_image/604719347d9c082c92e419de.png)