打印
[ZLG-ARM]

ARM 7的IRQ中断嵌套

[复制链接]
2222|4
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
xiaoxin1986|  楼主 | 2010-3-14 23:08 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
ARM 7的IRQ中断嵌套:
一、引用的周立功的《ARM微控制器基础与实战(第2版)》

1、当进入 IRQ 后,当要退出中断时,对向量地址寄存器写 0,通知VIC 中断结束。才会响应新的IRQ中断。
2、汇编程序示例
       IRQ_EINT0
                     … … …
                     … … …
                     … … …
                     LDR       R0,= VICVectAddr             (1)
                     MOV      R1,# 0                              (2)
                     STR        R1,[R0]                            (3)
                     SUBS      PC,LR,# 4        ;IRQ中断返回           (4)

            END
3、C语言程序示例
       void _irq IRQ_Eint3(void)
       {
… … …
                 … … …
        … … …

       VICVectAddr = ox00;
}

二、分析推断
1、C语言程序最终也会由编译器编译成汇编程序
2、若按汇编程序示例,IRQ中断的嵌套是发生在(3)执行后,而(4)没执行时。因若(3)没执行,则处理器不会响应新的IRQ中断。若(4)执行则已IRQ中断返回。
3、那么要想从时序上彻底禁止IRQ中断嵌套,则应:
       汇编程序示例
       IRQ_EINT0
                     MRS       R0,CPSR                          ;中断模式的CPSR
                     ORR      R0, R0, # NoInt(ox80)
MSR       CPSR_c,R0                       ;中断模式的CPSR的 I = 1,禁止IRQ中断
                     … … …
                     … … …
                     LDR       R0,= VICVectAddr             (1)
                     MOV      R1,# 0                              (2)
                     STR        R1,[R0]                            (3)
                     SUBS      PC,LR,# 4        ;IRQ中断返回           (4)

            END

     这样只有当(4)执行完后,即IRQ中断返回后,才重新开放中断。从而彻底禁止了IRQ中断嵌套。

相关帖子

沙发
寂寞男孩| | 2010-3-14 23:39 | 只看该作者
不懂,帮顶了

使用特权

评论回复
板凳
贾君鹏子| | 2010-3-15 00:23 | 只看该作者
在搞ARM9

使用特权

评论回复
地板
xiaoxin1986|  楼主 | 2010-3-16 23:27 | 只看该作者
这个没人知道吗?自己顶一个

使用特权

评论回复
5
寂寞男孩| | 2010-3-16 23:43 | 只看该作者
还没开始搞ARM,帮顶了

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

176

主题

1487

帖子

0

粉丝