Warning: file_get_contents(/data/phpspider/zhask/data//catemap/0/assembly/6.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Assembly ARMv6 FIQ,确认中断_Assembly_Arm_Irq - Fatal编程技术网

Assembly ARMv6 FIQ,确认中断

Assembly ARMv6 FIQ,确认中断,assembly,arm,irq,Assembly,Arm,Irq,我正在使用I.mx35 armv6核心处理器。我已将中断62配置为FIQ,安装并调用了我的处理程序。我的处理程序现在只是切换一个输出引脚,这样我就可以用一个作用域测试延迟。使用下面的代码,一旦我触发了FIQ,它就会以最快的速度继续,显然没有被确认。我是通过中断强制寄存器触发FIQ的,所以我确信源代码不会这么快触发它。如果我在FIQ例程中禁用中航工业的中断62,中断只触发一次 我已经阅读了ARM1136JF-S和ARM1136J-S技术参考手册中有关VIC端口的章节,其中涵盖了正确的退出程序。我只

我正在使用I.mx35 armv6核心处理器。我已将中断62配置为FIQ,安装并调用了我的处理程序。我的处理程序现在只是切换一个输出引脚,这样我就可以用一个作用域测试延迟。使用下面的代码,一旦我触发了FIQ,它就会以最快的速度继续,显然没有被确认。我是通过中断强制寄存器触发FIQ的,所以我确信源代码不会这么快触发它。如果我在FIQ例程中禁用中航工业的中断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
我的处理程序返回的很好,如果我在第一次运行后禁用它,系统将恢复正常操作,否则它会不断触发,系统似乎挂起


你认为我的假设是正确的,核心不承认中航工业,或者可能有其他原因触发FIQ?如果核心没有确认中航工业,我需要做什么来确认它?

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