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。
相关推荐
张同学031 天前
220V 转 12V/5V 电源输入电路设计笔记
笔记·嵌入式硬件·硬件工程
深蓝海拓1 天前
S7-1500PLC学习笔记:MOVE_BLK、MOVE_BLK_VARIANT、BLKMOV的区别
笔记·学习·plc
雨浓YN1 天前
OPC UA 通讯开发笔记 - 基于本地dll文件
windows·笔记
深蓝海拓1 天前
S7-1500学习笔记:用户自定义数据类型(UDT)
笔记·学习·plc
罗罗攀1 天前
PyTorch学习笔记|神经网络的损失函数
人工智能·pytorch·笔记·神经网络·学习
tq10861 天前
价值:社会对劳动所产生的效用增量形成的局部共识
笔记
A923A1 天前
【小兔鲜电商前台 | 项目笔记】第八天
前端·vue.js·笔记·项目·小兔鲜
猹叉叉(学习版)1 天前
【系统分析师_知识点整理】 15.数学计算与知识产权
笔记·软考·知识产权·系统分析师
風清掦1 天前
【江科大STM32学习笔记-10】I2C通信协议 - 10.1 软件I2C读写MPU6050
笔记·stm32·单片机·嵌入式硬件·物联网·学习
MwEUwQ3Gx1 天前
常见Linux权限提升笔记
linux·运维·笔记