免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1882 | 回复: 2
打印 上一主题 下一主题

[开发环境] 请问,异常的返回地址,为什么有的减4,有的减8,有的不减? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-03-26 15:51 |只看该作者 |倒序浏览
减4的,FIQ和IRQ,可以理解,因为PC提前8,恢复的时候减去4,正好是下一条指令的地址。
可是,软中断的指令的返回地址,为什么是 R14,返回指令: movs pc,r14_svc
为什么不减呢?
取数中止为什么返回地址是 R14-#8 ?这不是回到原指令了吗?

Orz

论坛徽章:
0
2 [报告]
发表于 2012-03-28 16:27 |只看该作者
fiq,irq,中断发生时,程序计数器pc的值已经更新,它指向当前指令后面的di3条,中断发生后,cpu将(pc-4)保存到lr中,(pc-4)指向当前指令后的第二条,所以中断处理返回操作是:SUBS PC,LR,#4.(你这个就已经理解错了)
SWI:当swi发生时,pc的值还未更新,指向当前指令后的第二条,中断发生后,cpu将(pc-4)保存到lr中,返回式:mov pc,lr
数据访问中止异常:中断发生时,pc已经更新,指向当前指令第三天,但不同的是:数据访问中断处理完后要返回到当前发生中断的指令出,所以。。。

看到你的问题,准们看了下书,哈哈

论坛徽章:
0
3 [报告]
发表于 2012-03-29 10:17 |只看该作者
暴风lay 发表于 2012-03-28 16:27
fiq,irq,中断发生时,程序计数器pc的值已经更新,它指向当前指令后面的di3条,中断发生后,cpu将(pc-4) ...


Orz
膜拜
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP