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

---------------------------------------------------------

Author :tiger-john
WebSite :blog.csdn.net/tigerjb

Email [email protected]

Update -Time :2011-1-21

Tiger声明:本人鄙视直接复制本人文章而不加出处的个人或团体,但不排斥别人转载tiger-john的文章,只是请您注明出处并和本人联系或留言给我3Q

---------------------------------------------------------

本篇文章针对的是ARM7系列的指令系统,当

IRQ发生中断异常嵌套时使人纠结的R14寄存器。希望通过本篇文章能让大家更深刻的了解当发生异常时,系统是如何执行,以及R14寄存器的用法和注意事项。

---------------------------------------------------------------------------

1. IRQ中断异常执行过程:

1> 执行用户模式下的程序

2> 发生IRQ中断,硬件将某个地址存入IRQ模式下的R14_irq寄存器,用户模式下的R14未被破坏

3> IRQ服务程序A执行完毕,将R14_irq寄存器内容减去某个常量后存入PC.

4> 返回到原程序的下一条指令处继续执行

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

2. IRQ嵌套执行程序时执行过程:

1> 执行用户模式下的程序

2> 发生IRQ中断,硬件将某个地址存入IRQ模式下的R14_irq寄存器,用户模式下的R14未被破坏

3> IRQ服务程序A程序中:

l 执行完语句A后又触发了中断,此时程序跳转到IRQ模式下的程序B中执行。

l 并将IRQ模式下的程序A中的某个地址B存入R14_irq中(此时把已经把地址A覆盖了,出现了错误)

l 执行到IRQ程序B中最后一条语句时,R14­_irq把它的值放入PC,程序跳转到IRQ程序A中的发生中断的小一条语句处,继续执行。

l 当执行到IRQ程序A中最后一条语句时,R14_irq把它的值给PC

但是,此时令我们纠结的是,R14_irq中的值放的是地址B处的值,因此程序将无法返回到用户模式下的程序中断处的小一条指令处继续执行)

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

如何解决这个令人纠结的问题呢:

l 我们要确保R14­_irq在发生嵌套时,不再保存任何有意义的值.

l R14入栈或者切换到其它处理器模式。

相关文章: