令人纠结和不淡定的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入栈或者切换到其它处理器模式。
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
相关阅读 更多
热门阅读
-
office 2019专业增强版最新2021版激活秘钥/序列号/激活码推荐 附激活工具
阅读:74
-
如何安装mysql8.0
阅读:31
-
Word快速设置标题样式步骤详解
阅读:28
-
20+道必知必会的Vue面试题(附答案解析)
阅读:37
-
HTML如何制作表单
阅读:22
-
百词斩可以改天数吗?当然可以,4个步骤轻松修改天数!
阅读:31
-
ET文件格式和XLS格式文件之间如何转化?
阅读:24
-
react和vue的区别及优缺点是什么
阅读:121
-
支付宝人脸识别如何关闭?
阅读:21
-
腾讯微云怎么修改照片或视频备份路径?
阅读:28