FIQ和IRQ的区别
来源:互联网 发布:淘宝官网下载安装2016 编辑:程序博客网 时间:2024/05/16 14:43
文章1-FIQ和IRQ区别
一般的中断控制器里我们可以配置与控制器相连的某个中断输入是FIQ还是IRQ,所以一个中断是可以指定为FIQ或者IRQ的,为了合理,要求系统更快响应,自身处理所耗时间也很短的中断设置为FIQ,否则就设置了IRQ。
如果该中断设置为了IRQ,那么当该中断产生的时候,中断处理器通过IRQ请求线告诉ARM,ARM就知道有个IRQ中断来了,然后ARM切换到IRQ模式运行。类似的如果该中断设置为FIQ,那么当该中断产生的时候,中断处理器通过FIQ请求线告诉ARM,ARM就知道有个FIQ中断来了,然后切换到FIQ模式运行。
简单的对比的话就是FIQ比IRQ快,为什么快呢?
ARM的FIQ模式提供了更多的banked寄存器,r8到r14还有SPSR,而IRQ模式就没有那么多,R8,R9,R10,R11,R12对应的banked的寄存器就没有,这就意味着在ARM的IRQ模式下,中断处理程序自己要保存R8到R12这几个寄存器,然后退出中断处理时程序要恢复这几个寄存器,而FIQ模式由于这几个寄存器都有banked寄存器,模式切换时CPU自动保存这些值到banked寄存器,退出FIQ模式时自动恢复,所以这个过程FIQ比IRQ快.
FIQ比IRQ有更高优先级,如果FIQ和IRQ同时产生,那么FIQ先处理。
在symbian系统里,当CPU处于FIQ模式处理FIQ中断的过程中,预取指令异常,未定义指令异常,软件中断全被禁止,所有的中断被屏蔽。所以FIQ就会很快执行,不会被其他异常或者中断打断,所以它又比IRQ快了。而IRQ不一样,当ARM处理IRQ模式处理IRQ中断时,如果来了一个FIQ中断请求,那正在执行的IRQ中断处理程序会被抢断,ARM切换到FIQ模式去执行这个FIQ,所以FIQ比IRQ快多了。
另外FIQ的入口地址是0x1c,IRQ的入口地址是0x18。
原文地址:http://www.cublog.cn/u2/83842/showart_1404725.html
文章2-ARM的FIQ为何比IRQ快:
1。FIQ的优先级比IRQ高。
2。FIQ模式下,比IRQ模式多了几个独立的寄存器。
不要小看这几个寄存器,ARM在编译的时候,如果你FIQ中断处理程序足够用这几个独立的寄存器来运作,它就不会进行通用寄存器的压栈,这样也省了一些时间。
3。FIQ的中断向量地址在0x0000001C,而IRQ的在0x00000018。(也有的在FFFF001C以及FFFF0018)
写过完整汇编系统的都比较明白这点的差别,18只能放一条指令,为了不与1C处的FIQ冲突,这个地方只能跳转,而FIQ不一样,1C以后没有任何中断向量表了,这样可以直接在1C处放FIQ的中断处理程序,由于跳转的范围限制,至少少了一条跳转指令。
4。IRQ和FIQ的响应延迟有区别
IRQ的响应并不及时,从Verilog仿真来看,IRQ会延迟几个指令周期才跳转到中断向量处,看起来像是在等预取的指令执行完。FIQ的响应不清楚,也许比IRQ快。
原文地址:http://blog.csdn.net/masxcy/archive/2009/06/26/4301723.aspx
- FIQ和IRQ的区别
- FIQ和IRQ的区别
- FIQ和IRQ区别
- FIQ和IRQ区别
- FIQ和IRQ区别
- FIQ和IRQ区别
- FIQ和IRQ区别
- FIQ和IRQ区别
- IRQ和FIQ中断的区别
- IRQ和FIQ中断的区别
- IRQ和FIQ中断的区别
- IRQ和FIQ中断的区别
- IRQ与FIQ的区别
- 嵌入式学习之IRQ和FIQ之间的区别
- FIQ和IRQ的区别及CPU实现
- IRQ,FIQ区别FAQ
- ARM的SVC、IRQ和FIQ模式。
- FIQ和IRQ
- 直接使用SMTP协议命令而在程序中实现电子邮件传送
- 获取硬件信息
- Spring AOP 之 RegexpMatchDemo
- Spring AOP 之 ThrowAdviceDemo
- 不怕你不笑 就怕你不倒
- FIQ和IRQ的区别
- Spring AOP 之 ThrowAdviceDemo2
- 字符串处理是许多程序中非常重要的一部分,它们可以用于文本显示,数据表示,查找键和很多目的.在Unix下,用户可以使用正则表达式的强健功能实现这些 目的,从Java1.4起,Java核心API就引入了java.util.regex程序包,它是一种有价值的基础
- Spring AOP 之 ThrowAdviceDemo3
- RAII
- 集合类说明及区别
- 几个数据库查询问题
- dos批处理命令详解
- 数据库实验题答案