《ARM概述及其编程模型-xiazai.ppt》由会员分享,可在线阅读,更多相关《ARM概述及其编程模型-xiazai.ppt(108页珍藏版)》请在三一办公上搜索。
1、第二章 ARM概述及编程模型,ARM相关,ARM概述及其编程模型ARM指令分类及寻址方式Thumb指令集ARM汇编语言程序设计ARM/Thumb程序混合编程C/汇编语言混合编程异常中断处理ARM C/C+编译环境,第二章 ARM概述及其编程模型,本章提纲ARM简介ARM处理器系列ARM处理器模式ARM寄存器介绍ARM体系中异常中断处理的基本概念 ARM体系中存储访问的基本知识,2.1 ARM简介,ARM公司简介,ARM是Advanced RISC Machines的缩写,它是一家微处理器行业的知名企业,该企业设计了大量高性能、廉价、耗能低的RISC(Reduced Instruction Se
2、t Computer 精简指令集)处理器。公司的特点是只设计芯片,而不生产。它将技术授权给世界上许多著名的半导体、软件和OEM厂商,并提供服务。,2.1 ARM简介,ARM公司简介,将技术授权给其它芯片厂商,形成各具特色的ARM芯片,2.1 ARM简介,ARM体系结构,ARM处理器为RISC芯片,其简单的结构使ARM内核非常小,这使得器件的功耗也非常低。它具有经典RISC的特点:,2.1 ARM简介,ARM体系结构,ARM体系结构的特点:,2.1 ARM简介,各ARM体系结构版本,ARM体系结构从最初开发到现在有了巨大的改进,并仍在完善和发展。为了清楚的表达每个ARM应用实例所使用的指令集,A
3、RM公司定义了6种主要的ARM指令集体系结构版本,以版本号V1V6表示。,2.1 ARM简介,各ARM体系结构版本V1,该版本的ARM体系结构,只有26位的寻址空间,没有商业化,其特点为:基本的数据处理指令(不包括乘法);字节、字和多字加载/存储指令;具有分支指令,包括在子程序调用中使用的分支和链接指令;在操作系统调用中使用的软件中断指令。,2.1 ARM简介,各ARM体系结构版本V2,同样为26位寻址空间,现在已经废弃不再使用,它相对V1版本有以下改进:具有乘法和乘加指令;支持协处理器(协处理器或者叫数学协处理器,协处理器主要的功能就是负责浮点运算)的指令;快速中断模式中的两个以上的备份寄存
4、器;具有原子性加载/存储指令SWP(寄存器与存储器字数据交换指令)和SWPB(寄存器与存储器字节数据交换指令)。,2.1 ARM简介,各ARM体系结构版本V3,寻址范围扩展到32位,除了3G版本外的其他版本兼容26位寻址空间:当前程序状态信息从R15寄存器移到CPSR(Current Program Status Register);增加了SPSR(Saved Program Status Register)保存被中断的程序状态;增加了MRS(读状态寄存器指令)和MSR(写状态寄存器指令)指令,用于访问CPSR和SPSR寄存器;修改了原来从异常中断返回的指令。,2.1 ARM简介,各ARM体系
5、结构版本V4,不再强制要求与以前的26位版本兼容,并明确了哪些指令会引起未定义指令异常发生,它相对V3版本作了以下的改进:半字加载/存储指令;字节和半字的加载和符号扩展指令;具有可以转换到Thumb状态的指令;用户模式寄存器的新的特权处理器模式。,2.1 ARM简介,各ARM体系结构版本V5,在V4版本的基础上,对现在指令的定义进行了必要的修正,对V4版本的体系结构进行了扩展并并增加了指令,具体如下:改进了ARM/Thumb状态之间的切换效率;对于非T变种和T变种的指令,使用相同的代码生成技术;增加计数前导零指令(该指令可以使整数除法和中断优先级排队操作更有效)和软件断点指令;对乘法指令如何设
6、置标志作了严格的定义。,2.1 ARM简介,各ARM体系结构版本V6,V6是2001年发布的,最先在2002年ARM11中使用 主要特点是增加了SIMD(Single Instruction Multiple Data,单指令多数据流)功能扩展,可以使音频/视频处理性能提高4倍。,2.2 ARM处理器系列,ARM处理器核简介,ARM公司开发了很多系列的ARM处理器核,目前最新的系列已经是ARM12了,而ARM6核以及更早的系列已经很罕见了。目前应用比较广泛的系列是:,2.2 ARM处理器系列,ARM处理器核简介ARM7,该系列包括ARM7TDMI、ARM7TDMI-S、带有高速缓存处理器宏单元
7、的ARM720T和扩充了Java加速器Jazelle的ARM7EJ-S。该系列处理器提供Thumb 16位压缩指令集和EmbededICE软件调试方式,适用于更大规模的SoC设计中。ARM7系列广泛应用于多媒体和嵌入式设备,包括Internet设备、网络和调制解调器设备,以及移动电话、PDA等无线设备。,2.2 ARM处理器系列,ARM处理器核简介ARM9,该系列包括ARM9TDMI、ARM920T和ARM940T。除了兼容ARM7系列,而且能够更加灵活的设计。ARM9系列主要应用于引擎管理、仪器仪表、安全系统和机顶盒等领域。,2.2 ARM处理器系列,ARM处理器核简介ARM10,该系列包括
8、ARM1020E、ARM1022E和ARM1026EJ-S处理器核,其核心在于使用向量浮点(VFP)单元VFP10提供高性能的浮点解决方案,从而极大提高了处理器的整型和浮点运算性能。可以用于视频游戏机和高性能打印机等场合。,2.2 ARM处理器系列,ARM处理器核简介SecurCore,该系列涵盖了SC100、SC110、SC200和SC210处理核。该系列处理器主要针对新兴的安全市场,以一种全新的安全处理器设计为智能卡和其它安全IC开发提供独特的32位系统设计,并具有特定反伪造方法,从而有助于防止对硬件和软件的盗版。,2.2 ARM处理器系列,ARM处理器核简介Xscale,Intel Xs
9、cale微控制器则提供全性能、高性价比、低功耗的解决方案,支持16位Thumb指令并集成数字信号处理(DSP)指令。,ARM7TDMI,简介,ARM7TDMI基于ARM体系结构V4版本,是目前低端的ARM核。具有广泛的应用,其最显著的应用为数字移动电话。,注意:“ARM核”并不是芯片,ARM核与其它部件如RAM、ROM、片内外设组合在一起才能构成现实的芯片。,ARM7TDMI,简介,ARM7TDMI支持32位寻址范围,并弥补了ARM6不能在低于5V电源电压下工作的不足。ARM7TDMI的后缀意义为:,支持EmbededICE观察硬件;,ARM体系的变种,Thumb指令集(T变种)长乘法指令(M
10、变种)增强型DSP指令(E变种)Java加速器Jazelle(J变种)ARM媒体功能扩展(SIMD变种),ARM7TDMI,简介,ARM7TDMI处理器是ARM通用32位微处理器家族的成员之一。它具有优异的性能,但功耗却很低,使用门的数量也很少。它属于精简指令集计算机(RISC),比复杂指令集计算机(CISC)要简单得多。这样的简化实现了:,高的指令吞吐量;出色的实时中断响应;小的、高性价比的处理器宏单元。,ARM7TDMI,三级流水线,ARM7TDMI处理器使用流水线来增加处理器指令流的速度。这样可使几个操作同时进行,并使处理和存储器系统连续操作,能提供0.9MIPS/MHz的指令执行速度。
11、ARM7TDMI的流水线分3级,分别为:取指译码执行,ARM7TDMI,三级流水线,正常操作过程中,在执行一条指令的同时对下一条指令进行译码,并将第三条指令从存储器中取出。这三条指令之间的位置关系如下表所示:,ARM7TDMI,存储器访问,ARM7TDMI处理器使用冯诺依曼(Von Neumann)结构,指令和数据共用一条32位总线。只有装载、存储和交换指令可以对存储器中的数据进行访问。数据可以是字节(8位)、半字(16位)或者字(32位)。,ARM7TDMI,存储器访问,计算机结构说明:“冯诺依曼”结构:把代码作为一种特殊的数据来操作,指令总线和数据总线及其存储区域是统一的;“哈佛”结构:指
12、令总线和数据总线及其存储区是分开、独立的。,2.3 处理器状态,处理器状态,ARM处理器内核,包含32位ARM指令集和16位Thumb指令集。因此ARM处理器有两种操作状态:ARM状态:32位,这种状态下执行的是字方式的ARM指令;Thumb状态:16位,这种状态下执行半字方式的Thumb指令。,注意:两个状态之间的切换并不影响处理器模式或寄存器内容。,2.3 处理器状态,处理器状态,使用BX指令将ARM内核的操作状态在ARM状态和Thumb状态之间进行切换,程序如下所示。LDR为加载字数据指令。,;从Arm状态切换到Thumb状态 LDR R0,=Lable+1 BX R0;从Thumb状态
13、切换到ARM状态 LDR R0,=Lable BX R0,地址最低位为1,表示切换到Thumb状态,地址最低位为0,表示切换到ARM状态,跳转地址标号,2.4 处理器模式,简介,ARM体系结构支持7种处理器模式,分别为:用户模式、快中断模式、中断模式、管理模式、中止模式、未定义模式和系统模式。,2.4 处理器模式,处理器模式,2.4 处理器模式,特权模式,除用户模式外,其它模式均为特权模式。ARM内部寄存器和一些片内外设在硬件设计上只允许(或者可选为只允许)特权模式下访问。此外,特权模式可以自由的切换处理器模式,而用户模式不能直接切换到别的模式。,2.4 处理器模式,异常模式,这五种模式称为异
14、常模式。它们除了可以通过程序切换进入外,也可以由特定的异常进入。当特定的异常出现时,处理器进入相应的模式。每种异常模式都有一些独立的寄存器,以避免异常退出时用户模式的状态不可靠。,2.4 处理器模式,用户和系统模式,这两种模式都不能由异常进入,而且它们使用完全相同的寄存器组。系统模式是特权模式,不受用户模式的限制。操作系统在该模式下访问用户模式的寄存器就比较方便,而且操作系统的一些特权任务可以使用这个模式访问一些受控的资源。,2.4 处理器模式,User正常程序执行的模式,System用于运行特权级的操作系统任务,FIQ支持高速数据传送和通道处理,(Undefined)支持通过软件仿真硬件协处
15、理器,Abort虚拟存储和存储保护,Supervisor供操作系统使用的一种保护模式,IRQ用于通常的中断处理,2.5 ARM寄存器,ARM处理器共包括37个寄存器31个通用寄存器未分组寄存器(Unbanked registers):R0R7分组寄存器(Banked registers):R8R14程序计数器PC6个状态寄存器程序状态寄存器CPSR(current program status register)备份程序状态寄存器SPSR(saved program status register),通用寄存器:R0 到 R15,可分为三类未分组寄存器(R0R7):在所有的运行模式下,都指向同
16、一个物理寄存器分组寄存器(R8R14):每一次所访问的物理寄存器与处理器当前的运行模式有关R8R12:每个对应两个物理寄存器,R8R12,R8_fiqR12_fiq,R13、R14:每个对应6个不同的物理寄存器,其中一个是用户模式与系统模式共用程序计数器PC(R15),通用寄存器,R15(PC),CPSR,ARM寄存器,USER/SYS,R15(PC),CPSR,ARM寄存器,USER/SYS,R15(PC),CPSR,ARM寄存器,USER/SYS,R15(PC),CPSR,ARM寄存器,USER/SYS,R15(PC),CPSR,ARM寄存器,USER/SYS,ARM状态各模式下的寄存器,
17、ARM状态各模式下的寄存器,所有的37个寄存器,分成两大类:31个通用32位寄存器;6个状态寄存器。,ARM状态各模式下可以访问的寄存器,一般的通用寄存器,在汇编语言中寄存器R0R13为保存数据或地址值的通用寄存器。它们是完全通用的寄存器,不会被体系结构作为特殊用途,并且可用于任何使用通用寄存器的指令。,一般的通用寄存器,其中R0R7为未分组的寄存器,也就是说对于任何处理器模式,这些寄存器都对应于相同的32位物理寄存器。,一般的通用寄存器,寄存器R8R14为分组寄存器。它们所对应的物理寄存器取决于当前的处理器模式,几乎所有允许使用通用寄存器的指令都允许使用分组寄存器,一般的通用寄存器,寄存器R
18、8R12有两个分组的物理寄存器。一个用于除FIQ模式之外的所有寄存器模式,另一个用于FIQ模式。这样在发生FIQ中断后,可以加速FIQ的处理速度。,程序计数器R15(PC),寄存器R15为程序计数器(PC),它指向正在取指的地址。可以认为它是一个通用寄存器,但是对于它的使用有许多与指令相关的限制或特殊情况。如果R15使用的方式超出了这些限制,那么结果将是不可预测的。,读R15的限制,正常操作时,从R15读取的值是处理器正在取指的地址,即当前正在执行指令的地址加上8个字节(两条ARM指令的长度)。由于ARM指令总是以字为单位,所以R15寄存器的最低两位总是为0(被4整除)。,当使用STR或STM
19、指令保存R15时,会有一个例外。这些指令可能将当前指令地址加8 字节或加12 字节保存(将来可能还有其它数字)。偏移量是8还是12取决于具体的ARM芯片,但是对于一个确定的芯片,这个值是一个常量。所以最好避免使用STR和STM指令来保存R15,如果很难做到,那么应当在程序中计算出该芯片的偏移量。,读R15的限制,计算偏移量程序代码,SUBR1,PC,#4;R1=(下面STR指令的地址)STRPC,R0;保存(STR指令地址+偏移量)LDRR0,R0;然后重装SUBR0,R0,R1;计算偏移量,读R15的限制,正常操作时,写入R15 的值被当作一个指令地址,程序从这个地址处继续执行(相当于执行一
20、次无条件跳转),写入R15,由于ARM指令以字为边界,因此写入R15的值最低两位通常为0b00。具体的规则取决于内核结构的版本:在ARM结构V3版及以下版本中,写入R15的值的最低两位被忽略,因此跳转地址由指令的实际目标地址(写入R15的值)和0 xFFFFFFFC相与得到;在ARM结构V4版及以上版本中,写入R15的值的最低两位为0,如果不是,结果将不可预测。,R15,一般的通用寄存器,寄存器R13、R14分别有6个分组的物理寄存器。一个用于用户和系统模式,其余5个分别用于5种异常模式。,链接寄存器R14(LR),R14为链接寄存器(LR),在结构上有两个特殊功能:在每种模式下,模式自身的R
21、14版本用于保存子程序返回地址;当发生异常时,将R14对应的异常模式版本设置为异常返回地址(有些异常有一个小的固定偏移量)。,R14寄存器与子程序调用,MOV PC,LR,R14(地址A),1.程序A执行过程中调用程序B;,操作流程,2.程序跳转至标号Lable,执行程序B。同时硬件将“BL Lable”指令的下一条指令所在地址存入R14;,3.程序B执行最后,将R14寄存器的内容放入PC,返回程序A;,R14寄存器与异常发生,异常发生时,程序要跳转至异常服务程序,对返回地址的处理与子程序调用类似,都是由硬件完成的。区别在于有些异常有一个小常量的偏移。,R14寄存器与异常,a,return,地
22、址A,1.执行用户模式下的程序;,2.发生IRQ中断,硬件将某个地址存入IRQ模式下的R14_irq寄存器,用户模式下的R14没有被破坏;,3.IRQ服务程序A执行完毕,将R14_irq寄存器的内容减去某个常量后存入PC,返回之前被中断的程序;,R14寄存器与异常嵌套,当发生异常嵌套时,这些异常之间可能会发生冲突。例如:如果用户在用户模式下执行程序时发生了IRQ中断,用户模式寄存器不会被破坏。但是如果允许在IRQ模式下的中断处理程序重新使能IRQ中断,并且发生了嵌套的IRQ中断时,外部中断处理程序保存在R14_irq中的任何值都将被嵌套中断的返回地址所覆盖。,R14寄存器与异常嵌套,a,ret
23、urn,地址A,1.执行用户模式下的程序;,2.发生IRQ中断,硬件将某个地址存入IRQ模式下的R14_irq寄存器,用户模式下的R14没有被破坏;,3.IRQ服务程序A执行完毕,将R14_irq寄存器的内容减去某个常量后存入PC,返回之前被中断的程序;,未被破坏,a,地址A,1.执行用户模式下的程序;,2.发生IRQ中断,硬件将某个地址存入IRQ模式下的R14_irq寄存器,用户模式下的R14没有被破坏;,3.IRQ服务程序A执行完毕,将R14_irq寄存器的内容减去某个常量后存入PC,返回之前被中断的程序;,未被破坏,a,return,地址B,4.如果在IRQ处理程序中打开IRQ中断,并且
24、再次发生IRQ中断,或者调用子程序;,5.硬件将返回地址保存在R14_irq寄存器中,原来保存的返回地址将被覆盖,造成错误;,被破坏,6.在程序B返回到程序A,然后在返回到用户模式下被中断的程序时,发生错误,将不能正确返回;,return,return,解决办法:确保R14的对应版本在发生中断嵌套时不再保存任何有意义的值(将R14入栈),或者切换到其它处理器模式下,R14寄存器与异常嵌套,堆栈指针寄存器R13(SP),寄存器R13常作为堆栈指针(SP)。在ARM指令集当中,没有以特殊方式使用R13的指令或其它功能,只是习惯上都这样使用。但是在Thumb指令集中存在使用R13的指令。,程序状态寄
25、存器(CPSR/SPSR),程序状态寄存器(CPSR/SPSR),条件标志位,模式控制位,中断禁止位,T控制位,条件代码标志,保留,控制位,溢出标志,进位或借位扩展,零,负或小于,IRQ禁止,FIQ禁止,状态位,模式位,N,Z,C,V,I,T,F,CPSR寄存器的格式,程序状态寄存器(CPSR/SPSR),条件码标志N:(结果是带符号数)若为负数,N=1否则,N=0Z:若结果为0,Z=1否则,Z=0C:加法产生进位,则C=1,否则为0减法产生借位,则C=0,否则为1移位操作时,C为移出值的最后一位V:(带符号数的加法/减法指令)结果溢出,V=1,指令条件码表,程序状态寄存器(CPSR/SPSR
26、),中断禁止位I=1 表示禁止 IRQF=1 表示禁止 FIQT标志T=0 表示执行ARM指令T=1 表示执行Thumb指令或者表示下一条将要执行的指令发生未定义指令中断,程序状态寄存器(CPSR/SPSR),模式控制位M4:0,2.6 Thumb寄存器,ARM态和Thumb态之间寄存器的关系,Thumb状态R0R7与ARM状态R0R7相同;Thumb状态CPSR和SPSR与ARM状态CPSR和SPSR相同;Thumb状态SP映射到ARM状态R13;Thumb状态LR映射到ARM状态R14;Thumb状态PC映射到ARM状态PC(R15)。,Thumb状态各模式下的寄存器,注意:括号内为ATP
27、CS中寄存器的命名,可以使用汇编伪指令将寄存器定义多个名字。其中ADS1.2的汇编程序直接支持这些名称,但注意a1a4,v1v4必须用小写。,Thumb状态下的通用寄存器,在汇编语言中寄存器R0R7为保存数据或地址值的通用寄存器。对于任何处理器模式,它们中的每一个都对应于相同的32位物理寄存器。它们是完全通用的寄存器,不会被体系结构作为特殊的用途,并且可用于任何使用通用寄存器的指令。,Thumb状态下的堆栈指针寄存器(SP),堆栈指针SP对应ARM状态的寄存器R13。每个异常模式都有其自身的SP分组版本,SP通常指向各异常模式所专用的堆栈。注意:在发生异常时,处理器自动进入ARM状态。,Thu
28、mb状态下的链接寄存器R14(LR),链接寄存器LR对应ARM状态寄存器R14,在结构上有两个特殊功能,详见“ARM状态下的链接寄存器LR”。注意:在发生异常时,处理器自动进入ARM状态。,Thumb状态寄存器在Arm状态寄存器上的映射,低寄存器,高寄存器,2.7 异常,简介,只要正常的程序流被暂时中止,处理器就进入异常模式。例如响应一个来自外设的中断。在处理异常之前,ARM内核保存当前的处理器状态,这样当处理程序结束时可以恢复执行原来的程序。如果同时发生两个或更多异常,那么将按照异常优先级的顺序来处理。,注:表中的I和F表示不对该位有影响,保留原来的值。,异常中断向量表,注:表中的I和F表示
29、不对该位有影响,保留原来的值。,异常中断向量表,当多个异常同时发生时,一个固定的优先级系统决定它们被处理的顺序:,异常优先级,注意:未定义的指令和SWI异常互斥。因为同一条指令不能既是未定义的,又能产生有效的软件中断;当FIQ使能,并且FIQ和数据中止异常同时发生时,ARM内核首先进入数据中止处理程序,然后立即跳转到FIQ向量。在FIQ处理结束后返回到数据中止处理程序。数据中止的优先级必须高于FIQ以确保数据转移错误不会被漏过。,异常优先级,快速中断请求(FIQ)适用于对一个突发事件的快速响应,这得益于在ARM状态中,快中断模式有8个专用的寄存器可用来满足寄存器保护的需要(这可以加速上下文切换
30、的速度)。不管异常入口是来自ARM状态还是Thumb状态,FIQ处理程序都会通过执行下面的指令从中断返回:SUBS PC,R14_fiq,#4 在一个特权模式中,可以通过置位CPSR中的F位来禁止FIQ异常。,异常-快速中断请求,中断请求(IRQ)异常是一个由IRQ输入端的低电平所产生的正常中断(在具体的芯片中,IRQ由片内外设拉低,IRQ是内核的一个信号,对用户不可见)。IRQ的优先级低于FIQ。对于FIQ序列它是被屏蔽的。任何时候在一个特权模式下,都可通过置位CPSR中的I 位来禁止IRQ。不管异常入口是来自ARM状态还是Thumb状态,FIQ处理程序都会通过执行下面的指令从中断返回:SU
31、BS PC,R14_fiq,#4,异常-中断请求,中止发生在对存储器的访问不能完成时,中止包含两种类型:预取中止 发生在指令预取过程中数据中止 发生在对数据访问时,异常-中止,当发生预取中止时,ARM内核将预取的指令标记为无效,但在指令到达流水线的执行阶段时才进入异常。如果指令在流水线中因为发生分支而没有被执行,中止将不会发生。在处理中止的原因之后,不管处于哪种处理器操作状态,处理程序都会执行下面的指令恢复PC和CPSR并重试被中止的指令:SUBS PC,R14_abt,#4,中止预取指中止,当发生数据中止后,根据产生数据中止的指令类型作出不同的处理:,中止数据中止,数据转移指令(LDR、ST
32、R)回写到被修改的基址寄存器。中止处理程序必须注意这一点;交换指令(SWP)中止好像没有被执行过一样(中止必须发生在SWP指令进行读访问时);,块数据转移指令(LDM,STM)完成。当回写被设置时,基址寄存器被更新。在指示出现中止后,ARM内核防止所有寄存器被覆盖。这意味着ARM内核总是会保护被中止的LDM指令中的R15(总是最后一个被转移的寄存器)。,当发生数据中止后,根据产生数据中止的指令类型作出不同的处理:,中止数据中止,在修复产生中止的原因后,不管处于哪种处理器操作状态,处理程序都必须执行下面的返回指令:SUBS PC,R14_abt,#8,中止数据中止,使用软件中断(SWI)指令可以
33、进入管理模式,通常用于请求一个特定的管理函数。SWI处理程序通过执行下面的指令返回:MOVS PC,R14_svc 这个动作恢复了PC和CPSR并返回到SWI之后的指令。SWI处理程序读取操作码以提取SWI函数编号。,异常-软件中断指令,当ARM处理器遇到一条自己和系统内任何协处理器都无法处理的指令时,ARM内核执行未定义指令陷阱。软件可使用这一机制通过模拟未定义的协处理器指令来扩展ARM指令集。注:ARM处理器完全遵循ARM结构v4T,可以捕获所有分类未被定义的指令位格式。,异常-未定义的指令,在模拟处理了失败的指令后,陷阱程序执行下面的指令:MOVS PC,R14_svc 这个动作恢复了P
34、C和CPSR并返回到未定义指令之后的指令。,异常入口/出口汇总,注意:“MOVS PC,R14_svc”是指在管理模式执行MOVS PC,R14指令。“MOVS PC,R14_und”、“SUBS PC,R14_abt,#4”等指令也是类似的。,异常的入口和出口处理,如果异常处理程序已经把返回地址拷贝到堆栈,那么可以使用一条多寄存器传送指令来恢复用户寄存器并实现返回。,SUBS LR,LR,#4;计算返回地址STMFD SP!,R0-R3,LR;保存使用到的寄存器.LDMFD SP!,R0-R3,PC;中断返回,中断处理代码的开始部分和退出部分,如果异常处理程序已经把返回地址拷贝到堆栈,那么可
35、以使用一条多寄存器传送指令来恢复用户寄存器并实现返回。,中断处理代码的开始部分和退出部分,SUBS LR,LR,#4;计算返回地址STMFD SP!,R0-R3,LR;保存使用到的寄存器.LDMFD SP!,R0-R3,PC;中断返回,注意:中断返回指令的寄存器列表(其中必须包括PC)后的“”符号表示这是一条特殊形式的指令。这条指令在从存储器中装载PC的同时(PC是最后恢复的),CPSR也得到恢复。,异常的入口和出口处理,1.在适当的LR中保存下一条指令的地址;2.将CPSR复制到适当的SPSR中;3.将CPSR模式位强制设置为与异常类型相对应的值;4.强制PC从相关的异常向量处取指。,进入异
36、常,注:ARM内核在中断异常时置位中断禁止标志,这样可以防止不受控制的异常嵌套。注:异常总是在ARM状态中进行处理。当处理器处于Thumb状态时发生了异常,在异常向量地址装入PC时,会自动切换到ARM状态。,进入异常,对异常的响应,1.将CPSR复制到相应的SPSR_中;2.根据异常类型,强制设置CPSR的模式控制位CPSR4:0,使处理器进入相应的执行模式;设置中断标志位(CPSR7=1),禁止IRQ中断;当进入Reset或FIQ模式时,还要设置中断标志位(CPSR6=1),禁止FIQ中断;3.将引起异常指令的下一条指令的地址保存到异常工作模式的R14_中;4.强制PC从相关的异常向量地址取
37、下一条指令执行,从而跳转到相应的异常处理程序处。,异常中断向量表,图示进入异常过程,2.用户程序运行时发生IRQ中断,硬件完成以下动作:,置位I位(禁止IRQ中断)清零T位(进入ARM状态)设置MOD位,切换处理器模式至IRQ模式,将下一条指令的地址存入IRQ模式的LR寄存器,将CPSR寄存器内容存入IRQ模式的SPSR寄存器,将跳转地址存入PC,实现跳转,BackAddr,JumpAddr,“?”表示对该位不关心,1.程序在系统模式下运行用户程序,假定当前处理器状态为Thumb状态、允许IRQ中断;,当异常结束时,异常处理程序必须:1.将LR中的值减去偏移量后存入PC,偏移量根据异常的类型而
38、有所不同;2.将SPSR的值复制回CPSR;3.清零在入口置位的中断禁止标志。注:恢复CPSR的动作会将T、F和I位自动恢复为异常发生前的值。,退出异常,在异常处理结束后,异常处理程序完成以下动作:,图示退出异常过程,将SPSR寄存器的值复制回CPSR寄存器;,将LR寄存的值减去一个常量后复制到PC寄存器,跳转到被中断的用户程序。,BackAddr,JumpAddr,return,BackAddr-c,“?”表示对该位不关心,字节(Byte):在ARM体系结构和8位/16位处理器体系结构中,字节的长度均为8位。字(Word):在ARM体系结构中,字长度为32位半字(Half-Word):在ARM体系结构中,半字长度为16位,2.8 ARM体系中的存储系统,2.8 ARM体系中的存储系统,存储空间使用232个8为字节的单一、线性地址空间。范围是0232-1由231个16位的半字组成,每个半字的地址是半字对准(可被2整除)。半字对准地址是A的半字由A和A+1的两个字节组成由230个32位的字组成,每个字的地址是字对准(可被4整除)。字对准地址是A的字由A和A+1、A+2、A+3的4个字节组成,大端存储系统小端存储系统,存储器格式,