ARM处理器模式切换(含MRS,MSR指令)

本文介绍了ARM处理器的模式切换,特别是MRS和MSR指令的使用。通过MRS读取CPSR或SPSR状态寄存器,MSR则用于写入状态寄存器,实现模式切换、中断控制等功能。在模式切换中,CPSR的M[4:0]位决定了处理器的工作模式。文章还展示了如何启用和禁用IRQ中断,以及如何初始化不同模式的栈指针。

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

++++++++++++++++++++++++++++++++++++++++++

本文系本站原创,欢迎转载! 转载请注明出处:

http://blog.csdn.net/mr_raptor/article/details/6556172

++++++++++++++++++++++++++++++++++++++++++

1.1.1   ARM处理器模式切换(含MRS,MSR指令)

除了用户模式和系统模式,其余模式下都有一个私有SPSR保存状态寄存器,用来保存切换到该模式之前的执行状态,之所以用户模式和系统模式没有SPSR是因为,通常CPU大部分时间执行在用户模式下,当产生异常或系统调用时会分别切换进入另外几种模式,保存用户模式下的状态,当切换回原先模式时,直接回复SPSR的值到CPSR就可以了,因此,用户模式和系统模式下不需要SPSR,其详细操作查看下节异常处理。

以上几种模式通过CPSR里的M[4:0]位进行区分,如图3-1所示:

 

图3-1 CPSR控制位

通过向模式位M[4:0]里写入相应的数据切换到不同的模式,在对CPSR,SPSR寄存器进行操作不能使用mov,ldr等通用指令,只能使用特权指令msr和mrs。

评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值