第2讲(Part1)--基于ARM的开发平台以及ARM在嵌入式系统中的应用.ppt
《第2讲(Part1)--基于ARM的开发平台以及ARM在嵌入式系统中的应用.ppt》由会员分享,可在线阅读,更多相关《第2讲(Part1)--基于ARM的开发平台以及ARM在嵌入式系统中的应用.ppt(66页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、第第2讲讲(Part1)-基于基于ARM的开发平台以及的开发平台以及ARM在嵌入式系统中在嵌入式系统中的应用的应用ARM技术的应用领域及特点nARMAdvanced RISC Machines qARM(Advanced RISC Machines),),既可以认为是既可以认为是一个公司的名字,也可以认为是对一类微处理器的通称,一个公司的名字,也可以认为是对一类微处理器的通称,还可以认为是一种技术的名字。还可以认为是一种技术的名字。q1991年年ARM公司成立于英国剑桥,主要出售芯片设公司成立于英国剑桥,主要出售芯片设计技术的授权。计技术的授权。ARM技术的应用领域及特点ARM 公司的Chip
2、 less模式q世界各大半导体生产商从世界各大半导体生产商从ARMARM公司购买其设计的公司购买其设计的ARMARM微处微处理器核,根据各自不同的应用领域,加入适当的外围电路,理器核,根据各自不同的应用领域,加入适当的外围电路,从而形成自己的从而形成自己的ARMARM微处理器芯片进入市场。微处理器芯片进入市场。q基于基于ARM技术的微处理器应用约占据了技术的微处理器应用约占据了32位位RISC微处微处 理器理器75以上的市场份额,以上的市场份额,ARM技术正在逐步渗入到我们技术正在逐步渗入到我们生活的各个方面。生活的各个方面。q我国的我国的中兴集成电路、中兴集成电路、大唐电讯、中芯国际和上海华
3、虹,大唐电讯、中芯国际和上海华虹,以及国外的一些公司如德州仪器、意法半导体、以及国外的一些公司如德州仪器、意法半导体、PhilipsPhilips、IntelIntel、SamsungSamsung等都推出了自己设计的基于等都推出了自己设计的基于ARMARM核的处理器。核的处理器。ARM技术的应用领域及特点ARM微处理器的应用领域 工业控制领域:作为工业控制领域:作为3232的的RISCRISC架构,架构,ARMARM微控制器微控制器的低功耗、高性价比,向传统的的低功耗、高性价比,向传统的8 8位位/16/16位微控制器位微控制器提出了挑战。提出了挑战。q到目前为止,到目前为止,ARM微处理器
4、及技术的应用已经广泛深微处理器及技术的应用已经广泛深入到国民经济的各个领域入到国民经济的各个领域ARM技术的应用领域及特点ARM微处理器的应用领域q网络应用:采用网络应用:采用ARM技术的技术的ADSL芯片,芯片,ARM在语音在语音及视频处理上进行了优化,获得广泛支持。及视频处理上进行了优化,获得广泛支持。q消费类电子产品:消费类电子产品:ARM技术在目前流行的数字音频播技术在目前流行的数字音频播放器、数字机顶盒和游戏机中得到广泛采用。放器、数字机顶盒和游戏机中得到广泛采用。q成像和安全产品:现在流行的数码相机和打印机中绝大成像和安全产品:现在流行的数码相机和打印机中绝大部分采用部分采用ARM
5、技术,手机中的技术,手机中的32位位SIM智能卡也采用了智能卡也采用了ARM技术。技术。qARM技术的应用领域及特点ARM微处理器的特点低功耗、低成本、高性能低功耗、低成本、高性能采用RISC指令集q低功耗、低成本、高性能低功耗、低成本、高性能使用大量的寄存器ARM/THUMB指令支持三/五级流水线ARM技术的应用领域及特点ARM微处理器的特点采用采用RISCRISC体系结构体系结构q采用采用RISC架构的架构的ARM处理器一般具有如下特点:处理器一般具有如下特点:固定长度的指令格式,指令归整、简单、基固定长度的指令格式,指令归整、简单、基 本寻本寻址方式有址方式有23种;种;使用单周期指令,
6、便于流水线操作执行;使用单周期指令,便于流水线操作执行;大量使用寄存器,数据处理指令只对寄存器进行大量使用寄存器,数据处理指令只对寄存器进行操作,只有加载操作,只有加载/存储指令可以访问存储器,以提高指存储指令可以访问存储器,以提高指令的执行效率。令的执行效率。ARM技术的应用领域及特点ARM微处理器的特点大量使用寄存器大量使用寄存器qARM 处理器共有处理器共有37个寄存器,被分为若干个组,这些个寄存器,被分为若干个组,这些寄存器包括:寄存器包括:31个通用寄存器,包括程序计数器(个通用寄存器,包括程序计数器(PC 指针),指针),均为均为32位的寄存器;位的寄存器;6个状态寄存器,用以标识
7、个状态寄存器,用以标识CPU的工作状态及程的工作状态及程序的运行状态,均为序的运行状态,均为32位。位。ARM技术的应用领域及特点ARM微处理器的特点高效的指令系统高效的指令系统qARM微处理器支持两种指令集:微处理器支持两种指令集:ARM指令集和指令集和Thumb指令集。指令集。qARM指令为指令为32位的长度,位的长度,Thumb指令为指令为16位长度。位长度。Thumb指令集为指令集为ARM指令集的功能子集,但与等价的指令集的功能子集,但与等价的ARM代码相比较,可节省代码相比较,可节省3040以上的存储空间,同时具备以上的存储空间,同时具备32位代码的所有优点。位代码的所有优点。ARM
8、技术的应用领域及特点ARM微处理器的特点其他技术其他技术q除此以外,除此以外,ARM体系结构还采用了一些特别的技术,体系结构还采用了一些特别的技术,在保证高性能的前提下尽量缩小芯片的面积,并降低功耗:在保证高性能的前提下尽量缩小芯片的面积,并降低功耗:q所有的指令都可根据前面的执行结果决定是否被执行,所有的指令都可根据前面的执行结果决定是否被执行,从而提高指令的执行效率。从而提高指令的执行效率。q可用加载可用加载/存储指令批量传输数据,以提高数据的传输效存储指令批量传输数据,以提高数据的传输效率。率。q可在一条数据处理指令中同时完成逻辑处理和移位处理。可在一条数据处理指令中同时完成逻辑处理和移
9、位处理。q在循环处理中使用地址的自动增减来提高运行效率。在循环处理中使用地址的自动增减来提高运行效率。ARM微处理器系列qARM7系列系列qARM9系列系列qARM9E系列系列qARM10E系列系列qSecurCore系列系列qIntel的的Xscaleq其中,其中,ARM7、ARM9、ARM9E和和ARM10为为4个通用处个通用处理器系列,每一个系列提供一套相对独特的性能来满足不同理器系列,每一个系列提供一套相对独特的性能来满足不同应用领域的需求。应用领域的需求。SecurCore系列专门为安全要求较高的应系列专门为安全要求较高的应用而设计。用而设计。ARM微处理器系列qARM9系列微处理器
10、在高性能和低功耗特性方面提供最系列微处理器在高性能和低功耗特性方面提供最佳的表现。具有以下特点:佳的表现。具有以下特点:5级整数流水线,指令执行效率更高。级整数流水线,指令执行效率更高。提供提供1.1MIPS/MHz的哈佛结构。的哈佛结构。支持支持32位位ARM指令集和指令集和16位位Thumb指令集。指令集。支持支持32位的高速位的高速AMBA总线接口。总线接口。全性能的全性能的MMU,支持支持Windows CE、Linux、Palm OS等多种等多种主流嵌入式操作系统。主流嵌入式操作系统。MPU支持实时操作系统。支持实时操作系统。支持数据支持数据Cache和指令和指令Cache,具有更高
11、的指令和数据处理能力。具有更高的指令和数据处理能力。ARM微处理器系列qARM9ARM9系列微处理器主要应用于无线设备、仪器仪表、安系列微处理器主要应用于无线设备、仪器仪表、安全系统、机顶盒、高端打印机、数字照相机和数字摄像全系统、机顶盒、高端打印机、数字照相机和数字摄像机等。机等。qARM9ARM9系列微处理器包含系列微处理器包含ARM920TARM920T、ARM922TARM922T和和ARM940TARM940T三三种类型,以适用于不同的应用场合。种类型,以适用于不同的应用场合。ARM处理器的工作状态q从编程的角度看,从编程的角度看,ARMARM微处理器的工作状态一般有两种,微处理器的
12、工作状态一般有两种,并可在两种状态之间切换:并可在两种状态之间切换:ARM状态,此时处理器执行状态,此时处理器执行32位的字对齐的位的字对齐的ARM指指令;令;Thumb状态,此时处理器执行状态,此时处理器执行16位的、半字对齐的位的、半字对齐的Thumb指令。指令。ARM处理器的工作状态qTHUMB指令是ARM指令的子集q可以相互调用,只要遵循一定的调用规则qThumb指令与ARM指令的时间效率和空间效率关系为:存储空间约为ARM代码的6070指令数比ARM代码多约3040存储器为32位时ARM代码比Thumb代码快约40存储器为16位时Thumb比ARM代码快约4050使用Thumb代码,
13、存储器的功耗会降低约30ARM处理器的工作状态状态切换方法状态切换方法 qARMARM指令集和指令集和ThumbThumb指令集均有切换处理器状态的指令,指令集均有切换处理器状态的指令,并可在两种工作状态之间切换,并可在两种工作状态之间切换,q在开始执行代码时,应该处于在开始执行代码时,应该处于ARMARM状态。状态。ARM处理器的工作状态进入进入ThumbThumb状态状态q当操作数寄存器的状态位(位当操作数寄存器的状态位(位0 0)为)为1 1时,可以采用执时,可以采用执行行BXBX指令的方法,使微处理器从指令的方法,使微处理器从ARMARM状态切换到状态切换到ThumbThumb状态。状
14、态。q当处理器处于当处理器处于ThumbThumb状态时发生异常(如状态时发生异常(如IRQIRQ、FIQFIQ、UndefUndef、AbortAbort、SWISWI等),则异常处理返回时,自动切等),则异常处理返回时,自动切换到换到ThumbThumb状态。状态。ARM处理器的工作状态切换到切换到ARMARM状态状态q当操作数寄存器的状态位为当操作数寄存器的状态位为0 0时,执行时,执行BXBX指令时可以使指令时可以使微处理器从微处理器从ThumbThumb状态切换到状态切换到ARMARM状态。状态。q在处理器进行异常处理时,把在处理器进行异常处理时,把PCPC指针放入异常模式链指针放入
15、异常模式链接寄存器中,并从异常向量地址开始执行程序,也可接寄存器中,并从异常向量地址开始执行程序,也可以使处理器切换到以使处理器切换到ARMARM状态。状态。ARM处理器的工作模式qusrusr:ARMARM处理器正常的程序执行状态处理器正常的程序执行状态qfiqfiq:用于高速数据传输或通道处理用于高速数据传输或通道处理qirqirq:用于通用的中断处理用于通用的中断处理qsvcsvc:操作系统使用的保护模式操作系统使用的保护模式qabtabt:用于虚拟存储及存储保护用于虚拟存储及存储保护qsyssys:运行具有特权的操作系统任务运行具有特权的操作系统任务qundund:当:当出现未定义指令
16、终止时进入该模式出现未定义指令终止时进入该模式ARM处理器的工作模式用户模式和特权模式q除了用户模式之外的其他除了用户模式之外的其他6 6种处理器模式称为特权模式种处理器模式称为特权模式q特权模式下,程序可以访问所有的系统资源,也可以特权模式下,程序可以访问所有的系统资源,也可以任意地进行处理器模式的切换。任意地进行处理器模式的切换。q特权模式中,除系统模式外,其他特权模式中,除系统模式外,其他5 5种模式又称为异常模式种模式又称为异常模式q大多数的用户程序运行在用户模式下,此时,应用程大多数的用户程序运行在用户模式下,此时,应用程序不能够访问一些受操作系统保护的系统资源,应用序不能够访问一些
17、受操作系统保护的系统资源,应用程序也不能直接进行处理器模式的切换。程序也不能直接进行处理器模式的切换。q用户模式下,当需要进行处理器模式切换时,应用程用户模式下,当需要进行处理器模式切换时,应用程序可以产生异常处理,在异常处理中进行处理器模式序可以产生异常处理,在异常处理中进行处理器模式的切换。的切换。ARM处理器的工作模式q处理器模式可以通过软件进行切换,也可以通过外部处理器模式可以通过软件进行切换,也可以通过外部中断或者异常处理过程进行切换。中断或者异常处理过程进行切换。q当应用程序发生异常中断时,处理器进入相应的异常当应用程序发生异常中断时,处理器进入相应的异常模式。在每一种异常模式下都
18、有一组寄存器,可以保模式。在每一种异常模式下都有一组寄存器,可以保证在进入异常模式时,用户模式下的寄存器不被破坏。证在进入异常模式时,用户模式下的寄存器不被破坏。q系统模式并不是通过异常进入的,它和用户模式具有系统模式并不是通过异常进入的,它和用户模式具有完全一样的寄存器。但是系统模式属于特权模式,可完全一样的寄存器。但是系统模式属于特权模式,可以访问所有的系统资源,也可以直接进行处理器模式以访问所有的系统资源,也可以直接进行处理器模式切换,它主要供操作系统任务使用。该任务仍然使用切换,它主要供操作系统任务使用。该任务仍然使用用户模式的寄存器组,而不是使用异常模式下相应的用户模式的寄存器组,而
19、不是使用异常模式下相应的寄存器组,这样可以保证当异常中断发生时任务状态寄存器组,这样可以保证当异常中断发生时任务状态不被破坏。不被破坏。ARM处理器的存储器格式qARMARM体系结构所支持的最大寻址空间为体系结构所支持的最大寻址空间为4GB4GB(2 23232字节)字节)qARMARM体系结构将存储器看作是从零地址开始的字节的线体系结构将存储器看作是从零地址开始的字节的线性组合。从零字节到三字节放置第一个存储的字数据,性组合。从零字节到三字节放置第一个存储的字数据,从第四个字节到第七个字节放置第二个存储的字数据,从第四个字节到第七个字节放置第二个存储的字数据,依次排列。依次排列。qARMAR
20、M体系结构可以用两种方法存储字数据,称之为大端体系结构可以用两种方法存储字数据,称之为大端格式和小端格式格式和小端格式 ARM处理器的存储器格式qARMARM微处理器的指令长度可以是微处理器的指令长度可以是3232位(在位(在ARMARM状态下),状态下),也可以为也可以为1616位(在位(在ThumbThumb状态下)。状态下)。qARMARM微处理器中支持字节(微处理器中支持字节(8 8位)、半字(位)、半字(1616位)、字位)、字(3232位)三种数据类型,其中,字需要位)三种数据类型,其中,字需要4 4字节对齐(地字节对齐(地址的低两位为址的低两位为0 0)、半字需要)、半字需要2
21、2字节对齐(地址的最低字节对齐(地址的最低位为位为0 0)ARM处理器的存储器格式非对齐的存储访问操作非对齐的存储访问操作 q在在ARMARM种,如果存储单元的地址没有遵守对齐规则,则种,如果存储单元的地址没有遵守对齐规则,则称为非对齐的存储访问操作。称为非对齐的存储访问操作。q非对齐的指令预取操作非对齐的指令预取操作q非对齐的数据访问操作非对齐的数据访问操作ARM处理器的存储器格式非对齐的指令预取操作非对齐的指令预取操作 q当处理器处于当处理器处于ARMARM状态期间,如果写入到寄存器状态期间,如果写入到寄存器PCPC中的中的值是非字对齐的,要么指令执行的结果不可预知,要值是非字对齐的,要么
22、指令执行的结果不可预知,要么地址值中最低两位被忽略。么地址值中最低两位被忽略。q当处理器处于当处理器处于THUMBTHUMB状态期间,如果写入到寄存器状态期间,如果写入到寄存器PCPC中中的值是非半字对齐的,要么指令执行的结果不可预知,的值是非半字对齐的,要么指令执行的结果不可预知,要么地址值中最低位被忽略。要么地址值中最低位被忽略。ARM处理器的存储器格式非对齐的数据访问操作非对齐的数据访问操作 q对于对于Load/StoreLoad/Store操作,如果是非对齐的数据访问操作,操作,如果是非对齐的数据访问操作,系统定义了三种可能的结果:系统定义了三种可能的结果:执行的结果不可预知执行的结果
23、不可预知忽略字单元地址的低两位的值,即访问地址为忽略字单元地址的低两位的值,即访问地址为(address AND 0XFFFFFFFC)(address AND 0XFFFFFFFC)的字单元;忽略半字单元的字单元;忽略半字单元地址的最低位的值,即访问地址为地址的最低位的值,即访问地址为(address AND(address AND 0XFFFFFFFE)0XFFFFFFFE)的半字单元。的半字单元。忽略字单元地址的低两位的值;忽略半字单元地址的最忽略字单元地址的低两位的值;忽略半字单元地址的最低位的值;由存储系统实现这种忽略。也就是说,这低位的值;由存储系统实现这种忽略。也就是说,这时该地
24、址值原封不动地送到存储系统。时该地址值原封不动地送到存储系统。q当发生非对齐的数据访问时,到底采用上述三种方法中当发生非对齐的数据访问时,到底采用上述三种方法中的哪一种,是由各指令指定的。的哪一种,是由各指令指定的。ARM 处理器的寄存器格式nARM微处理器共有微处理器共有37个个32位寄存器,其中位寄存器,其中31个为通用寄存器,个为通用寄存器,6个为状态寄存器。个为状态寄存器。但是这些寄存器不能被同时访问,具体哪但是这些寄存器不能被同时访问,具体哪些寄存器是可编程访问的,取决微处理器些寄存器是可编程访问的,取决微处理器的工作状态及具体的运行模式。但在任何的工作状态及具体的运行模式。但在任何
25、时候,通用寄存器时候,通用寄存器R14R0、程序计数器、程序计数器PC、一个或两个状态寄存器都是可访问的。、一个或两个状态寄存器都是可访问的。ARM 处理器的寄存器格式q通用寄存器:通用寄存器包括R0R15,可以分为三类:未分组寄存器未分组寄存器R0R0R7R7分组寄存器分组寄存器R8R8R14R14程序计数器程序计数器PC(R15)PC(R15)ARM 处理器的寄存器格式ARM 处理器的寄存器格式未分组寄存器未分组寄存器R0R0R7R7q在所有的运行模式下,未分组寄存器都指向同一个物理寄存器,他们未被系统用作特殊的用途,因此,在中断或异常处理进行运行模式转换时,由于不同的处理器运行模式均使用
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- Part1 基于 ARM 开发 平台 以及 嵌入式 系统 中的 应用
限制150内