ARM32位单片机的结构编程和开发工具2595.ppt
《ARM32位单片机的结构编程和开发工具2595.ppt》由会员分享,可在线阅读,更多相关《ARM32位单片机的结构编程和开发工具2595.ppt(122页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、第12章 ARM32位单片机的结构、编程和开发工具1 112.1 ARM内核体系结构12.2 ARM编程模型12.3 ARM汇编指令12.4 ARM汇编程序设计12.5 ARM程序开发工具ADS 本章内容212.1 ARM内核体系结构 ARM是一类微处理器,同时也是一个公司的名字。AR M公 司 于1990年1 1月在英国剑桥成立(原 名Advanced RISC Machine),专门从事基于RISC技术的芯片设计、开发和授权。目前,ARM处理器(即采用ARM IP核的处理器)已遍及工业控制、通信系统、无线通讯、网络系统、消费类电子产品、成像和安全产品等各类产品市场。截止到2012年,基于A
2、RM技术设计的处理器已经占据32位RISC微处理器约80%以上的市场份额,ARM技术正在逐步渗入到我们生活的各方面。3ARM处理器是第一个为商业用途开发的RISC微处理器。ARM所采用的体系结构对于传统的RISC体系结构既有继承,又有舍弃和发展,即完全根据实际设计的需要仔细研究,没有机械照搬。最初的ARM设计最关心的是必须保持设计的简单性。ARM的简单性在ARM的硬件组织和实现方面比指令集的结构方面体现的更明显。但是ARM仍保留一些CISC的特征,并且因此达到比纯粹的RISC更高的代码密度,使得ARM在开始时就获得了其功率效率和较小的核面积的优势。12.1.1 ARM体系结构版本4ARM微处理
3、器内核中普遍采用了流水线结构,随着ARM内核的发展,其流水线结构越来越复杂。常见的ARM处理器内核流水线如图12-1所示。图12-1 ARM处理器内核流水线工作示意图12.1.1 ARM体系结构版本5 迄今为止,ARM体系结构共定义了8个版本,版本号分别为v1v8,从版本v1到v8,ARM体系的指令集功能不断扩大。同时,各版本中还有一些变种,这些变种定义该版本指令集中不同的功能。ARM处理器系列中的各种处理器,实现技术各不相同,性能差别很大,应用场合也不同,但只要它们支持同一ARM体系版本,基于它们的应用软件将是兼容的。需要注意,ARM的体系结构版本号并不是ARM核的版本号。12.1.1 AR
4、M体系结构版本6常见的ARM体系架构与ARM核的版本对应关系见表12-1。ARM核核 体系结构体系结构ARM1ARMv1ARM2ARMv2ARM6,ARM600,ARM610,ARM7,ARM700,ARM710ARMv3StrongARM,ARM8,ARM810,ARM810 ARMv4ARM9E-S,ARM10TDM1,ARM1020EARMv5ARM1136J(F)-S,ARM1176JZ(F)-S,ARM11MPCoreARMv6ARMCortex-M,ARMCortex-R,ARMCortex-AARMv7表12-1常见的ARM体系架构与ARM核的版本对应关系12.1.1 ARM体系
5、结构版本7基于ARM的处理器内核简称ARM内核,内核并不是芯片,ARM内核与其他部件组合(如存储器、定时器和片内外设接口等)在一起才构成芯片。图12-2 ARM芯片内部主要模块示意图12.1.2 ARM内核ARM芯片中只有处理器内核由ARM公司设计,其他外围模块由获得ARM公司处理器IP授权的芯片厂商自行设计。芯片厂商针对不同的应用领域,通过设计具有很强针对性的专用硬件加速器,根据外设搭配不同的接口电路等设计出适用于专业领域的SOC芯片,从而实现基于相同处理器内核芯片产品的差异化。8 ARM处理器内核不但包括CPU,还包括高速缓存、MMU控制器、嵌入式跟踪宏单元、TCM接口、总线控制逻辑、AH
6、B接口、协处理器、中断控制器等电路模块。整个ARM处理器内核的核心是CPU。虽然随着ARM处理器内核的升级,其CPU也不断改进,但其基本结构主要由32位ALU、31个32位通用寄存器及6个状态寄存器、32个8位乘法器、32个桶形移位寄存器、指令译码及控制逻辑、指令流水线和数据/地址寄存器组成。12.1.2 ARM内核9 图12-3ARM CPU基本组成模型12.1.2 ARM内核10ARM处理器是32位处理器,但兼容16位指令集和数据类型。从编程的角度看,ARM处理器有以下两种操作状态:ARM状态 32位,处理器执行的是字的ARM指令;Thumb状态 16位,处理器执行的是半字的Thumb指令
7、。在程序执行过程中,处理器可以随时在这两种操作状态之间切换。值得注意的是,操作状态的切换并不影响处理器的工作模式或寄存器的内容。ARM处理器复位后开始执行代码时,应该处于ARM状态。12.2 ARM编程模型12.2.1 处理器状态11ARM指令集和Thumb指令集均有切换处理器状态的指令,并可在两种操作状态之间切换。两个状态可以按以下方法切换:进入Thumb状态 当操作数寄存器的状态位(最低位)为1时,执行BX指令就可以进行Thumb状态。如果处理器在Thumb状态发生异常(所有异常处理都在ARM状态下执行),则当异常处理返回时自动切换到Thumb状态。进入ARM状态 操作数寄存器的状态位(最
8、低位)为0时,执行BX指令就可以进行ARM状态。处理器进行异常处理时,把PC的值放入异常模式链接寄存器中,从异常向量地址开始执行程序,系统自动进入ARM状态。处理器状态的切换12ARM体系结构支持7种处理器模式:用户模式、快中断模式、中断模式、管理模式、中止模式、未定义模式和系统模式。具体参考表12-2。12.2.2 处理器模式处理器模式处理器模式用途用途备注备注用户(usr)正常程序工作模式不能直接切换到其它模式快中断(fiq)处理高速中断,用于高速数据传输及通道处理FIQ异常响应时进入该模式中断(irq)用于通用中断处理IRQ异常响应时进入该模式管理(svc)操作系统使用的保护模式,系统复
9、位后的默认模式系统复位和软件中断响应时进入该模式中止(abt)用于支持虚拟内存和存储器保护数据或指令预取中止时进入该模式未定义(und)用于支持硬件协处理器的软件仿真未定义指令异常响应时进行该模式系统(sys)用于支持操作系统的特权任务等与用户类似,但具有可以直接切换到其它模式等特权表12-2 处理器模式及其用途13除用户模式外,其它模式为特权模式。ARM内部寄存器和一些片内外设在硬件设计上只允许(或可选为只允许)特权模式下访问。此处,特权模式可以自由地切换处理器模式,而用户模式不能直接切换别的模式。有5种处理器模式称为异常模式,它们是:快中断模式、中断模式、管理模式、中止模式、未定义模式。它
10、们除了可以通过程序切换进入外,也可以由特定的异常进入。当特定的异常出现时,处理器进入相应的模式。每种模式都有某些附加的寄存器,以避免异常退出时用户模式的状态不可靠。系统模式与用户模式一样不能由异常进入,且使用与用户模式完全相同的寄存器。然而系统模式是特权模式,不受用户模式的限制。有了系统模式,操作系统要访问用户模式的寄存器就比较方便。同时,操作系统的一些特权任务可以使用这个模式,以访问一些受控的资源而不必担心异常出现时的任务状态变得不可靠。14ARM处理器共有37个32位寄存器:31个通用寄存器 R0R15、R13_svc、R14_svc、R13_abt、R14_abt、R13_unt、R14
11、_unt、R13_irq、R14_irt和R8_frqR14_frq;6个状态寄存器 CPSR、SPSR_svc、SPSR_abt、SPSR_unt、SPSR_irq和SPSR_fiq。这些寄存器并不是在同一时间全都可以被访问,具体哪些寄存器可编程访问,取决于处理器状态和具体的操作模式。12.2.3 寄存器集15(1)通用寄存器(2)程序计数器(PC)(3)程序状态寄存器(PSR)(4)条件码标志位(5)控制位(6)ARM状态寄存器与Thumb状态寄存器之间的关系12.2.3 寄存器集1612.2.3 寄存器集通用寄存器包括R0R15,可以分为两类:不分组寄存器(R0R7)和分组寄存器(R8R
12、14)。1)不分组寄存器(R0R7)。在处理器的所有模式下,不分组寄存器中的每个都指向一个物理寄存器,且未被系统用于特殊用途。因此,在中断或异常处理中进行模式切换时,由于不同的处理器模式均使用相同的物理寄存器,可能会破坏寄存器中的数据,进行程序设计时应引起注意。(1)通用寄存器172)分组寄存器(R8R14)。分组寄存器中的每一次所访问的物理寄存器都与处理器当前的模式有关。若要访问特定的物理寄存器,则要使用规定的物理寄存器名字后缀。物理寄存器名字形式如下:R13_R14_其中,是寄存器后缀,分别使用usr、svc、fiq、irq、abt和und表示6种模式。18 对对于于寄寄存存器器R8R12
13、R8R12,每个寄存器对应2个不同的物理寄存器,当使用fiq模式时访问寄存器R8_fiqR12_fiq;当使用除fiq模式外的其他模式时访问寄存器R8 R12。对对于于寄寄存存器器R13R13和和R14R14,每个寄存器对应6个不同的物理寄存器。其中的一个物理寄存器是用户模式和系统模式公用的,其余5个分别用于5种异常模式。寄存器R13通常作为堆栈指针(SP),用于保存当前处理器工作模式下堆栈的栈顶地址。寄存器寄存器R14R14作为链接寄存器(LR),用于保存子程序的返回地址。当子程序折返回地址保存在堆栈中,R14也可作为通用寄存器。处理器在不同模式时,允许每种模式都有自已的栈顶和链接寄存器。1
14、9(2)程序计数器(PC)PC作为程序计数器,用于保存处理器要取的下一条指令的地址。R15作为程序计数器,用于保存处理器要取的下一条指令的地址。ARM状态下,所有的ARM指令都是32位长度的,指令以字对准保存;Thumb状态下,所有的Thumb指令都是16位长度的,指令以半字对准保存。由于ARM体系采用多级流水线技术,对于ARM指令集而言,PC总是指向当前指令之后两条指令的地址,即PC的值为当前指令的地址加8。20(3)程序状态寄存器(PSR)程序状态寄存包括当前程序状态寄存器(CPSR)和备份程序状态寄存器(SPSR)。所有处理器模式下都可以访问当前程序状态寄存器。CPSR包括条件标志位、中
15、断禁止位、当前处理器模式标志,以及其他一些相关的控制和状态位。在每一种异常工作模式下,都有一个备份状态寄存器。当异常发生时,SPSR用于保存CPSR的当前值,当从异常退出时,可用SPSR来恢复CPSR。用户模式和系统模式不属于异常模式,因此这两种模式没有SPSR,当在这两种情况下访问SPSR时,结果是未知的。CPSR和SPSR的格式如图12-4所示。21图 12-4 CPSR/SPSR格式22(4)条件码标志位 N、Z、C和V均为条件码标志位。其内容可被算术或逻辑运算指令的结果所改变,并全由条件码标志位状态可以决定某条指令是否执行。标志N。当两个用补码表示的带符号数进行运算时,N=1表示结果为
16、负数;N=0表示运算结果为正数或零。标志Z。Z=1表示指令运算结果为0;Z=0表示指令运算结果为非零。23标志C。对于加法运算(包括比较指令CMN),C=1表示加法运算产生进位(即无符号数溢出),C=0表示加法运算未产生进位;对于减法运算(包括比较指令CMP),C=0表示减法运算产生借位(即无符号数溢出),C=1表示减法运算未产生借位;对于包含移位操作的非加/减运算指令,C为移出值的最后一位;对于其他非加/减运算指令,C的值通常不改变。标志V。对于加法/减法指令,当操作数和运算结果为二进制的补码表示的带符号数时,V=1表示符号位溢出,V=0表示符号位未溢出;对于其他的非加/减运算指令,V的值通
17、常不改变。24(5)控制位CPSR的低8位,即I、F、T和M0M4称为控制位。当发生异常时这些位可以被改变。当处理器运行在特权模式时,这些位也可以由程序修改。中断禁止位I和F。I=1表示禁止IRQ中断,F=1表示禁止FIQ中断。T标志位。对于ARM体系结构v4及以上版本的T系列处理器,T=0表示程序运行于ARM状态,T=1表示程序运行于Thumb状态;对于ARM体系结构v4及以上版本的非T系列处理器,T=0表示程序运行于ARM状态,T=1表示执行下一条指令以引起未定义的指令异常。注意:绝对不要强制改变CPSR寄存器中的T位。如果这样做,处理器则会进入一个无法预知的状态。25运行模式位M0M4。
18、这些模式位决定处理器的模式。见表12-4。不是所有模式位的组合都定义了有效的处理器模式,因此,请注意不要使用表中没有列出的组合。保留位。CPSR中的其他位为保留位,当改变CPSR中的条件码标专位或控制位时,不要改变保留位,在程序中也不要使用保留位来存储数据。保留位将用于ARM版本的扩展。26M4:0处理器模式可访问的Thumb状态寄存器可访问的ARM状态寄存器10000用户R0R7,SP,LR,PC,CPSR R0R14,PC,CPSR10001快中断R0R7,SP_fiq,LR_fiq,PC,CPSR,SPSR_fiqR0R7,R8_fiqR14_fiq,PC,CPSR,SPSR_fiq10
19、010中断R0R7,SP_fiq,LR_fiq,PC,CPSR,SPSR_fiqR0R7,SP_svc,LR_svc,PC,CPSR,SPSR_svcR0R12,R13_fiq,R14_fiq,PC,CPSR,SPSR_fiq10011管理R0R12,R13_svc,R14_svc,PC,CPSR,SPSR_svc10111中止R0R7,SP_abt,LR_abt,PC,CPSR,SPSR_abtR0R12,R13_abt,R14_abt,PC,CPSR,SPSR_abt11011未定义R0R7,SP_und,LR_und,PC,CPSR,SPSR_undR0R12,R13_und,R14_u
20、nd,PC,CPSR,SPSR_und11111系统R0R7,SP,LR,PC,CPSR,SPSRR0R14,PC,CPSR表12-4 模式位的含义27(6)ARM状态寄存器与Thumb状态寄存器之间的关系Thumb状态下的寄存器集是ARM状态下的寄存器集的子集。用户可以访问8个通用寄存器(R0R7)、PC、SP、LR、SPSR和CPSR。每种特权模式都有一组SP、LR、SPSR。Thumb状态寄存器与ARM状态寄存器集有如下的关系:Thumb状态R0R7与ARM状态R0R7相同。Thumb状态CPSR和SPSR与ARM状态CPSR和SPSR相同。Thumb状态SP映射到ARM状态R13。Th
21、umb状态LR映射到ARM状态R14。Thumb状态PC映射到ARM状态PC(R15)。具体关系如图12-5所示。28图12-5 Thumb寄存器在ARM状态寄存器上的映射 Thumb状态下,寄存器R8R15并不是标准寄存器集的一部分,但用户可以使用汇编语言程序有限制地访问这些寄存器,将其用作快速的寄存器。使用带特殊变量的MOV指令,数据可以在低寄存器(R0R7)和高寄存器(R8R15)之间进行传送;高寄存器的值可以使用CMP指令进行比较或使用ADD指令加上低寄存器的值。29 ARM处理器支持的数据类型有字节、半字和字。字节 字节的长度为8位(bit);半字 半字的长度为16位(bit),半字
22、必须以2字节为边界对齐;字 字的长度为32位(bit)。字必须以4字节为边界对齐。这三种数据类型都支持无符号数和带符号数,当任意一种类型描述为unsigned时,N位数值使用正常的二进制格式表示范围为 的非负整数;当任意一种类型描述为signed时,N位数值使用2的补码格式表示范围为 的整数。ARM指令的长度刚好是1个字(分配为占用4个字节)。Thumb指令的长度刚好一个半字(占用2个字节)。所有数据操作都以字为单位。加载和存储指令可以以字节、半字和字进行操作,当加载字节或半字时自动实现零扩展或符号扩展。12.2.4 体系结构直接支持的数据类型3012.2.5 存储器及存储器映射I/OARM处
23、理器采用冯诺依曼结构,指令和数据共用一条32位数据总线,只有加载、存储和交换指令可访问存储器中的数据。ARM公司的规范仅定义了内核与存储系统之间的信号及时序(局部总线),而现实的芯片一般在外部总线与内核的局部总线之间有一个存储器管理部件将局部总线的信号和时序转换为现实的外部总线信号和时序。因此,外部总信的信号和时序与具体的芯片有关,不是ARM的标准。具体到某个芯片的外部存储系统的设计,需要参考其芯片的数据手册或使用手册等资料。1.地址空间 2.存储器格式 3.指令的预取和自修改代码 4.存储器映射的I/O 311.地址空间ARM体系结构使用单个平面的232个8位字节地址空间,对存储器能支持的最
24、大寻址空间为4G(232)。ARM体系统结构将存储器看成从0 x00000000地址开始的以字节为单位的线性组合。每个字数据占4个字节单位,每个半字数据占2个字节单位。字节地址按照无符号数排列,从0到232-1。地址空间可以看作是包含230个32位字,地址以字为单位进行分配,也就是将地址除以4。地址为A的字包含4个字节,地址分别为A、A+1、A+2和A+3。在ARM体系结构v4及以上版本中,地址空间还可被看包含231个16位半字。地址按照半字进行分配。地址为A的半字包含2个字节,地址分别为A和A+1。322.存储器格式地址空间的规则要求地址A:位于地址A的字包含的字节位于地址A、A+1、A+2
25、和A+3。位于地址A的半字包含的字节位于地址A、A+1。位于地址A+2的半字包含的字节位于地址A+2和A+3。位于地址A的字包含的字节位于地址A和A+3。33小端格式(little-ednian)在小端格式中,一个字当中最低地址的字节被看作是最低位字节,最高地址的字节被看作是最高位字节。因此,存储器系统字节0连接到数据线,如图12-6所示。图12-6 字内字节的小端地址34大端格式(big-endian)在大端格式中,ARM处理器将最高位字节保存在最低地址字节,将最低位字节保存在最高地址字节。因此,存储器系统字节0连接到数据线3124,如图12-7所示。图12-7 字内字节的大端地址35一个具
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- ARM32 单片机 结构 编程 开发 工具 2595
限制150内