在学习韦老师视频中中断异常部分时候,对于发生中断时需要执行的#保存异现场 #恢复现场 中的“返回”弄不清楚,查阅网络文章后,发现一篇概述我觉得我能理解的一篇如下:
 
重要基础知识:R15(PC)总是指向“正在取指”的指令,而不是指向“正在执行”的指令或正在“译码”的指令。一般来说,人们习惯性约定将“正在执行的指令作为参考点”,称之为当前第一条指令,因此 PC总是指向第三条指令。当 ARM 状态时,每条指令为 4 字节长,所以 PC 始终指向该指令地址加 8 字节的地址,即:PC 值=当前程序执行位置+8;
    而 ADS 中的 pc,是为了调试看着方便而修改过的,它指向的是正在执行的指令,即“真正 pc-8”!
 
1.SWI 和和未定义指令异常中断的返回:
指令地址
A         PC-8  当前指令为 SWI 或未定义指令 此时发生中断.PC 的值还没有更新.
A+4       PC-4  中断时处理器将 PC-4 保存到 LR。       ;lr!
A+8       PC
 
返回时,从发生中断的指令 A(PC-8)的下一条指令 A+4(PC-4)处开始执行,所以直接把 LR 的值赋给 PC 就行了,具体指令为 MOVPC,LR  (PC=A+4=LR)
白话解释:对于 SWI 和未定义指令异常: 发生异常时 pc 没有更新,根据 ARM 的三级流水线原理,pc 没有更新,仍然等于(A+8); lr= pc – 4(这时处理器决定的,无法更改!)即 A+4。
由于这类异常返回后应执行下一条指令(A+4),所以返回时,pc= lr 即可。
 
2.IRQ 和 FIQ 异常中断处理的返回:
指令地址  对应于 PC
A         PC-8      执行此指令完成后(!)查询 IRQ 及 FIQ,如果有中断请求则产生中断.
A+4       PC-4
A+8       PC         ;lr!
(此时 PC 的值已经更新,指向 A+12.将当前 PC-4,即 A+8 )。
保存到 LR.返回时,要接着执行 A+4(LR-4)处的指令,所以返回指令为
SUBSPC, LR,#4(PC=A+4=LR-4)
白话解释:对于普中断和快中断异常,中断必须在一条指令执行完以后被检测到,如正在执行指令甲时发生了中断,不等指令甲执行完是不会处理该中断的,发生异常时 pc 已经更新(A+12); lr= pc – 4(这时处理器决定的,无法更改!)即 A+8 返回后,应执行被中断而没有执行的指令(上面的 A+4),所以返回时,pc = lr-4
 
3,指令预取中止异常中断处理的返回:
指令地址
A     PC-8     执行本指令时发生中断,  
A+4   PC-4     处理器将 A+4(PC-4)保存到 LR.    ;lr!
A+8   PC
 
返回时,发生指令预取中止的指令 A(PC-8)处重新执行,所以返回指令为
SUBSPC, LR,#4(PC=A=LR-4)
白话解释:对于预取指令中止异常,发生预取指令异常时,是在执行时发生的异常,pc 未更新,即 pc= A+8;lr = pc – 4(这时处理器决定的,无法更改!)即 A+4。
由于这类异常返回后应重新执行异常的那个指令(A),所以返回时,pc= lr-4
 
4,数据访问中止异常中断处理的返回:
 
指令地址
A          PC-8    本指令访问有问题的数据,产生中断时,PC 的值已经更新   
A+4        PC-4    中断发生时 PC=A+12,处理器将 A+8(PC-4)保存到 LR.
A+8        PC        ;lr!
 
返回时,要返回到 A 处继续执行,所以指令为 SUBSPC,  LR,#8.(PC=A=LR-8)
白话解释:对于数据访问中止异常,发生数据访问中止异常时,是在执行时访问数据错误导致的异常,pc 已经更新,即 pc= A+12
lr= pc – 4(这时处理器决定的,无法更改!)即 A+8。
由于这类异常返回后应重新执行异常的那个指令(A),所以返回时,pc= lr-8
 
小节:
Ø 引起 PC 更新的原因一种是数据中止,还有就是中断了.
Ø 中断必须是在一条指令执行完毕后才能被检测到,所以它中断的只是还未执行的那条指令(pc - 8),所以 pc= lr – 4;
Ø 与中断相同,SWI 和未定义指令异常也是返回到下一条指令(pc - 4),只是他们在执行时,PC 的值并没有更新,所以 pc= lr;
Ø 预取指令中止异常,也没有发生 pc  更新,但它还得重新执行发生异常的那条指令,所以 pc= lr – 4;
Ø 数据访问中止异常,发生了 pc  更新,并且它也需要重新执行发生异常的那条指令,所以 pc= lr – 8。
如何解释ARM状态与Thumb状态下的FIQ,IRQ,PABT(指令预取终止),DABT(数据预取错误)的返回指令一样: 猜测:thumb的取指是 一次取两条! 这样就可以解释为什么是一样的。但是还不确定。

ARM异常中断返回的几种情况的更多相关文章

  1. ARM体系的异常中断

    在ARM体系中,通常有3种方式控制处理器的流程  1:在正常执行过程中,每执行一条ARM指令,程序计数器寄存器PC的值加四个字节,在每执行一条Thumb指令,程序计数器寄存器PC的值加两个字节,整个过 ...

  2. 2—ARM中的异常中断

    ARM体系中的3种控制程序执行的方式 正常执行过程中,每执行1条ARM指令,PC的值加4个字节:每执行1条Thumb指令,PC的值加2个字节.整个过程按照顺序执行. 通过跳转指令,调到特定的地址开始执 ...

  3. 探讨read的返回值的三种情况

    http://blog.chinaunix.net/uid-23629988-id-3035613.html 今天探讨一个很看似简单的API “read”的返回值问题.read的返回值有哪几个值?每个 ...

  4. try catch finally 中包含return的几种情况,及返回结果

    当当当,兴致勃勃的第二篇博客,散花~ 下面是正题(敲黑板) 第一种情况:在try和catch中有return,finally中没有return,且finally中没有对try或catch中要 retu ...

  5. empty对如下8种情况返回true

    1.strrchr函数 在W3School站点上的注释如下: strrchr() 函数查找字符串在另一个字符串中最后一次出现的位置,并返回从该位置到字符串结尾的所有字符.如果成失败,否则返回 fals ...

  6. ARM异常中断处理

    ARM异常中断处理 在ARM体系中,通常有以下3种方式控制程序的执行流程: 在正常程序执行过程中,每执行一条ARM指令,程序计数器寄存器(PC)的值加4个字节:每执行一条Thumb指令,程序计数器寄存 ...

  7. Linux内核抢占与中断返回【转】

    转自:http://blog.csdn.net/tommy_wxie/article/details/7425728 版权声明:本文为博主原创文章,未经博主允许不得转载. [html] view pl ...

  8. 【ARM】arm异常中断处理知识点

    ARM处理器7种类型异常 按优先级从高到低的排列如下: 复位异常(Reset) 数据异常(Date Abort) 快速中断异常(FIQ) 外部中断异常(IRQ) 预取异常(Prefetch Abort ...

  9. s3c2440裸机-异常中断(一. 异常、中断的原理与流程)

    1.异常中断概述 在arm架构的处理器中,cpu有7中工作模式,2中工作状态. 1.CPU模式(Mode): 7种Mode: 除了usr/sys,其他5种都是异常模式.我们知道中断属于异常的2中,中断 ...

随机推荐

  1. 【CV论文阅读】Going deeper with convolutions(GoogLeNet)

    目的: 提升深度神经网络的性能. 一般方法带来的问题: 增加网络的深度与宽度. 带来两个问题: (1)参数增加,数据不足的情况容易导致过拟合 (2)计算资源要求高,而且在训练过程中会使得很多参数趋向于 ...

  2. wpf slider进度条的样式模板,带有进度颜色显示

    效果图: 仅仅需在前台加上这段代码就可以: <UserControl.Resources> <!--笔刷--> <LinearGradientBrush x:Key=&q ...

  3. Android系统编译时遇到的几个.mk的疑惑。

    在Android4.2的源代码Build/prduct_config.mk里面遇到几个疑惑: # Convert a short name like "sooner" into t ...

  4. [WebGL入门]十二,模型数据和顶点属性

    注:文章译自http://wgld.org/,原作者杉本雅広(doxas),文章中假设有我的额外说明,我会加上[lufy:].另外.鄙人webgl研究还不够深入,一些专业词语.假设翻译有误.欢迎大家指 ...

  5. 设计模式(一)单例模式:创建模式 ASPNET CORE WEB 应用程序的启动 当项目中 没有STARTUP.CS 类如何设置启动 配置等等

    设计模式(一)单例模式:创建模式 先聊一下关于设计的几个原则(1)单一原则(SRP):一个类应该仅有一个引起它变化的原因 :意思就是 (一个类,最好只负责一件事情,并且只有一个引起它变化的原因(2)开 ...

  6. webrtc 视频 demo

    webrtc 视频 demo webrtc网上封装的很多,demo很多都是一个页面里实现的,今天实现了个完整的 , A 发视频给 B A webrtc.html作为offer <!DOCTYPE ...

  7. 创业公司十分钟简单搭建GIT私有库

    欢迎关注老码农的微信公共账号,与CSDN博客同步 一.背景 小公司.协同开发的人不多,建gitlab比較麻烦,仅仅须要在Server端建立一个简单的git共享库就OK. 二.建立仓库 Server端: ...

  8. 7.2 高速缓冲存储器-Cache

    高速缓冲存储器:Cache.Cache的功能是提高CPU数据的输入和输出的速率.CPU的速度与主存的速度之间有巨大的差异.主存的存取时间.存取速度要比CPU的速度要慢了很多倍.为了调和它们之间的巨大速 ...

  9. php获得文件的属性

    PHP获取文件属性可以用到多种函数,来实现我们对文件各种不同信息的获取需求.在这里我们就简单的介绍了这些获取方式的实现方法. 详细解读PHP获取远程图片技巧 详细介绍PHP读取目录函数 如何运用相关函 ...

  10. linux修改yum源

    在自己安装的CentOS6.5中使用yum安装软件,总是提示404错误信息,百度后发现原来要设置yum源. 在安装完CentOS后一般需要修改yum源,才能够在安装更新rpm包时获得比较理想的速度.国 ...