Android CPU注册名称?

Fre*_*ara 6 android arm computer-architecture cpu-registers

此代码片段是从Samsung Tab S上的Android崩溃报告中提取的:

Build fingerprint: 'samsung/chagallwifixx/chagallwifi:5.0.2/LRX22G/T800XXU1BOCC:user/release-keys'
Revision: '7'
ABI: 'arm'
    r0 a0d840bc  r1 a0dcb880  r2 00000001  r3 a0d840bc
    r4 a0dc3c4c  r5 00000000  r6 a066d200  r7 00000000
    r8 32d68f40  r9 a0c359a8  sl 00000014  fp bef3ba84
    ip a0dc3fb8  sp bef3ba10  lr a0c35a0c  pc a0c34bc8  cpsr 400d0010
Run Code Online (Sandbox Code Playgroud)

r0通过r9非常清楚的通用寄存器,sp(r13)是堆栈指针,pc(r15)是程序计数器(指令指针).参考维基百科的ARM体系结构页面寄存器部分(我查看的许多页面之一),我发现lr(r14)是链接寄存器,并且cpsr是"当前程序状态寄存器".

我想知道what sl(r10),fp(r11)和ip(r12)是什么.我想到ip不是该"指令指针",因为该功能是由完成pc(r15).

是否有一个我没有找到的参考文件说明了这些名称?

Not*_*hat 8

当前的ARM EABI过程调用标准概述了r12-r15的标准"特殊"名称:

  • PC(r15):程序计数器
  • LR(r14):链接寄存器
  • SP(r13):堆栈指针
  • IP(r12):程序内临时寄存器*

GNU工具还支持已弃用的旧版APCS中的名称 作为给定寄存器编号的标识符,即使它们不再具有任何含义:

  • FP(r11):帧指针 - 对于ARM代码可能仍然为真; Thumb代码倾向于在r7中保持实际的帧指针,当然代码可以在没有帧指针的情况下编译,在这种情况下,"fp"只是另一个被调用者保存的通用寄存器.
  • SL(r10):堆栈限制 - 我实际上并不知道那个的历史,但在大多数现代代码中,r10并不比r4-r8更特殊.

需要注意的是R9是不是一定是通用寄存器-在EABI保留它针对特定平台的目的.在linux-gnueabi下它没什么特别的,但是其他平台可能会将它用于特殊目的,如TLS或全局对象表指针,因此它也可以通过SB(静态基础)或TR(线程寄存器).

*PC相对分支指令的有限范围背后的故事 - 如果链接器发现呼叫的目标最终超过32MB,它可能会生成一个胶合代码(在呼叫站点范围内的一些额外指令)作为分支目标,它计算实际地址并执行绝对分支,它可能需要一个临时寄存器.