zl程序教程

您现在的位置是:首页 >  硬件

当前栏目

[思考]-ARM LR寄存器的思考

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