中断延迟时间的衡量

中断延迟

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

Author :tiger-john
WebSite :blog.youkuaiyun.com/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延迟时间也要相应增加。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值