FIQ和IRQ是两种不同类型的中断,ARM为了支持这两种不同的中断,提供了对应的叫做FIQ和IRQ处理器模式(ARM有7种处理模式)。

一般的中断控制器里我们可以配置与控制器相连的某个中断输入是FIQ还是IRQ,所以一个中断是可以指定为FIQ或者IRQ的,为了合理,要求系统更快响应,自身处理所耗时间也很短的中断设置为FIQ,否则就设置了IRQ。

如果该中断设置为了IRQ,那么当该中断产生的时候,中断处理器通过IRQ请求线告诉ARM,ARM就知道有个IRQ中断来了,然后ARM切换到IRQ模式运行。类似的如果该中断设置为FIQ,那么当该中断产生的时候,中断处理器通过FIQ请求线告诉ARM,ARM就知道有个FIQ中断来了,然后切换到FIQ模式运行。

简单的对比的话就是FIQ比IRQ快,为什么快呢?

1:ARM的FIQ模式提供了更多的banked寄存器,r8到r14还有SPSR,而IRQ模式就没有那么多,R8,R9,R10,R11,R12对应的banked的寄存器就没有,这就意味着在ARM的IRQ模式下,中断处理程序自己要保存R8到R12这几个寄存器,然后退出中断处理时程序要恢复这几个寄存器,而FIQ模式由于这几个寄存器都有banked寄存器,模式切换时CPU自动保存这些值到banked寄存器,退出FIQ模式时自动恢复,所以这个过程FIQ比IRQ快。

2:FIQ比IRQ有更高优先级,如果FIQ和IRQ同时产生,那么FIQ先处理。

3:FIQ的中断向量地址在0x0000001C,而IRQ的在0x00000018。(也有的在FFFF001C以及FFFF0018),写过完整汇编系统的都比较明白这点的差别,18只能放一条指令,为了不与1C处的FIQ冲突,这个地方只能跳转,而FIQ不一样,1C以后没有任何中断向量表了,这样可以直接在1C处放FIQ的中断处理程序,由于跳转的范围限制,至少少了一条跳转指令。

4:IRQ和FIQ的响应延迟有区别

IRQ的响应并不及时,从Verilog仿真来看,IRQ会延迟几个指令周期才跳转到中断向量处,看起来像是在等预取的指令执行完。FIQ的响应不清楚,也许比IRQ快。

中断延迟:从外部中断请求信号发出到执行对应的中断服务程序ISR的第一条指令所需要的时间。通过软件程序设计来缩短中断延迟的方法有:中断优先级和中断嵌套。

IRQ和FIQ中断的区别相关推荐

  1. 控制IRQ和FIQ中断的编译器内部函数 - 基于Keil MDK

    置顶/星标公众号,不错过每一条消息 本文是一篇偏向底层的内容. 1.写在前面 编译器内部函数__disable_irq.__enable_irq.__disable_fiq和__enable_fiq用 ...

  2. IRQ中断与FIQ中断的区别

    在学习嵌入式的时候中断是我们必须要了解的东西. 首先我们要知道什么是中断,中断的概念(可看可不看,重要的是理解)是指半中间发生阻隔.停顿或故障而断开.其实中断也是异常的一种,只是是一种人为可控的异常. ...

  3. fiq中断的入口地址_FIQ和IRQ区别

    FIQ 和 IRQ 区别 FIQ 和 IRQ 是两种不同类型的中断, ARM 为了支持这两种不同 的中断,提供了对应的叫做 FIQ 和 IRQ 处理器模式( ARM 有 7 种处 理模式) .一般的中 ...

  4. fiq中断的入口地址_ARM中断模式(IRQ)和快速中断模式(FIQ)区别比较

     概念 IRQ(Interrupt Request):指中断模式. FIQ(Fast Interrupt Request):指快速中断模式. IRQ与FIQ是ARM处理器的两种不同编程模式(ARM有7 ...

  5. IRQ与FIQ的区别

    http://www.myir-tech.com/resource/503.asp IRQ(Interrupt Request):指中断模式. FIQ(Fast Interrupt Request): ...

  6. ARM 中断--IRQ and FIQ配置--外部配置

    ARM 中断--IRQ and FIQ配置--外部配置 中断分为外部中断和定时器中断: 中断源都是有一个触发条件,条件满足就会产生中断.不同的中断源触发条件不一样 ARM中中断分为两种:FIQ(fas ...

  7. fiq中断的入口地址_ARM 之FIQ(快速中断) IRQ(中断)

    IRQ,FIQ定义:  这就是个普通中断,当我们程序定义了该中断,并且在程序运行的时候产生了IRQ中断,则此时的芯片是这样运行的------中断处理器吧利用IRQ请求线来高速ARM,ARM就知道有个I ...

  8. fiq中断的入口地址_嵌入式技巧:ARM的三种中断调试方法介绍

    嵌入式软件开发流程 参照嵌入式软件的开发流程.第一步:工程建立和配置.第二步:编辑源文件.第三步:工程编译和链接.第四步:软件的调试.第五步:执行文件的固化. 在整个流程中,用户首先需要建立工程并对工 ...

  9. fiq中断的入口地址_uboot中添加FIQ中断及相关问题

    本文主要说明了在uboot中添加FIQ中断时遇到的问题以及对应的解决办法. 首先交代一下项目的软硬件环境.硬件方面,使用s3c2440作为主控芯片,外接串口.网卡等设备.软件方面,主控芯片上电后运行u ...

最新文章

  1. 计算机基础知识自考真题,自考《计算机应用基础》基础试题
  2. 【Linux 内核】进程管理 task_struct 结构体 ③ ( real_parent 字段 | parent 字段 | group_leader 字段 | real_cred、cred字段 )
  3. 24小时临时邮箱_免费临时邮箱和接码平台
  4. NYOJ 927 The partial sum problem 【DFS】+【剪枝】
  5. 央视-腾讯发布报告:九成受访者认为AI 距离自己并不遥远
  6. 计算机跨考医学检验技术,医学检验技术考研可以考哪些专业?
  7. nginx应用geoip模块,实现不同地区访问不同页面的需求(实践版)
  8. 【一天一个C++小知识】010.malloc/free和new/delete
  9. 开发服务器 安装 centos 8 无法进入图形安装界面 X startup failed falling back to text mode
  10. PCB集成元件封装库下载推荐
  11. 流畅的Python笔记
  12. 91手机助手官网iPhone版 v5.6.1 官方版
  13. 证券公司业务部门深度全解
  14. 为web-polygraph添加user_agent和add_headers配置变量
  15. 内窥镜去反光的论文整理(转)
  16. python 操作excel笔记
  17. 无法完成windows正版认证
  18. 联想模拟器安装激活面具magisk教程
  19. python之客户流失预警
  20. ionic自定义图标(ion-icon)

热门文章

  1. ARM中的紧耦合内存(TCM)
  2. 遍历$.each()和$().each()用法
  3. 作为一个准研究生,怎样才能在研究生阶段不虚度?
  4. Java 第5天 经典算法之冒泡排序
  5. 如何裁剪图片中不要的部分?这个裁剪方法很好用
  6. PCL中利用KD-Tree搜索空间点云最临近点源码
  7. 微信小程序-一个跑步app
  8. 幸福和不幸福是对比出来的
  9. 机器学习所需要的高数知识
  10. LL(1)语法分析器