ARM寄存器有37个。31个通用寄存器+6个状态寄存器。7种处理器模式对应7组寄存器组。通用寄存器可分为备份寄存器和未备份寄存器。未备份寄存器为R0-R7,备份寄存器为R8-R12。重点是寄存器R13,R14和R15。
1 、R13:栈指针。
每种异常模式都有其专用的栈地址。应用程序在初始化时,就把各种异常模式下的栈指针指向该异常模式专用栈地址。
2、R14:链接寄存器
存放返回地址。分为调用子程序时的返回地址和异常中断时的返回地址两种情况。
3、R15:程序计数器
下两条即将被执行的指令的地址。由于ARM指令是字对齐的,即4个字节构成一条指令,所以R15中存放的地址值必须是4的倍数。既然是这样,所以R15中存放的值的第0、1位必须为0,这样才能使4的倍数。同理,如果是THUMB指令,则要求是半字对齐,即2个字节构成一条指令,所以R15中存放的地址值必须是2的倍数。所以THUMB指令下R15中存放的值的第0位必须为0,这样才能是2的倍数。
二 CPSR和SPSR_mode(共6个)
??????
这里有个问题,在进入异常模式时,R13需要保存哪些寄存器?它在异常中断响应和异常中断返回中起什么作用?
arm寄存器
最新推荐文章于 2021-12-18 17:35:15 发布