ARM处理器架构-----异常/中断处理

本文深入探讨了ARM处理器的中断处理流程,包括模式切换、异常向量表、中断处理函数的自动恢复机制。通过分析2440init.s中的代码,展示了如何从异常中断处理程序退出,并强调了中断不可嵌套的特性。同时提到了在ADS中对中断函数的特殊声明方式,以及在UCOSII中的中断处理修改。

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

中断是我们嵌入式开发很常用到的一种资源和编程手段。这篇文章重点分析arm的中断处理流程。

 首先,中断是异常的一种。当发生一种异常时,处理器会进入不同的工作模式。ARM的异常和相应的模式之间的对应关系见下表:


当一个异常导致模式的改变时,ARM核自动地:

1、把cpsr保存到相应模式下的spsr

2、把pc保存到相应模式下的lr

3、设置cpsr为相应异常模式

4、设置pc为相应异常处理程序的入口地址

对于IRQ或者FIQ而言,还多一项变化:禁用相关的中断IRQ或FIQ,禁止同类型的其他中断被触发。(这也是自动实现的,因此正常情况下,ARM中断不可嵌套


从异常中断处理程序退出时,需要我们在程序中用软件实现下面两个操作:

1、从spsr_mode中恢复数据到cpsr中

2、从lr_mode中恢复内容到pc中,返回到异常中断的指令的下一条政令处执行.


2440默认的有一个异常向量表,即发生某一个异常后,会根据异常向量表设置pc为相应的处理函数入口地址。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值