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

冀博 2011-01-24 10:34:57
本篇文章针对的是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入栈或者切换到其它处理器模式。
...全文
517 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
AI沉默 2012-04-18
  • 打赏
  • 举报
回复
哦,故事的经过是这样的,呵呵
tangmingyou 2012-03-12
  • 打赏
  • 举报
回复
咋没人解答呢
shyokou 2011-01-27
  • 打赏
  • 举报
回复
难道 IRQ 处理中允许重入嵌套吗, 除非 IRQ 处理程序是按照允许重入嵌套设计的, 否则就不该允许重入嵌套呀 ...

[Quote=引用楼主 tigerjb 的回复:]
本篇文章针对的是ARM7系列的指令系统,当
IRQ发生中断异常嵌套时使人纠结的R14寄存器。希望通过本篇文章能让大家更深刻的了解当发生异常时,系统是如何执行,以及R14寄存器的用法和注意事项。
---------------------------------------------------------------------------
1. IRQ中断异常执行过程:
1> 执行用户……
[/Quote]
冀博 2011-01-24
  • 打赏
  • 举报
回复
两个图位置放反了。最下面的图是IRQ中断执行过程。第一个图是IRQ嵌套时执行过程

21,453

社区成员

发帖
与我相关
我的任务
社区描述
汇编语言(Assembly Language)是任何一种用于电子计算机、微处理器、微控制器或其他可编程器件的低级语言,亦称为符号语言。
社区管理员
  • 汇编语言
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧