+ -
当前位置:首页 → 问答吧 → 令人纠结和不淡定的R14寄存器

令人纠结和不淡定的R14寄存器

时间:2011-01-24

来源:互联网

本篇文章针对的是ARM7系列的指令系统,当
IRQ发生中断异常嵌套时使人纠结的R14寄存器。希望通过本篇文章能让大家更深刻的了解当发生异常时,系统是如何执行,以及R14寄存器的用法和注意事项。
---------------------------------------------------------------------------
1. IRQ中断异常执行过程:
1> 执行用户模式下的程序
2> 发生IRQ中断,硬件将某个地址存入IRQ模式下的R14_irq寄存器,用户模式下的R14未被破坏。
3> IRQ服务程序A执行完毕,将R14_irq寄存器内容减去某个常量后存入PC.
4> 返回到原程序的下一条指令处继续执行

2. IRQ嵌套执行程序时执行过程:
1> 执行用户模式下的程序
2> 发生IRQ中断,硬件将某个地址存入IRQ模式下的R14_irq寄存器,用户模式下的R14未被破坏。
3> 在IRQ服务程序A程序中:
 执行完语句A后又触发了中断,此时程序跳转到IRQ模式下的程序B中执行。
 并将IRQ模式下的程序A中的某个地址B存入R14_irq中(此时把已经把地址A覆盖了,出现了错误)
 执行到IRQ程序B中最后一条语句时,R14¬_irq把它的值放入PC,程序跳转到IRQ程序A中的发生中断的小一条语句处,继续执行。
 当执行到IRQ程序A中最后一条语句时,R14_irq把它的值给PC。
但是,此时令我们纠结的是,R14_irq中的值放的是地址B处的值,因此程序将无法返回到用户模式下的程序中断处的小一条指令处继续执行)


如何解决这个令人纠结的问题呢:
 我们要确保R14¬_irq在发生嵌套时,不再保存任何有意义的值.。
 将R14入栈或者切换到其它处理器模式。

作者: tigerjb   发布时间: 2011-01-24

两个图位置放反了。最下面的图是IRQ中断执行过程。第一个图是IRQ嵌套时执行过程

作者: tigerjb   发布时间: 2011-01-24