微波EDA网,见证研发工程师的成长!
首页 > 硬件设计 > 嵌入式设计 > ARM中断处理的研究

ARM中断处理的研究

时间:07-12 来源:互联网 点击:

通过将LR_irq压栈来解决的,如程序语句:

但是仍不能排除在保存LR之前中断发生的可能性。要解决上述LR_irq被破坏的问题,就必须切换处理器的模式,常见的是切换到SVC处理模式。在SVC模式中,通过BL调用子程序时会将返回地址保存在LR_SVC之中。此时新中断发生(因为它会将返回地址保存到LR_irq而不是LR_SVC),不会破坏旧中断中子程序返回地址了。有了基于上述的原理分析再来编写可重入性中断的代码就思路清晰了。但是为了保证处理的高效性,尽可能地及早允许中断以缩短延时,在保存完LR_irq和SPSR_irq后,就马上切换到SVC模式中并重新允许中断,如图4所示(虚线是压栈保存,实线是弹栈恢复)。

结合图4中的处理步骤,可以比较清晰地写出可重入中断处理的汇编语言程序:

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top