arm 中cpsr和spsr

本文介绍了ARM处理器中异常处理的基本过程,包括如何保存当前状态到特殊程序状态寄存器(spsr)以及如何通过链接寄存器(LR)实现异常返回。文章详细解释了异常发生时处理器状态的保存方式,并探讨了LR寄存器在程序跳转和异常处理中的作用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

spsr是用来保存cpsr状态,当异常中断发生时候,用来回退cpsr的值

比如异常发生,步骤
1:将LR(R4)加偏移量,送到PC中
2:将cpsr中状态送到spsr,保存cpsr中的状态
3:如果需要禁止中断位,将中断位进行禁止(I禁止IRQ中断,F禁止FIQ中断)

先对LR等寄存器进行操作,然后保存cpsr(程序状态寄存器),然后对设置中断位

其中LR(R14)(还要sp(R3),PC(R15))一般有两种用法
1:程序跳转,时候用来返回PC值
例BX loop
。。。。
loop
。。。。
mov pc LR;
执行跳转

2:异常中断发生时候,R14保存异常返回地址

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值