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

本文探讨了ARM7系列处理器中IRQ中断异常执行的过程,并深入分析了IRQ嵌套时R14寄存器的使用导致的问题及解决方案。

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

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

Author :tiger-john
WebSite :blog.youkuaiyun.com/tigerjb

Email jibo.tiger@gmail.com

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> 返回到原程序的下一条指令处继续执行

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处的值,因此程序将无法返回到用户模式下的程序中断处的小一条指令处继续执行)

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

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

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值