《最新ARM技术的应用领域及特点(共74张PPT课件).pptx》由会员分享,可在线阅读,更多相关《最新ARM技术的应用领域及特点(共74张PPT课件).pptx(74页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、提纲(tgng)ARM技术(jsh)的应用领域及特点ARM 处理器的寄存器组织(zzh)ARM处理器的工作模式ARM微处理器系列第二章 ARM体系结构及编程模型ARM 异常处理ARM处理器的工作状态ARM处理器的存储器格式1第一页,共七十四页。ARMAdvanced RISC Machines qARM(Advanced RISC Machines),既可以认为是一个),既可以认为是一个公司的名字,也可以认为是对一类公司的名字,也可以认为是对一类(y li)(y li)微处理器的通称,还微处理器的通称,还可以认为是一种技术的名字。可以认为是一种技术的名字。ARM技术(jsh)的应用领域及特点q
2、1991年年ARM公司成立于英国剑桥,主要出售公司成立于英国剑桥,主要出售(chshu)(chshu)芯片设计芯片设计技术的授权。技术的授权。2第二页,共七十四页。ARM 公司(n s)的Chip less模式q世界各大半导体生产商从世界各大半导体生产商从ARMARM公司购买其设计的公司购买其设计的ARMARM微处理器核,微处理器核,根据各自不同的应用领域,加入适当的外围电路根据各自不同的应用领域,加入适当的外围电路(dinl)(dinl),从而形成,从而形成自己的自己的ARMARM微处理器芯片进入市场。微处理器芯片进入市场。ARM技术(jsh)的应用领域及特点q基于基于ARM技术的微处理器应
3、用约占据了技术的微处理器应用约占据了32位位RISC微处微处 理器理器75以上的市场份额,以上的市场份额,ARM技术正在逐步渗入到我们生活技术正在逐步渗入到我们生活的各个方面。的各个方面。q我国的我国的中兴集成电路、中兴集成电路、大唐电讯、中芯国际和上海华虹,以及大唐电讯、中芯国际和上海华虹,以及国外的一些公司如德州仪器、意法半导体、国外的一些公司如德州仪器、意法半导体、PhilipsPhilips、IntelIntel、SamsungSamsung等都推出了自己设计的基于等都推出了自己设计的基于ARMARM核的处理器。核的处理器。3第三页,共七十四页。ARM微处理器的应用领域 工业控制领域:
4、作为工业控制领域:作为3232的的RISCRISC架构,基于架构,基于ARMARM核的微控制核的微控制器芯片不但占据了高端微控制器市场器芯片不但占据了高端微控制器市场(shchng)的大部分市场的大部分市场(shchng)份额,同时也逐渐向低端微控制器应用领域扩展,份额,同时也逐渐向低端微控制器应用领域扩展,ARMARM微控制器的低功耗、高性价比,向传统的微控制器的低功耗、高性价比,向传统的8 8位位/16/16位位微控制器提出了挑战。微控制器提出了挑战。ARM技术(jsh)的应用领域及特点q到目前为止,到目前为止,ARM微处理器及技术的应用已经广泛深入微处理器及技术的应用已经广泛深入(shn
5、r)到国民经济的各个领域到国民经济的各个领域4第四页,共七十四页。ARM微处理器的应用领域ARM技术(jsh)的应用领域及特点q网络应用:随着宽带网络应用:随着宽带(kun di)技术的推广,采用技术的推广,采用ARM技术的技术的ADSL芯片正逐步获得竞争优势。此外,芯片正逐步获得竞争优势。此外,ARM在语音及视频处理上进行了优在语音及视频处理上进行了优化,并获得广泛支持,也对化,并获得广泛支持,也对DSP的应用领域提出了挑战。的应用领域提出了挑战。q消费类电子产品:消费类电子产品:ARM技术在目前流行的数字音频播放器、技术在目前流行的数字音频播放器、数字机顶盒和游戏机中得到数字机顶盒和游戏机
6、中得到(d do)广泛采用。广泛采用。q成像和安全产品:现在流行的数码相机和打印机中绝大部成像和安全产品:现在流行的数码相机和打印机中绝大部分采用分采用ARM技术。手机中的技术。手机中的32位位SIM智能卡也采用了智能卡也采用了ARM技技术。术。q5第五页,共七十四页。ARM微处理器的特点(tdin)低功耗、低成本、高性能低功耗、低成本、高性能采用(ciyng)RISC指令集ARM技术(jsh)的应用领域及特点q低功耗、低成本、高性能低功耗、低成本、高性能使用大量的寄存器ARM/THUMB指令支持三/五级流水线6第六页,共七十四页。ARM微处理器的特点(tdin)采用采用RISCRISC体系结
7、构体系结构ARM技术(jsh)的应用领域及特点q采用采用(ciyng)RISC架构的架构的ARM处理器一般具有如下特点:处理器一般具有如下特点:固定长度的指令格式,指令归整、简单、基固定长度的指令格式,指令归整、简单、基 本寻址本寻址方式有方式有23种;种;使用单周期指令,便于流水线操作执行;使用单周期指令,便于流水线操作执行;大量使用寄存器,数据处理指令只对寄存器进行操大量使用寄存器,数据处理指令只对寄存器进行操作,只有加载作,只有加载/存储指令可以访问存储器,以提高指令的存储指令可以访问存储器,以提高指令的执行效率。执行效率。7第七页,共七十四页。ARM微处理器的特点(tdin)大量使用寄
8、存器大量使用寄存器ARM技术(jsh)的应用领域及特点qARM 处理器共有处理器共有37个寄存器,被分为个寄存器,被分为(fn wi)若干个组,这若干个组,这些寄存器包括:些寄存器包括:31个通用寄存器,包括程序计数器(个通用寄存器,包括程序计数器(PC 指针),均为指针),均为32位的寄存器;位的寄存器;6个状态寄存器,用以标识个状态寄存器,用以标识CPU的工作状态及程序的的工作状态及程序的运行状态,均为运行状态,均为32位。位。8第八页,共七十四页。ARM微处理器的特点高效高效(o xio)(o xio)的指令系统的指令系统ARM技术(jsh)的应用领域及特点qARM微处理器支持微处理器支
9、持(zhch)两种指令集:两种指令集:ARM指令集和指令集和Thumb指令集。指令集。qARM指令为指令为32位的长度,位的长度,Thumb指令为指令为16位长度。位长度。Thumb指令集为指令集为ARM指令集的功能子集,但与等价的指令集的功能子集,但与等价的ARM代码相比较,代码相比较,可节省可节省3040以上的存储空间,同时具备以上的存储空间,同时具备32位代码的所有优位代码的所有优点。点。9第九页,共七十四页。ARM微处理器的特点其他其他(qt)(qt)技术技术ARM技术(jsh)的应用领域及特点q除此以外,除此以外,ARM体系结构还采用了一些特别的技术,在体系结构还采用了一些特别的技术
10、,在保证保证(bozhng)高性能的前提下尽量缩小芯片的面积,并降低功耗:高性能的前提下尽量缩小芯片的面积,并降低功耗:q所有的所有的ARM指令都可根据前面的执行结果决定是否被执指令都可根据前面的执行结果决定是否被执行,从而提高指令的执行效率。行,从而提高指令的执行效率。q可用加载可用加载/存储指令批量传输数据,以提高数据的传输效存储指令批量传输数据,以提高数据的传输效率。率。q可在一条数据处理指令中同时完成逻辑处理和移位处理。可在一条数据处理指令中同时完成逻辑处理和移位处理。q在循环处理中使用地址的自动增减来提高运行效率。在循环处理中使用地址的自动增减来提高运行效率。10第十页,共七十四页。
11、ARM微处理器系列(xli) ARM微处理器系列(xli)qARM7系列系列(xli)qARM9系列系列qARM9E系列系列qARM10E系列系列qSecurCore系列系列qIntel的的Xscaleq其中,其中,ARM7、ARM9、ARM9E和和ARM10为为4个通用处理个通用处理器系列,每一个系列提供一套相对独特的性能来满足不同应用器系列,每一个系列提供一套相对独特的性能来满足不同应用领域的需求。领域的需求。SecurCore系列专门为安全要求较高的应用而设系列专门为安全要求较高的应用而设计。计。 11第十一页,共七十四页。ARM7微处理器系列(xli) qARM7系列是低功耗的系列是低
12、功耗的32位位RISC处理器,最适合用于对价位处理器,最适合用于对价位和功耗要求较高的消费类应用。和功耗要求较高的消费类应用。ARM7系列有如下系列有如下(rxi)特点:特点:具有嵌入式具有嵌入式ICERT逻辑,调试逻辑,调试(dio sh)开发方便;开发方便;极低的功耗,适合对功耗要求较高的应用,如便携式产品;极低的功耗,适合对功耗要求较高的应用,如便携式产品;能够提供能够提供0.9MIPS/ MHz的三级流水线结构;的三级流水线结构;兼容兼容16位的位的Thumb指令集,代码密度高;指令集,代码密度高;对操作系统的支持广泛,如对操作系统的支持广泛,如Windows CE、Linux、Pal
13、m OS等;等;指令系统与指令系统与ARM9系列、系列、ARM9E系列和系列和ARM10E系列兼容,便于用户的产品系列兼容,便于用户的产品升级换代;升级换代;主频最高可达主频最高可达130M,高速的运算处理能力能胜任绝大多数的复杂应,高速的运算处理能力能胜任绝大多数的复杂应用。用。ARM微处理器系列12第十二页,共七十四页。ARM7微处理器系列(xli)ARM微处理器系列(xli)q主要应用领域:工业控制、主要应用领域:工业控制、Internet设备设备(shbi)、网络和调制、网络和调制解调器设备解调器设备(shbi)、移动电话等多种多媒体和嵌入式应用。、移动电话等多种多媒体和嵌入式应用。q
14、ARM7系列微处理器包括如下几种类型的核:系列微处理器包括如下几种类型的核:ARM7TDMI、ARM7TDMI-S、ARM720T、ARM7EJ。其中,。其中,ARM7TMDI是目是目前使用最广泛的前使用最广泛的32位嵌入式位嵌入式RISC处理器,属低端处理器,属低端ARM处理器核。处理器核。TDMI的基本含义为:的基本含义为:T:支持:支持16位压缩指令集位压缩指令集Thumb;D:支持片上:支持片上Debug;M:内嵌硬件乘法器(:内嵌硬件乘法器(Multiplier)I:嵌入式:嵌入式ICE,支持片上断点和调试点;,支持片上断点和调试点;13第十三页,共七十四页。ARM9微处理器系列(x
15、li) ARM微处理器系列(xli)qARM9系列微处理器在高性能和低功耗特性方面提供最佳的系列微处理器在高性能和低功耗特性方面提供最佳的表现。具有以下表现。具有以下(yxi)特点:特点:5级流水线,指令执行效率更高。级流水线,指令执行效率更高。提供提供1.1MIPS/MHz的哈佛结构。的哈佛结构。支持支持32位位ARM指令集和指令集和16位位Thumb指令集。指令集。支持支持32位的高速位的高速AMBA总线接口。总线接口。全性能的全性能的MMU,支持,支持Windows CE、Linux、Palm OS等多种主流等多种主流嵌入式操作系统。嵌入式操作系统。MPU支持实时操作系统。支持实时操作系
16、统。支持数据支持数据Cache和指令和指令Cache,具有更高的指令和数据处理能力。,具有更高的指令和数据处理能力。14第十四页,共七十四页。ARM9微处理器系列(xli)qARM9ARM9系列微处理器主要系列微处理器主要(zhyo)应用于无线设备、仪器仪表、应用于无线设备、仪器仪表、安全系统、机顶盒、高端打印机、数字照相机和数字摄像安全系统、机顶盒、高端打印机、数字照相机和数字摄像机等。机等。ARM微处理器系列(xli)qARM9ARM9系列微处理器包含系列微处理器包含ARM920TARM920T、ARM922TARM922T和和ARM940TARM940T三种类型,三种类型,以适用于不同的
17、应用场合。以适用于不同的应用场合。15第十五页,共七十四页。ARM9E微处理器系列(xli) ARM微处理器系列(xli)qARM9EARM9E系列微处理器的主要系列微处理器的主要(zhyo)(zhyo)特点如下:特点如下:支持支持DSP指令集,适合于需要高速数字信号处理的场合。指令集,适合于需要高速数字信号处理的场合。5级流水线,指令执行效率更高。级流水线,指令执行效率更高。支持支持32位位ARM指令集和指令集和16位位Thumb指令集。指令集。支持支持32位的高速位的高速AMBA总线接口。总线接口。支持支持VFP9浮点处理协处理器。浮点处理协处理器。全性能的全性能的MMU,支持众多主流嵌入
18、式操作系统。,支持众多主流嵌入式操作系统。支持数据支持数据Cache和指令和指令Cache,具有更高的处理能力。,具有更高的处理能力。主频最高可达主频最高可达300M。16第十六页,共七十四页。ARM9E微处理器系列(xli)qARM9EARM9E系列微处理器主要应用于下一代无线设备、数字消费系列微处理器主要应用于下一代无线设备、数字消费品、成像设备、工业控制品、成像设备、工业控制(kngzh)(kngzh)、存储设备和网络设备等领、存储设备和网络设备等领域。域。ARM微处理器系列(xli)qARM9EARM9E系列微处理器包含系列微处理器包含ARM926EJ-SARM926EJ-S、ARM9
19、46E-SARM946E-S和和ARM966E-SARM966E-S三种类型,以适用于不同的应用场合。三种类型,以适用于不同的应用场合。17第十七页,共七十四页。ARM10E微处理器系列(xli) ARM微处理器系列(xli)qARM10EARM10E系列微处理器的主要系列微处理器的主要(zhyo)(zhyo)特点如下:特点如下:支持支持DSP指令集,适合于需要高速数字信号处理的场合。指令集,适合于需要高速数字信号处理的场合。6级流水线,指令执行效率更高。级流水线,指令执行效率更高。支持支持32位位ARM指令集和指令集和16位位Thumb指令集。指令集。支持支持32位的高速位的高速AMBA总线
20、接口。总线接口。支持支持VFP10浮点处理协处理器。浮点处理协处理器。全性能的全性能的MMU,支持众多主流嵌入式操作系统。,支持众多主流嵌入式操作系统。支持数据支持数据Cache和指令和指令Cache,具有更高的处理能力,具有更高的处理能力主频最高可达主频最高可达400M。内嵌并行读内嵌并行读/写操作部件。写操作部件。18第十八页,共七十四页。ARM10E微处理器系列(xli)qARM10EARM10E系列微处理器主要应用系列微处理器主要应用(yngyng)(yngyng)于下一代无线设备、于下一代无线设备、数字消费品、成像设备、工业控制、通信和信息系统等领数字消费品、成像设备、工业控制、通信
21、和信息系统等领域。域。ARM微处理器系列(xli)qARM10EARM10E系列微处理器包含系列微处理器包含ARM1020EARM1020E、ARM1022EARM1022E和和ARM1026EJ-SARM1026EJ-S三种类型,以适用于不同的应用场合。三种类型,以适用于不同的应用场合。19第十九页,共七十四页。SecurCore微处理器系列(xli) ARM微处理器系列(xli)qSecurCoreSecurCore系列系列(xli)(xli)微处理器除了具有微处理器除了具有ARMARM体系结构各种主要特点体系结构各种主要特点外,还在系统安全方面具有如下的特点:外,还在系统安全方面具有如下
22、的特点:带有灵活的保护单元,确保操作系统和应用数据的安全。带有灵活的保护单元,确保操作系统和应用数据的安全。采用软内核技术,防止外部对其进行扫描探测。采用软内核技术,防止外部对其进行扫描探测。可集成用户自己的安全特性和其他协处理器。可集成用户自己的安全特性和其他协处理器。20第二十页,共七十四页。SecurCore微处理器系列(xli)q SecurCoreSecurCore系列微处理器主要应用于一些对安全性要求较高系列微处理器主要应用于一些对安全性要求较高的应用产品及应用系统,如电子商务的应用产品及应用系统,如电子商务(din z shn w)(din z shn w)、电子政、电子政务、电
23、子银行业务、网络和认证系统等领域。务、电子银行业务、网络和认证系统等领域。ARM微处理器系列(xli)q SecurCoreSecurCore系列微处理器包含系列微处理器包含SecurCore SC100SecurCore SC100、SecurCore SecurCore SC110SC110、SecurCore SC200SecurCore SC200和和SecurCore SC210SecurCore SC210四种类型,以四种类型,以适用于不同的应用场合。适用于不同的应用场合。21第二十一页,共七十四页。StrongARM微处理器系列(xli) ARM微处理器系列(xli)qIntel
24、 StrongARM处理器是便携式通讯产品处理器是便携式通讯产品(chnpn)(chnpn)和消费类电和消费类电子产品子产品(chnpn)(chnpn)的理想选择,已成功应用于多家公司的掌上电脑的理想选择,已成功应用于多家公司的掌上电脑系列产品系列产品(chnpn)(chnpn)。qIntel StrongARM SA-1100Intel StrongARM SA-1100处理器是采用处理器是采用ARMARM体系结构高度集成体系结构高度集成的的3232位位RISCRISC微处理器。它融合了微处理器。它融合了IntelIntel公司的设计和处理技术以公司的设计和处理技术以及及ARMARM体系结构
25、的电源效率,采用在软件上兼容体系结构的电源效率,采用在软件上兼容ARMv4ARMv4体系结构、体系结构、同时采用具有同时采用具有IntelIntel技术优点的体系结构。技术优点的体系结构。22第二十二页,共七十四页。Xscale处理器 ARM微处理器系列(xli)qXscale Xscale 处理器是基于处理器是基于ARMv5TEARMv5TE体系结构的解决方案,是一款体系结构的解决方案,是一款全性能、高性价比、低功耗的处理器。它支持全性能、高性价比、低功耗的处理器。它支持1616位的位的ThumbThumb指指令和令和DSPDSP指令集,已使用在数字移动电话、个人数字助理和网指令集,已使用在
26、数字移动电话、个人数字助理和网络产品络产品(chnpn)(chnpn)等场合。等场合。qXscale Xscale 处理器是处理器是IntelIntel目前目前(mqin)(mqin)主要推广的一款主要推广的一款ARMARM微处理微处理器。器。23第二十三页,共七十四页。ARM微处理器的工作(gngzu)状态 ARM微处理器的工作(gngzu)状态q 从编程的角度看,从编程的角度看,ARMARM微处理器的工作状态一般微处理器的工作状态一般(ybn)(ybn)有两种,并可有两种,并可在两种状态之间切换:在两种状态之间切换:ARM状态,此时处理器执行状态,此时处理器执行32位的字对齐的位的字对齐的
27、ARM指令;指令;Thumb状态,此时处理器执行状态,此时处理器执行16位的、半字对齐的位的、半字对齐的Thumb指指令。令。 24第二十四页,共七十四页。ARM与THUMBq THUMB指令(zhlng)是ARM指令(zhlng)的子集ARM微处理器的工作(gngzu)状态q 可以相互调用,只要(zhyo)遵循一定的调用规则q Thumb指令与ARM指令的时间效率和空间效率关系为: 存储空间约为ARM代码的6070 指令数比ARM代码多约3040 存储器为32位时ARM代码比Thumb代码快约40 存储器为16位时Thumb比ARM代码快约4050 使用Thumb代码,存储器的功耗会降低约3
28、025第二十五页,共七十四页。状态(zhungti)切换方法 q ARMARM指令集和指令集和ThumbThumb指令集均有切换处理器状态指令集均有切换处理器状态(zhungti)(zhungti)的指的指令,并可在两种工作状态令,并可在两种工作状态(zhungti)(zhungti)之间切换,之间切换,ARM微处理器的工作(gngzu)状态q 在开始执行代码时,处于在开始执行代码时,处于ARMARM状态。状态。26第二十六页,共七十四页。进入进入(jnr)(jnr)ThumbThumb状态状态q 当操作数寄存器的状态位(位当操作数寄存器的状态位(位0 0)为)为1 1时,可以采用执行时,可以
29、采用执行BXBX指令指令(zhlng)(zhlng)的方法,使微处理器从的方法,使微处理器从ARMARM状态切换到状态切换到ThumbThumb状态。状态。q 当处理器处于当处理器处于ThumbThumb状态时发生异常(如状态时发生异常(如IRQIRQ、FIQFIQ、UndefUndef、AbortAbort、SWISWI等),则异常处理返回时,自动等),则异常处理返回时,自动(zdng)(zdng)切换到切换到ThumbThumb状态。状态。ARM微处理器的工作状态27第二十七页,共七十四页。切换切换(qi hun)(qi hun)到到ARMARM状态状态q 当操作数寄存器的状态位为当操作数
30、寄存器的状态位为0 0时,执行时,执行BXBX指令时可以指令时可以(ky)(ky)使微处理器从使微处理器从ThumbThumb状态切换到状态切换到ARMARM状态。状态。ARM微处理器的工作(gngzu)状态q 在处理器进行异常处理时,把在处理器进行异常处理时,把PCPC指针放入异常模式链接寄存器中,指针放入异常模式链接寄存器中,并从异常向量地址开始执行程序,也可以使处理器切换到并从异常向量地址开始执行程序,也可以使处理器切换到ARMARM状状态。态。28第二十八页,共七十四页。处理器模式(msh)ARM微处理器的工作(gngzu)模式q usrusr:ARMARM处理器正常处理器正常(zhn
31、gchng)(zhngchng)的程序执行状态的程序执行状态q fiqfiq:用于高速数据传输或通道处理:用于高速数据传输或通道处理q irqirq:用于通用的中断处理:用于通用的中断处理q svcsvc:操作系统使用的保护模式:操作系统使用的保护模式q abtabt:用于虚拟存储及存储保护:用于虚拟存储及存储保护q syssys:运行具有特权的操作系统任务:运行具有特权的操作系统任务q undund:当出现未定义指令终止时进入该模式:当出现未定义指令终止时进入该模式29第二十九页,共七十四页。用户模式(msh)和特权模式(msh)ARM微处理器的工作(gngzu)模式q 除了用户模式之外的其
32、他除了用户模式之外的其他(qt)(qt)6 6种处理器模式称为特权模式种处理器模式称为特权模式q 特权模式下,程序可以访问所有的系统资源,也可以任意特权模式下,程序可以访问所有的系统资源,也可以任意地进行处理器模式的切换。地进行处理器模式的切换。q 特权模式中,除系统模式外,其他特权模式中,除系统模式外,其他5 5种模式又称为异常模式种模式又称为异常模式q 大多数的用户程序运行在用户模式下,此时,应用程序不大多数的用户程序运行在用户模式下,此时,应用程序不能够访问一些受操作系统保护的系统资源,应用程序也不能够访问一些受操作系统保护的系统资源,应用程序也不能直接进行处理器模式的切换。能直接进行处
33、理器模式的切换。q 用户模式下,当需要进行处理器模式切换时,应用程序用户模式下,当需要进行处理器模式切换时,应用程序可以产生异常处理,在异常处理中进行处理器模式的切可以产生异常处理,在异常处理中进行处理器模式的切换。换。30第三十页,共七十四页。模式(msh)切换ARM微处理器的工作(gngzu)模式q 处理器模式可以通过软件进行处理器模式可以通过软件进行(jnxng)(jnxng)切换,也可以通过外切换,也可以通过外部中断或者异常处理过程进行部中断或者异常处理过程进行(jnxng)(jnxng)切换。切换。q 当应用程序发生异常中断时,处理器进入相应的异常模当应用程序发生异常中断时,处理器进
34、入相应的异常模式。在每一种异常模式下都有一组寄存器,供相应的异式。在每一种异常模式下都有一组寄存器,供相应的异常处理程序使用,这样就可以保证在进入异常模式时,常处理程序使用,这样就可以保证在进入异常模式时,用户模式下的寄存器不被破坏。用户模式下的寄存器不被破坏。q 系统模式并不是通过异常进入的,它和用户模式具有完全一样系统模式并不是通过异常进入的,它和用户模式具有完全一样的寄存器。但是系统模式属于特权模式,可以访问所有的系统的寄存器。但是系统模式属于特权模式,可以访问所有的系统资源,也可以直接进行处理器模式切换。它主要供操作系统任资源,也可以直接进行处理器模式切换。它主要供操作系统任务使用。通
35、常操作系统的任务需要访问所有的系统资源,同时务使用。通常操作系统的任务需要访问所有的系统资源,同时该任务仍然使用用户模式的寄存器组,而不是使用异常模式下该任务仍然使用用户模式的寄存器组,而不是使用异常模式下相应的寄存器组,这样可以保证当异常中断发生时任务状态不相应的寄存器组,这样可以保证当异常中断发生时任务状态不被破坏。被破坏。31第三十一页,共七十四页。ARM微处理器的存储器格式(g shi) q ARMARM体系结构所支持体系结构所支持(zhch)(zhch)的最大寻址空间为的最大寻址空间为4GB4GB(2 23232字节)字节)ARM微处理器的存储器格式(g shi)q ARMARM体系
36、结构将存储器看作是从零地址开始的字节的线性组体系结构将存储器看作是从零地址开始的字节的线性组合。从零字节到三字节放置第一个存储的字数据,从第四个合。从零字节到三字节放置第一个存储的字数据,从第四个字节到第七个字节放置第二个存储的字数据,依次排列。字节到第七个字节放置第二个存储的字数据,依次排列。q ARMARM体系结构可以用两种方法存储字数据,称之为大端格式体系结构可以用两种方法存储字数据,称之为大端格式和小端格式和小端格式 32第三十二页,共七十四页。ARM体系结构的存储器格式(g shi)大端格式 ARM微处理器的存储器格式(g shi)q 在这种格式在这种格式(g shi)(g shi)
37、中,字数据的高字节存储在低地址中,而中,字数据的高字节存储在低地址中,而字数据的低字节则存放在高地址中字数据的低字节则存放在高地址中33第三十三页,共七十四页。ARM体系结构的存储器格式(g shi)小端格式 ARM微处理器的存储器格式(g shi)q 与大端与大端(ddun)(ddun)存储格式相反,在小端存储格式中,低地址中存存储格式相反,在小端存储格式中,低地址中存放的是字数据的低字节,高地址存放的是字数据的高字节放的是字数据的低字节,高地址存放的是字数据的高字节34第三十四页,共七十四页。指令(zhlng)长度及数据类型 qARMARM微处理器的指令长度微处理器的指令长度(chngd)
38、(chngd)可以是可以是3232位(在位(在ARMARM状态下),状态下),也可以为也可以为1616位(在位(在ThumbThumb状态下)。状态下)。ARM微处理器的存储器格式(g shi)qARMARM微处理器中支持字节(微处理器中支持字节(8 8位)、半字(位)、半字(1616位)、字位)、字(3232位)三种数据类型,其中,字需要位)三种数据类型,其中,字需要4 4字节对齐(地址字节对齐(地址的低两位为的低两位为0 0)、半字需要)、半字需要2 2字节对齐(地址的最低位为字节对齐(地址的最低位为0 0)35第三十五页,共七十四页。非对齐(du q)的存储访问操作 q在在ARMARM中
39、,如果存储单元的地址中,如果存储单元的地址(dzh)(dzh)没有遵守对齐规则,没有遵守对齐规则,则称为非对齐的存储访问操作。则称为非对齐的存储访问操作。ARM微处理器的存储器格式(g shi)q非对齐的指令预取操作非对齐的指令预取操作q 非对齐的数据访问操作非对齐的数据访问操作36第三十六页,共七十四页。非对齐(du q)的指令预取操作 q 当处理器处于当处理器处于ARMARM状态期间,如果写入到寄存器状态期间,如果写入到寄存器PCPC中的值是非字中的值是非字对齐的,要么指令执行的结果不可预知对齐的,要么指令执行的结果不可预知(y zh)(y zh),要么地址值中最,要么地址值中最低两位被忽
40、略。低两位被忽略。ARM微处理器的存储器格式(g shi)q当处理器处于当处理器处于THUMBTHUMB状态期间,如果写入到寄存器状态期间,如果写入到寄存器PCPC中的中的值是非半字对齐的,要么指令执行的结果不可预知,要值是非半字对齐的,要么指令执行的结果不可预知,要么地址值中最低位被忽略。么地址值中最低位被忽略。37第三十七页,共七十四页。非对齐的数据(shj)访问操作 q对于对于Load/StoreLoad/Store操作,如果是非对齐的数据操作,如果是非对齐的数据(shj)(shj)访问操作,访问操作,系统定义了三种可能的结果:系统定义了三种可能的结果:ARM微处理器的存储器格式(g s
41、hi) 执行的结果不可预知执行的结果不可预知忽略字单元地址的低两位的值,即访问地址为忽略字单元地址的低两位的值,即访问地址为(address (address AND 0XFFFFFFFC)AND 0XFFFFFFFC)的字单元;忽略半字单元地址的最低位的字单元;忽略半字单元地址的最低位的值,即访问地址为的值,即访问地址为(address AND 0XFFFFFFFE)(address AND 0XFFFFFFFE)的半字的半字单元。单元。忽略字单元地址的低两位的值;或忽略半字单元地址的忽略字单元地址的低两位的值;或忽略半字单元地址的最低位的值;由存储系统实现这种忽略。也就是说,这最低位的值;
42、由存储系统实现这种忽略。也就是说,这时该地址值原封不动地送到存储系统。时该地址值原封不动地送到存储系统。q 当发生非对齐的数据访问时,到底采用上述三种方法中的哪一种,当发生非对齐的数据访问时,到底采用上述三种方法中的哪一种,是由各指令指定的。是由各指令指定的。38第三十八页,共七十四页。寄存器组织(zzh) q ARMARM微处理器共有微处理器共有3737个个3232位寄存器,其中位寄存器,其中3131个为通用寄存个为通用寄存器,器,6 6个为状态寄存器。但是这些寄存器不能被同时个为状态寄存器。但是这些寄存器不能被同时(tngsh)(tngsh)访问,具体哪些寄存器是可编程访问的,取决微处理器
43、的访问,具体哪些寄存器是可编程访问的,取决微处理器的工作状态及具体的运行模式。但在任何时候,通用寄存器工作状态及具体的运行模式。但在任何时候,通用寄存器R14R14R0R0、程序计数器、程序计数器PCPC、一个或两个状态寄存器都是可、一个或两个状态寄存器都是可访问的。访问的。 ARM微处理器的寄存器格式(g shi)39第三十九页,共七十四页。ARM状态(zhungti)下的寄存器组织 q 通用寄存器:通用寄存器包括(boku)R0R15,可以分为三类:未分组寄存器未分组寄存器R0R0R7R7 分组寄存器分组寄存器R8R8R14R14程序程序(chngx)(chngx)计数器计数器PC(R15
44、)PC(R15)ARM微处理器的寄存器格式40第四十页,共七十四页。ARM状态(zhungti)下的寄存器组织ARM微处理器的寄存器格式(g shi)41第四十一页,共七十四页。未分组寄存器R0R7ARM微处理器的寄存器格式(g shi)q 在所有的运行模式下,未分组寄存器都指向同一个物理寄存器,他们未被系统用作特殊的用途,因此,在中断或异常(ychng)处理进行运行模式转换时,由于不同的处理器运行模式均使用相同的物理寄存器,可能会造成寄存器中数据的破坏,这一点在进行程序设计时应引起注意。42第四十二页,共七十四页。分组寄存器R8R12ARM微处理器的寄存器格式(g shi)q 每次所访问的物
45、理寄存器与处理器当前(dngqin)的运行模式有关q R8R12:每个寄存器对应(duyng)两个不同的物理寄存器 当使用fiq模式时,访问寄存器R8_fiqR12_fiq; 当使用除fiq模式以外的其他模式时,访问寄存器R8_usrR12_usr。43第四十三页,共七十四页。分组寄存器R13R14ARM微处理器的寄存器格式(g shi)q R13、R14:每个寄存器对应(duyng)6个不同的物理寄存器q 其中的一个是用户模式与系统模式共用,另外5个物理寄存器对应于其他(qt)5种不同的运行模式q 采用以下的记号来区分不同的物理寄存器: R13_ R14_q mode为以下几种之一:usr、
46、fiq、irq、svc、abt、und。44第四十四页,共七十四页。堆栈(duzhn)指针R13ARM微处理器的寄存器格式(g shi)q R13在ARM指令中常(zhngchng)用作堆栈指针,但这只是一种习惯用法,用户也可使用其他的寄存器作为堆栈指针。q 在Thumb指令集中,某些指令强制性的要求使用R13作为堆栈指针。q 由于处理器的每种运行模式均有自己独立的物理寄存器R13,在初始化部分,都要初始化每种模式下的R13,这样,当程序的运行进入异常模式时,可以将需要保护的寄存器放入R13所指向的堆栈,而当程序从异常模式返回时,则从对应的堆栈中恢复。 45第四十五页,共七十四页。子程序连接(
47、linji)寄存器R14ARM微处理器的寄存器格式(g shi)q R14也称作子程序连接寄存器或连接寄存器LR。当执行BL子程序调用指令时,可以从R14中得到R15(程序计数器PC)的备份(bi fn)。其他情况下,R14用作通用寄存器。q 在每一种运行模式下,都可用R14保存子程序的返回地址,当用BL或BLX指令调用子程序时,将下一条指令的地址值拷贝给R14,执行完子程序后,又将R14的值拷贝回PC,即可完成子程序的调用返回。BLSUB1SUB1:STMFD SP!, , LR /*将R14存入堆栈*/LDMFDSP!,PC/*完成子程序返回 */46第四十六页,共七十四页。程序(chng
48、x)计数器PC(R15)ARM微处理器的寄存器格式(g shi)q ARMARM状态状态(zhungti)(zhungti)下,位下,位1:01:0为为0 0,位,位31:231:2用于保存用于保存PCPC;q ThumbThumb状态下,位状态下,位00为为0 0,位,位31:131:1用于保存用于保存PCPC;q R15R15虽然也可用作通用寄存器,但一般不这么使用,因为对虽然也可用作通用寄存器,但一般不这么使用,因为对R15R15的使用有一些特殊的限制,当违反了这些限制时,程序的使用有一些特殊的限制,当违反了这些限制时,程序的执行结果是未知的。的执行结果是未知的。q 由于由于ARM体系结
49、构采用了多级流水线技术,对于体系结构采用了多级流水线技术,对于ARM指令集而指令集而言,言,PC总是指向当前指令的下两条指令的地址,即总是指向当前指令的下两条指令的地址,即PC的值为当的值为当前指令的地址值加前指令的地址值加8个字节。个字节。47第四十七页,共七十四页。程序(chngx)状态寄存器(CPSR/SPSR)q CPSR(CPSR(当前当前(dngqin)程序状态寄存器程序状态寄存器) ),CPSRCPSR可在任何运可在任何运行模行模式下被访问,它包括条件标志位、中断禁止位、当前处理式下被访问,它包括条件标志位、中断禁止位、当前处理器模式标志位,以及其他一些相关的控制和状态位。器模式
50、标志位,以及其他一些相关的控制和状态位。ARM微处理器的寄存器格式(g shi)q 每一种运行模式下又都有一个专用的物理状态寄存器,称为每一种运行模式下又都有一个专用的物理状态寄存器,称为SPSR(SPSR(备份的程序状态寄存器),异常发生时,备份的程序状态寄存器),异常发生时,SPSRSPSR用于保存用于保存CPSRCPSR的值,从异常退出时则可由的值,从异常退出时则可由SPSRSPSR来恢复来恢复CPSRCPSR。q 由于用户模式和系统模式不属于异常模式,他们没有由于用户模式和系统模式不属于异常模式,他们没有SPSRSPSR,当在这,当在这两种模式下访问两种模式下访问SPSRSPSR,结果