`
sony-soft
  • 浏览: 1028029 次
文章分类
社区版块
存档分类
最新评论

中断延迟时间的衡量

 
阅读更多

中断延迟

------------------------------------------------------------

Author :tiger-john
WebSite :blog.csdn.net/tigerjb

Email jibo.tiger@gmail.com

Update-Time : 2011217日星期四

Tiger声明:本人鄙视直接复制本人文章而不加出处的个人或团体,

但不排斥别人转载tiger-john的文章,只是请您注明出处并和本人联

系或留言给我3Q

-------------------------------------------------------------

中断是为了从系统中得到更好响应的一个工具。everyone wants to know :系统对每个中断的响应速度到底有多快?

中断延迟就是系统响应一个中断所需要的时间,在一些情况下,如果系统对中断处理不及时,系统可能会显得非常迟钝甚至出现崩溃的现象。

1. 最小中断延迟:

FIQIRQ的最小中断延迟是请求通过同步器的时间Tsyncmin加上Tfiq (4个处理器周期)

2. 最大中断延迟

FIQ使能时,最坏情况是正在执行一条装载所有寄存器的指令LDM(它耗时最长),同时发生了FIQ和数据中止异常,在响应FIQ中断之前要先把正在执行的指令完成,然后先进入数据中止异常,再马上跳转到FIQ异常入口,所以延迟时间包含:

l Tsyncmax:请求通过同步器的最长时间,为2个处理器周期(由内核决定)

l Tldm:最长的指令执行需要的时间。Tldm在零等待状态系统中的执行时间为20个周期。

(注:此处是特殊情况,一般的ARM7内核的芯片的存储器系统比内核速度慢,造成其不是零等待的)

l Texc:数据中止入口的时间,Texc3个周期(由内核决定)

l Tfiq:FIQ入口的时间。Tfiq2个周期(由具体的内核决定)

FIQ总的延迟时间=Tsyncmax+Tldm+Texc+Tfiq=27个周期。

(例如:在40MHZ处理器时钟中,最大延迟时间略少于0.7us。在此时间结束后,ARM7执行位于0x1c处的指令。

注:最大的IRQY延迟时间与之相似,但必须考虑到这样一种情况,当更高优先级的FIQIRQ同时申请时,IRQ要延迟到FIQ处理程序允许IRQ中断时才处理(可能需要对中断控制器进行相应的操作)。IFQ延迟时间也要相应增加。

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics