原创 向量中断与非向量中断的区别

2012-8-10 13:39 8106 22 26 分类: 消费电子

作者:下家山(请尊重原创,转载请注明:上海索漫科技培训教材http://www.xiajiashan.com )

向量,即指有方向的量。这里所说的方向就是向量地址。

向量中断——由硬件提供中断服务程序入口地址;

非向量中断——由软件件提供中断服务程序入口地址。

上面提到的中断向量表:

Reset中断向量地址是0x00000000,那么当复位中断发生时,程序自动跳到0x00000000开始的地址执行。这一过程由硬件实现。

当定时器中断发生时,程序自动跳到0x00000018开始的位置执行。因为该地址是IRQ地址,IRQ不同于Reset,Reset只有一个,但IRQ有很多个。所以,程序跳到0x00000018时还要进行分支选择,那么怎么选择呢?

最开始,0x00000018是从VICVectAddr寄存器中找到当前中断服务程序地址执行的,那么向量中断和非向量中断,该选哪个呢?

ARM中断核(PrimeCell)规定所有“非向量中断”共用到“默认向量地址寄存器”中。

xiajiashan_0917_1.jpeg

同时规定,“向量中断”地址保存在“向量地址寄存器0-15”中。

xiajiashan_0917_2.jpeg

所以,当IRQ中断发生时,ARM中断核(PrimeCell)会到16个IRQ solt中查找,如果没有找到则装载“默认向量地址寄存器”中的地址到”向量地址寄存器”中。

xiajiashan_0917_3.jpeg

其实,可以把非向量中断理解成优先级最低的向量中断,因为在ARM中断核(PrimeCell)从“向量地址寄存器”读取地址时,是先扫描(Scan)整个IRQ slot,如果没有找到则无条件的装载“默认向量地址寄存器”的值。这个值就是非向量IRQ中断服务程序入口地址。

【By 下家山 Q群 75303301        上海松江文汇路928号258室    松江大学城

上海索漫科技  http://www.xiajiashan.com  专注嵌入式(ARM7,Cortex-M0,Cortex-M3,ARM9,linux)培训】

可以这么理解,向量IRQ有16个地址,而非向量IRQ只有一个地址。

疑问:可以设置多个非向量IRQ吗,怎么设置,中断发生后怎么处理?

答案:可以同时设置两个(两个以上)的非向量IRQ,但是这些非向量IRQ共用一个中断服务程序入口地址,但中断发生后,由软件通过IRQ状态寄存器判断当前发生的哪个IRQ中断。(IRQ状态寄存器不区分是向量IRQ还是非向量IRQ)

写于上海松江

作者:下家山(请尊重原创, 转载请注明)  http://www.xiajiashan.com,有什么问题可与我联系:ximenpiaoxue4016@sina.com

文章评论4条评论)

登录后参与讨论

用户1586985 2011-12-16 16:22

你所谓的非向量中断,其实也是有向量的,只不过是多个中断共用一个向量,如果真没有向量的话,中断该如何找入口呢?

用户1071866 2010-12-28 17:08

中断的特性怎么能这么分呢,HAL需要好好学学啊,只有中断向量,没有向量中断的说法

用户1210730 2010-9-20 09:09

学习了

用户1516406 2010-9-19 17:37

好深刻啊,真的事一语中的。
相关推荐阅读
用户1037328 2016-04-17 17:59
好的理论可以避免犯错——读《丈量世界》有感!
     《丈量世界》,早就因为仰慕高斯而想看这本书      1.殊途同归      这本书写的是高斯和洪堡两个人,为什么要把这两个人放在一起写呢?因为高斯是一个宅男,不喜欢什么旅游,考察!他觉得...
用户1037328 2016-04-05 09:10
叛逆在爱因斯坦性格中的重要性(一)
叛逆在爱因斯坦性格中的重要性(一) 《爱因斯坦传》读书笔记      昨天晚上,读完了2016年书单的第二部书,《爱因斯坦传》。我想梳理一下自己读这本书的收获,或者说感悟!在读这...
用户1037328 2016-04-05 09:09
叛逆在爱因斯坦性格中的重要性(二)
叛逆在爱因斯坦性格中的重要性(二) 《爱因斯坦传》读书笔记                                四  叛逆性 在爱因斯坦的同时期科学家中,我想比他IQ...
用户1037328 2014-07-09 19:55
RTEMS系统时钟原理
作者,下家山(转载请注明作者及出处,请尊重原创)   专注嵌入式(ARM7,Cortex-M0,Cortex-M3,ARM9,linux)培训 一:从应用看原理      每个...
用户1037328 2014-07-09 19:47
RTEMS在S3C2410上的移植(一)
作者:下家山(转载,请注明) 1:RTEMS开发环境建立 1.1开发环境建立前的准备工作 因为RTEMS开发环境主要用的是GNU的工具链,所以需要一台装有Linux的HOST. 1.2...
用户1037328 2014-07-09 19:45
深入浅出学Makefile<三,如何自动生成Makefile>
(请尊重原创,转载请注明,作者:下家山) 五: 运行make编译得到可执行文件 root@parson-desktop:/home/parson/tmp/automk# make gcc ...
我要评论
4
22
关闭 站长推荐上一条 /2 下一条