3238|2

82

帖子

0

TA的资源

一粒金砂(初级)

楼主
 

初学arm问问题-异常返回时PC值的问题 [复制链接]

---------异常返回时PC值的问题---------------
        如果发生IRQ时,则 PC=LR-4
        例如:
                指令A
                指令B
                指令C
                ----
                在执行完毕指令A后,处理器扫描CPSR,发现有IRQ中断,则执行LR=PC+8-4=PC+4
                返回时,执行PC=LR-4=PC(问题1:此时PC是A地址 还是 B地址???)

                我个人感觉应该是B地址,如果A地址的话,那么不就重复执行了一次A指令了吗?
        问题2:如果,我猜测是正确的话,那么在执行A指令之后,PC会“赶紧” +4,先于 进入中断处理程序???
此帖出自ARM技术论坛

最新回复

哦 谢了  呵呵  详情 回复 发表于 2008-8-27 09:21
点赞 关注
 

回复
举报

57

帖子

0

TA的资源

一粒金砂(初级)

沙发
 
由于流水线机制的存在,PC的指针总是指向当前执行的指令后面的第二条,也就是说执行a时,pc指向的是c
当执行完a后,检测中断,如果允许中断,则:
1) 将PC-4 存放到 lr_irq, 这里的PC的值已经更新,指向D了
2) SPSR_irq = CPSR
3)  切换到irq状态
4) 禁止中断
5) 跳转到中断向量表执行子程序

返回时:
1) PC = lr_irq - 4, 算一下就知道是b指令的位置,所以你的推测是对的

这部分的解释详见 arm体系结构与编程 269 页
此帖出自ARM技术论坛
 
 
 

回复

84

帖子

0

TA的资源

一粒金砂(初级)

板凳
 

谢了  呵呵
此帖出自ARM技术论坛
 
 
 

回复
您需要登录后才可以回帖 登录 | 注册

查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/10 下一条
Microchip 直播|利用motorBench开发套件高效开发电机磁场定向控制方案 报名中!
直播主题:利用motorBench开发套件高效开发电机磁场定向控制方案
直播时间:2025年3月25日(星期二)上午10:30-11:30
快来报名!

查看 »

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表