ARMv6 FIQ,确认中断

时间:2010-05-27 17:29:37

标签: assembly arm irq

我正在使用i.mx35 armv6核心处理器。我将Interrupt 62配置为FIQ,并安装了我的处理程序并进行了调用。我的处理程序此刻只是切换输出引脚,因此我可以使用示波器测试延迟。使用下面的代码,一旦我触发FIQ,它就会尽可能快地继续,显然没有得到承认。我通过中断强制寄存器触发FIQ,因此我确信源不会快速触发它。如果我在FIQ例程中禁用AVIC中的中断62,则中断仅触发一次。

我已经阅读了ARM1136JF-S和ARM1136J-S技术参考手册中关于VIC端口的章节,它涵盖了正确的退出程序。我只有一个FIQ处理程序,所以我不需要分支。我不明白的一句话是:

STR R0, [R8,#AckFinished]

我不确定AckFinished应该是什么或该命令应该做什么。

我的FIQ处理程序如下:

ldr r9, IOMUX_ADDR12
ldr r8, [r9]
orr r8, #0x08                        @ top LED
str r8,[r9]                          @turn on LED
bic r8, #0x08                        @ top LED
str r8,[r9]                          @turn off LED

subs pc, r14, #4
IOMUX_ADDR12:   .word 0xFC2A4000 @remapped IOMUX addr

我的处理程序返回正常,如果我在第一次运行后禁用它,则恢复正常的系统操作,否则它会不断触发,系统似乎挂起。

您是否认为我的假设是正确的,核心不承认AVIC或者是否有其他原因导致此FIQ触发?如果核心没有确认AVIC,我需要做什么来承认它?

1 个答案:

答案 0 :(得分:2)

正如您所说,看起来您没有从产生中断的一个或两个外设或VIC本身清除待处理的中断。