FIQ 与 IRQ

在 ARM 架构中,FIQ(Fast Interrupt Request,快速中断请求)和 IRQ(Interrupt Request,普通中断请求)是两类核心中断模式,核心差异体现在响应速度、硬件支持、优先级等维度

一、基础配置与触发逻辑

  1. 可配置性 :中断控制器支持将外接中断输入指定为 FIQ 或 IRQ 类型;通常将响应要求高、处理耗时短的中断设为 FIQ,普通中断设为 IRQ。
  2. 触发与模式切换
    • IRQ 触发:中断控制器通过 IRQ 请求线通知 ARM,ARM 切换至 IRQ 模式运行中断处理程序;
    • FIQ 触发:中断控制器通过 FIQ 请求线通知 ARM,ARM 切换至 FIQ 模式运行中断处理程序。

二、FIQ 比 IRQ 更快的核心原因

1. 寄存器硬件支持差异

特性 FIQ 模式 IRQ 模式
Banked 寄存器 包含 r8-r14 + SPSR(专属备份寄存器) 仅 r13-r14 + SPSR(无 r8-r12 备份)
寄存器处理逻辑 模式切换时 CPU 自动保存 / 恢复 r8-r12,无需软件干预 需中断处理程序手动保存 / 恢复 r8-r12,增加软件开销

2. 优先级差异

FIQ 优先级高于 IRQ:若两类中断同时产生,ARM 优先响应并处理 FIQ,完成后再处理 IRQ。

3. 中断向量地址与执行效率

  • IRQ 向量地址:0x00000018(或 0xFFFF0018),该地址仅能存放 1 条指令,需跳转至实际中断处理程序,增加指令执行开销;
  • FIQ 向量地址:0x0000001C(或 0xFFFF001C),其后无其他中断向量,可直接存放完整的 FIQ 处理程序,无需跳转,减少指令周期。

4. 响应延迟差异

  • IRQ 响应存在延迟:从外部请求到执行 ISR 第一条指令,需等待预取指令执行完毕,延迟数个指令周期;
  • FIQ 响应更快:无 IRQ 的预取指令等待开销,中断延迟显著低于 IRQ。

三、总结

  1. FIQ 的核心优势是硬件级加速(专属 Banked 寄存器、无跳转开销),适配高实时性、短处理周期的中断场景;
  2. IRQ 依赖软件处理寄存器保存 / 恢复,响应效率低,适用于普通实时性要求的中断;
  3. 中断延迟可通过 "优先级配置 + 中断嵌套" 优化,但 FIQ 的硬件特性决定其基础延迟远低于 IRQ。
相关推荐
RainCity4 天前
Java Swing 自定义组件库分享(十二)
java·笔记·后端
LinXunFeng12 天前
Obsidian - 使用 Share Note 分享笔记并自部署
前端·笔记·github
闪闪发亮的小星星16 天前
高斯光以及高斯光公式解释
笔记
cqbzcsq16 天前
CellFlow虚拟细胞论文阅读
论文阅读·人工智能·笔记·学习·生物信息
阿米亚波16 天前
【Windows】QEMU 启动 openEuler aarch64/arm64 架构系统 + 离线软件源
linux·windows·经验分享·笔记·架构·arm
自传.16 天前
尚硅谷 Vibe Coding|第三章(1) Claude Code深度使用与进阶技巧 学习笔记
笔记·学习·尚硅谷·vibecoding
.千余16 天前
【C++】模板进阶全解:非类型参数|全特化|偏特化|分离编译完全指南
开发语言·c++·笔记·学习·其他
自传.16 天前
尚硅谷 Vibe Coding|第二章 AI编程工具生态 学习笔记
笔记·学习·ai编程·尚硅谷·vibe coding
秋波。未央16 天前
Java Agent 开发 · Day 1 学习笔记(含作业完整标准答案)
java·笔记·学习
AndyHeee16 天前
【SVC、PendSV(系统异常) 与 外设 IRQ 、NVIC笔记】
arm开发