ARM 深入理解LR、PC部分内容
其实我也不算很确定,但是目前就是这样理解的。
写出来mark一下,有不对还请大家指出呀。
学的时候举的例子是两种情况:有返回、无返回。
-
其中,返回则默认为是BX LR语句,作用等同于【MOV PC,LR,即跳转到LR中存放的地址处】
-
LR存放的地址是什么呢?
我的理解是(返回值将要返回到的目标位置+bit[0])
其中bit[0]是自设定用来标记thumb mode的,在本例中取值为1 -
PC存放的又是什么地址呢?
PC其实是下一步将要执行的指令的地址。
1. 无返回语句
- 首先到190的那一步,BL.W func。
- 为了读这个语句,我们要用assembler解析。这个指令是4字节,所以PC指向194。
- 因为要作为thumb mode标示,所以需要再在PC基础上加一个bit[0],将此时的值给LR
- PC的下一步就是跳转到func(100)取读函数。所以将 PC 的地址改为100。
LR : 195
PC: 100
2. 有返回语句
- 首先到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
加一个例子复习一下:
(是第一种情况)
- 首先到4AC的那一步,BL.W Sub1。
- LR就是4AC+4+1 = 4B1
- PC就是当前的下一步 = 340