ARM 深入理解LR、PC部分内容

其实我也不算很确定,但是目前就是这样理解的。
写出来mark一下,有不对还请大家指出呀。


学的时候举的例子是两种情况:有返回、无返回。

  • 其中,返回则默认为是BX LR语句,作用等同于【MOV PC,LR,即跳转到LR中存放的地址处】

  • LR存放的地址是什么呢?
    我的理解是(返回值将要返回到的目标位置+bit[0])
    其中bit[0]是自设定用来标记thumb mode的,在本例中取值为1

  • PC存放的又是什么地址呢?
    PC其实是下一步将要执行的指令的地址。

1. 无返回语句

ARM 深入理解LR、PC部分内容

  • 首先到190的那一步,BL.W func。
  • 为了读这个语句,我们要用assembler解析。这个指令是4字节,所以PC指向194。
  • 因为要作为thumb mode标示,所以需要再在PC基础上加一个bit[0],将此时的值给LR
  • PC的下一步就是跳转到func(100)取读函数。所以将 PC 的地址改为100。

LR : 195
PC: 100


2. 有返回语句

ARM 深入理解LR、PC部分内容

  • 首先到190的那一步,BL.W func。
  • 为了读这个语句,我们要用assembler解析。这个指令是4字节,所以PC指向194。这个就是我们的目标返回地址。
  • 因为要作为thumb mode标示,所以需要再在PC基础上加一个bit[0],将此时的值给LR
  • PC的下一步就是跳转到func(100)取读函数。因为函数读完以后还有返回指令,所以一直追溯到返回那一行12C。
  • 返回的地址就是前面PC记录过的目标返回地址194,此时的值给PC

LR : 195
PC: 194


加一个例子复习一下:
ARM 深入理解LR、PC部分内容

(是第一种情况)

  • 首先到4AC的那一步,BL.W Sub1。
  • LR就是4AC+4+1 = 4B1
  • PC就是当前的下一步 = 340