ARM-中断管理

摘自:ARM-中断状态,中断响应流程(四大步三小步)-CSDN博客

当异常发生时,ARM处理器核心会自动完成以下操作来保存现场:

  1. 保存CPSR :将当前程序状态寄存器 (CPSR) 的内容复制到相应异常模式的备份寄存器 (SPSR_mode) 中。

  2. 设置CPSR

    • 切换处理器进入 ARM状态

    • 根据需要,禁止中断 (设置 FIQIRQ 禁止位)。

    • 根据异常类型,切换到对应的异常模式

  3. 保存返回地址 :将当前程序计数器 (PC) 的值保存到相应异常模式的链接寄存器 (lr_mode) 中。

  4. 跳转处理 :强制将 PC 设置为异常向量表的固定首地址,开始执行中断服务程序。

  • 软/硬中断区别硬中断 由硬件随机产生;软中断 (如SWI指令)由软件预先安排,用于主动进入特权模式。

  • 恢复现场 :上述由硬件完成,而中断返回时必须由软件手动恢复 现场,包括从 SPSR_mode 恢复 CPSR、从 lr_mode 恢复 PC 等。

  • Cortex-M vs Cortex-A :文章指出,Cortex-M系列 (如STM32)支持中断嵌套 ;而Cortex-A系列因处理速度快,硬件上不支持嵌套。

概念类别 核心内容/状态 简要说明
中断状态 1. 挂起态 中断已发生,但尚未被处理
2. 激活态 正在执行对应的中断处理函数
3. 未激活态 无中断请求发生
异常类型 (7种) 1. 复位异常 优先级最高,用于系统启动
2. 数据异常 访问数据时出错(如地址无效)
3. 快速中断(FIQ) 高速、低延迟中断
4. 外部中断(IRQ) 普通外设中断
5. 预取异常 取指令时出错
6. 软中断(SWI) 软件主动触发,用于系统调用
7. 未定义指令异常 指令译码失败
相关推荐
balance_rui18 小时前
FreeRTOS
笔记·stm32
uncle_ll19 小时前
LangChain基础学习笔记
笔记·学习·langchain·llm·rag
三品吉他手会点灯19 小时前
C语言学习笔记 - 14.C编程预备计算机专业知识 - 本讲内容概述
c语言·笔记·学习
陈皮糖..20 小时前
27 届运维实习笔记|第三、四周:从流程熟练到故障排查,企业运维实战深化
运维·笔记·sql·nginx·ci/cd·云计算·jenkins
三水不滴20 小时前
SpringAI + SpringDoc + Knife4j 构建企业级智能问卷系统
经验分享·spring boot·笔记·后端·spring
三品吉他手会点灯20 小时前
C语言学习笔记 - 15.C编程预备计算机专业知识 - CPU 内存条 硬盘 显卡 主板 显示器 之间的关系
c语言·笔记·学习
三品吉他手会点灯21 小时前
C语言学习笔记 - 11.C语言简介 - VSCode(C/C++)环境安装与配置
c语言·笔记·学习
The Chosen One9851 天前
计算机知识点的理解开悟后的分享(一)
笔记
独孤九剑打醒他1 天前
#原创声明 #拒绝白嫖 #技术立场 #创作者保护
笔记
avocado_green1 天前
【考驾照】科目一备考笔记(个人手工整理,非AI生成)
笔记