arm寄存器

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需要保存哪些寄存器?它在异常中断响应和异常中断返回中起什么作用?

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值