嵌入式系统-第五章-异常及编程课件.ppt
- 【下载声明】
1. 本站全部试题类文档,若标题没写含答案,则无答案;标题注明含答案的文档,主观题也可能无答案。请谨慎下单,一旦售出,不予退换。
2. 本站全部PPT文档均不含视频和音频,PPT中出现的音频或视频标识(或文字)仅表示流程,实际无音频或视频文件。请谨慎下单,一旦售出,不予退换。
3. 本页资料《嵌入式系统-第五章-异常及编程课件.ppt》由用户(三亚风情)主动上传,其收益全归该用户。163文库仅提供信息存储空间,仅对该用户上传内容的表现方式做保护处理,对上传内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知163文库(点击联系客服),我们立即给予删除!
4. 请根据预览情况,自愿下载本文。本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
5. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007及以上版本和PDF阅读器,压缩文件请下载最新的WinRAR软件解压。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 嵌入式 系统 第五 异常 编程 课件
- 资源描述:
-
1、第五章第五章 异常及编程异常及编程5.1 ARM的异常的异常5.2 复位及编程复位及编程5.3 SWI中断处理程序中断处理程序5.4 FIQ和和IRQ中断处理程序中断处理程序5.1 ARM的异常的异常 程序正常执行流程中,程序计数器在其地址范围内连续增加,还可以跳转至附近程序标号或跳转并链接到子程序。当该常规执行流程被转向到启用处理器处理内部或外部资源产生的事件时,即发生了处理器异常。l外部产生的中断;l处理器试图执行一个未定义的指令;l访问有特权的操作系统函数。处理此类异常时,有必要保护处理器先前的状态,以保证在完成相应的异常处理例程后能够恢复产生异常时程序运行的状态,使其继续执行。异常异常
2、 说说 明明复位在处理器复位管脚有效时发生。该异常仅在处理器上电时或上电后的复位时才发生。可通过跳转到复位向量(0 x0000)来完成软复位。未定义指令在处理器或协处理器均不能识别当前指令时发生。软件中断(SWI)这是一个用户定义的同步中断指令。它使得在USER模式下运行的程序能够请求在Supervisor模式下运行的特权操作,如:RTOS函数等。预取指中断在处理器试图执行一个未取指令时发生,因为地址非法。数据中断在数据传送指令试图在非法地址存储数据时发生。IRQ在处理器外部中断引脚低电平有效且CPSR的I位为0时发生。FIQ在处理器外部中断引脚低电平有效且CPSR的F位为0时发生。ARM处理
3、器模式处理器模式处理器模式处理器模式说说 明明备备 注注USER正常程序运行的工作模式不能直接切换到其它模式特权模式SYS用于支持操作系统的特权任务等可直接切换到其它模式异常模式SVC操作系统使用的一种保护模式在系统重启重启和复位复位时,才进入此模式FIQ快速中断请求处理只有在FIQ异常响应时,才进入此模式IRQ中断请求处理只有在IRQ异常响应时,才进入此模式ABT用于虚拟内存和存储器保护在ARM7内核中没有用UND支持软件仿真的硬件协处理器只有在未定义指令异常响应时,才进入此模式ARM异常处理过程异常处理过程ARM产生异常时,在任何情况下处理异常的方法都是一样的,即:(1)通过将PC拷贝到R
4、14_exc以及将CPSR拷贝SPSR_exc来保存当前的状态(exc表示异常类型)。(2)将处理器操作模式改变为适当的异常模式。(3)禁用中断。(4)将PC强制变为00H1CH范围内某个与异常类型有关的特殊值(向量地址)。这个向量地址是指向异常处理程序的转移指令也即开始执行异常处理程序。从异常处理程序的返回从异常处理程序的返回从异常返回的方法取决于该异常处理程序使用不使用堆栈操作。通常情况下,异常处理的返回必须:l从SPSR_exc恢复CPSR;l使用R14_exc(LR)中的返回地址恢复程序计数器PC。l不必从复位处理程序返回,因为复位处理程序直接执行主代码。如果异常处理程序使用了堆栈,可
5、以通过使用一条装载多个带限定符的指令来返回。LDMFDSP!,R0R12,PC 限定符指定从SPSR_exc恢复CPSR。从从SWI和未定义指令异常处理程序返回和未定义指令异常处理程序返回 SWI和未定义指令异常是由指令本身造成的,因此,处理异常时,处理器将(PC-4)存储在R14_exc中。因而使R14_exc指向下一条要执行的指令。要从R14中恢复程序计数器,则使用:MOVS PC,R14从处理程序返回控制权。将返回地址推入堆中并在返回时将其弹出的处理程序入口和出口代码为:STMFD SP!,reglist,R14;.LDMFD SP!,reglist,PC 从从FIQ和和IRQ中断中断处
6、理程序返回处理程序返回执行完每一条指令后,处理器检测中断管脚是否为 LOW(电平),以及 CPSR中断禁用位是否为清除。结果,仅在程序计数器被更新后才发生 IRQ 或 FIQ 异常。处理器将(PC-4)存储在R14_exc中。使R14_exc指向发生异常时尚未完成的一条指令。处理程序完成后,必须从 R14_exc指向的上一条指令处继续运行。该继续执行地址较R14_exc中的地址少一个字(四个字节),因此,其返回指令为:SUBS PC,R14,#4将返回地址压入栈中并在返回时将其弹出的处理程序入口和出口代码为:SUB R14,R14,#4STMFD SP!,reglist,R14;.LDMFD
7、SP!,reglist,PC 对于发生在 Thumb 状态下的异常,处理程序返回指令(SUBS PC,R14,#4)改变了程序计数器,将其指向下一条要执行指令的地址。由于程序计数器的更新是在处理异常之前完成,下一条指令应在(PC-4)。因此,处理器存储在R14_exc的值为PC。安装异常处理程序安装异常处理程序必须将任何新的异常处理程序安装在向量表中。安装完成后,不论什么时候产生相应的异常,都会执行新的处理程序。在复位时安装处理程序在复位时安装处理程序如果ROM是在存储器的0 x00位置,则可在代码的起始处为每个向量分配一个跳转语句。如果FIQ处理程序是直接从0 x1C运行的,则也可将FIQ处
8、理程序包含在其中(见下面示例)。示例展示了如果它们位于ROM的零地址时建立向量的代码。可替换装入的跳转语句。Vector_Init_BlockLDR PC,Reset_AddrLDR PC,Undefined_AddrLDR PC,SWI_AddrLDR PC,Prefetch_AddrLDR PC,Abort_AddrNOP;Reserved vectorLDR PC,IRQ_AddrLDR PC,FIQ_AddrReset_Addr DCD Start_BootUndefined_Addr DCD Undefined_HandlerSWI_Addr DCD SWI_HandlerPrefe
9、tch_Addr DCD Prefetch_HandlerAbort_Addr DCD Abort_HandlerDCD 0;Reserved vectorIRQ_Addr DCD IRQ_HandlerFIQ_Addr DCD FIQ_Handler复位状态下,必须使ROM处在0 x0位置。复位代码可将RAM映射到0 x0位置。这样做之前,它需从ROM的某个区域将该向量(根据需要还有FIQ处理程序)复制到RAM中。在此情况下,必须用一条LDR PC指令为复位处理程序确定地址,以便使复位向量代码能独立定位。示例将上面示例给出的向量复制到了RAM中的向量表。MOV R8,#0ADR R9,Vec
10、tor_Init_BlockLDMIA R9!,R0-R7;Copy the vectors(8 words)STMIA R8!,R0-R7LDMIA R9!,R0-R7;Copy the DCDed addressesSTMIA R8!,R0-R7;(8 words again)从从C安装处理程序安装处理程序开发过程中有时必需从主应用程序直接将异常处理程序安装在向量中。结果,所需的指令编码必须被写到相应的向量地址中。这可由跳转和载入PC两种方法来转到该处理程序。跳转方法:跳转方法:1.获取异常处理程序的地址。2.减去相应向量的地址。3.减去0 x8以便预取。4.将结果右移两位给出一个字的偏移
11、,而不是一个字节的偏移。5.测试其高八位为清除,确保结果仅为24位长(因为跳转的偏移被限制为此长度)。6.把它与0 xEA000000(跳转指令操作码)进行逻辑“或”运算,生成要放在向量中的值。/*Updates contents of vector to contain branch instruction*/*to reach routine from vector.Function return value is*/*original contents of vector.*/*NB:Routine must be within range of 32MB from vector.*/u
12、nsigned Install_Handler(unsigned routine,unsigned*vector)unsigned vec,oldvec;vec=(routine-(unsigned)vector-0 x8)2);if(vec&0 xFF000000)/*diagnose the fault*/prinf(Installation of Handler failed);exit(1);vec=0 xEA000000|vec;oldvec=*vector;*vector=vec;return(oldvec);以下代码调用它来安装 IRQ 处理程序:unsigned*irqvec=
13、(unsigned*)0 x18;Install_Handler(unsigned)IRQHandler,irqvec);在此情况下,将丢弃返回的初始 IRQ 向量内容。装入装入 PC 方法:方法:所需的指令可按如下方法构成:1.获取包含异常处理程序地址那个字的地址。2.减去相应向量的地址。3.减去 0 x8 以便预取。4.检查其结果能否用 12 位表示。5.把它与 0 xe59FF000(LDR pc,pc,#offset 的操作码)进行逻辑“或”运算,生成要放在向量中的值。6.将异常处理程序的地址放入该存储位置。示例展示了实现了该方法的 C 例程。/*Updates contents of
展开阅读全文