嵌入式系统软件的开发PPT课件_第1页
嵌入式系统软件的开发PPT课件_第2页
嵌入式系统软件的开发PPT课件_第3页
嵌入式系统软件的开发PPT课件_第4页
嵌入式系统软件的开发PPT课件_第5页
已阅读5页,还剩86页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1,第十章嵌入式系统软件的开发,2,第一节嵌入式系统开发模式,概述处理器及硬件开发平台的选定操作系统选定开发环境选定,3,10.1.1嵌入式系统开发模式概述,最大特点:软硬件综合开发,原因:,嵌入式产品是软硬件的结合体;,软件针对硬件开发、固化,不能进行任意修改。,4,嵌入式系统开发过程,系统定义,Yes,No,5,6,硬件设计制作,功能模块图设计,逻辑电路图设计,7,软件设计实现,软件概要设计,软件详细设计,软件实现,软件测试,8,图中各个术语介绍:系统定义此阶段与通用软件工程中的含义一致。是系统生命周期最简短的阶段。可行性研究用于确定是不是存在有效方法来解决系统定义中的关键问题。来决定该系统有没有开发的必要。需求分析确定功能需求、性能需求、环境需求。分析结果要提交系统的功能模块图。系统总体设计确定嵌入式总体构架,从功能上对软硬件进行划分。选择嵌入式微处理器、是否使用嵌入式OS,及OS种类等。这个步骤是最重要环节。,9,硬件设计实现硬件概要设计根据系统总体设计,对硬件进行进一步描述。详细确定各个功能模块的详细特性、内存大小、模块关联、总线等。要提供一份详细的硬件功能框图,每个模块的输入输出等。硬件详细设计给出实现硬件功能的具体器件。设计其周边电路,设计出电路的原理图。生成PCB图(printedcircuitBoard。硬件制作根据PCB加工出印刷电路板,焊接、装配后调试,直到证明各个模块连接无错误为止。硬件测试对制成的整体硬件进行功能、性能测试,修改。直到完全达到设计要求为止。,10,软硬件集成将测试完的软件系统装入硬件系统中。进行系统综合测试。验证系统功能,必须正确无误地实现系统功能。然后才能将软件固化在硬件系统中(EPROM)。复杂、费时间。功能性能测试将系统在实践中进行检验。如不能满足要求,还要修改。最糟糕情况下还要回到系统总体设计阶段,进行重新设计和实现。,11,软硬件协同开发,通常的嵌入式系统开发软/硬件协同开发,嵌入式软件开发,嵌入式硬件开发,嵌入式系统协同设计、测试、验证,12,10.1.2处理器及硬件开发平台的选定,选择依据:应用的类型及I/O接口主频及功耗对不同类型存储器的支持封装产品生命力和厂家实力、技术支持及第三方软件的支持硬件开发平台的选择,13,10.1.3操作系统选定,选择依据:选择嵌入式OS的必要性自建、购买或使用开源软件对嵌入式操作系统的功能、性能要求与硬件平台和开发工具的关系行业标准技术支持版税或服务费,14,操作系统与硬件平台的关系,操作系统应支持选定的硬件平台如果不支持,需考虑移植工作不同类型嵌入式微处理器之间的移植:任务上下文切换、时钟、中断等同类型微处理器但不同类型硬件板之间的移植:硬件接口及设备驱动程序,15,工具是否能为基于特定操作系统的应用开发提供最大支持:运行库与OS相结合提供应用工程创建和管理功能,构建基于特定操作系统的应用框架对操作系统的剪裁与配置提供高级调试功能提供配套的应用逻辑分析工具、覆盖测试工具等,16,10.1.4开发环境选定,对硬件平台的支持嵌入式软件开发特点是交叉开发。交叉链接。和交叉调试,开发工具要能支持选定的硬件平台,生成相应微处理器的目标程序。编程语言C/C+,汇编语言,JAVA,与嵌入式操作系统的关系根据自己系统情况适当选择OS,购买还是自编,或采用开源软件。(公开源代码的软件)。购买是需要付费的,自编OS代价高、时间长,但能获得更好的性能。开源软件需要自己改动,要经过精密仔细的调试和验证无错(折中方案)。,17,第二节实时软件分析设计方法,18,10.2实时软件分析设计方法,10.2.1实时软件的分析设计要求一个实时系统是硬件、软件和数据元素的集成。系统设计人员必须对系统元素需求恰当地分配功能和性能。实时性与功能一样重要。实时软件的三个特征:1.实时系统是受资源约束的。时间是系统的首要资源。要在限定的时间内完成一个定义的任务。,19,2.实时系统是紧凑和复杂的。实时系统代码量大,但是有关时间的标准代码只占很小部分。而这小部分代码是最为复杂的,有复杂的算法。3.在运行中是不需要用户参与的。实时软件必须能自检测到导致故障的问题,在其对数据和控制环境造成破坏之前进行处理和改正。满足系统响应时间是实时系统设计的一项重要任务。例:一个移动作战系统对敌目标的探测、攻击和接收上级命令的功能。其中自身定位系统如下图。用来确定系统在地球上的位置。(确定物体东西位置的为经度,确定位置南北的为纬度),20,21,采样时间和任务计算时间:,22,23,陀螺仪及三轴陀螺仪,陀螺仪是一个装在能自由转向的小框架上的小飞轮。当飞轮绕自身对称轴高速转动时,无论如何改变框架的方位,其中心轴的空间取向始终保持不变,角动量守恒定律。如飞机上装上三个定向指示仪,并使三个小飞轮的自转轴相互垂直,飞行员就可以通过飞轮轴相对于机身的指向来确定飞机的空间取向。单轴的只能测量一个方向的量,一个系统需三个陀螺仪,而三轴的一个陀螺仪就能替代三个单轴的。,24,10.2.2DARTS分析设计方法DesignAlgorithmforRealTimeSystems,嵌入式多任务软件开发阶段,着眼于将系统分为多个并发任务,而非多个模块。要定义任务间的接口关系,而非模块间的接口。模块划分和接口关系在任务设计阶段确定的。DARTS是结构化分析/设计的扩展,给出了划分任务的方法,定义任务间的接口机制。,25,一个机器人控制器。控制6个转轴,和I/O传感器交互作用。转轴与I/O由控制器控制。程序由控制面板操作启动。,上电,断电,手动,运行,停止,结束,程序选择,26,1.需求分析与说明需求分析给出了系统功能需求:功能、输入输出、外部接口需求、性能等。状态变迁图说明了操作员与系统之间所有交互作用。结合操作手册为用户提供了操作步骤。,27,2.系统设计系统设计是说明如何将系统分解成为多个任务。(1)数据流分析(DataFlowDiagram)数据流图有4种基本图形符号:箭头表示数据流;圆或椭圆表述数据加工处理,有输入和输出;表示数据存储;方框表示数据的源点或终点。以数据流为分析工具,从系统功能开始分析系统中的数据流。确定主要功能。每个数据流图都包含变换圈,表示系统完成的功能,箭头表示变换间的数据流动、数据存储区,数据词典。,数据字典是指对数据的数据项、数据结构、数据流、数据存储、处理逻辑、外部实体等进行定义和描述,其目的是对数据流程图中的各个元素做出详细的说明。,28,29,(2)划分任务识别出系统的所有功能和它们之间的数据流之后,还要识别任务的并行性的功能。将一个软件系统分解成并行任务,主要考虑系统中功能的异步性。分析数据流图中的变换,来确定那些变换可以并行处理,那些变换本质上是顺序的。通过这些方法划分任务,一个数据的变换对应一个任务,或者一个任务包括几个变换。一个变换是一个独立的任务,还是和其他接个变换一起组成一个任务,这要决定于:1)I/O依赖性;2)功能和时间关键性;3)计算需求;4)功能内聚,5)时间内聚;6)周期执行。这些因素都需要周密的考虑。,30,(3)定义任务接口有两类任务接口模块:通信模块TCM和同步互斥模块TSM来实现的任务的关联。这两个模块是由任务来调用的,称为系统调用。在调用TCM过程中要依靠TSM使两个任务同步和互斥,来保障数据的一致性和正确性。3.实例(略),31,4.任务设计任务间接口设计好之后,就要建立各个任务的结构。一个任务就是一个程序序列。画出各个任务的数据流图,从数据流图导出任务模块结构图。然后定义任务模块的接口。(见图10-22)5.模块构筑进行每个模块的详细设计,然后进行编码。6.任务与系统集成最后将模块连接成任务,然后将各任务连接成系统。,32,嵌入式软件开发工具,嵌入式软件开发工具的集成度和可用性将直接关系到嵌入式系统的开发效率。,33,嵌入式软件开发工具的分类,嵌入式软件开发阶段,需求分析(RequirementAnalysis),设计(SoftwareDesign),编码(Coding),测试(Test),发布、维护(Release),34,嵌入式软件开发工具的分类,根据不同的阶段,嵌入式软件开发工具可以分为:需求分析工具(RequirementAnalysisTools)软件设计工具(SoftwareDesignTools)编码、调试工具(CodingTools)测试工具(TestingTools)配置管理工具、维护工具等,35,主要嵌入式软件开发工具产品,36,嵌入式软件开发工具的分类,嵌入式软件的开发可分为以下几种:编写简单的板级测试软件,主要是辅助硬件的调试开发基本的驱动程序开发特定嵌入式操作系统的驱动程序(板级支持包)开发嵌入式系统软件,如嵌入式操作系统等开发应用软件,37,嵌入式软件开发工具的分类,从以上嵌入式软件开发分类来看,嵌入式软件开发工具可以分为:与嵌入式OS相关的开发工具,用于开发:基于嵌入式OS的应用部分驱动程序等与嵌入式OS无关的开发工具,用于开发:基本的驱动程序辅助硬件调试程序系统软件等,38,嵌入式软件的交叉开发环境,交叉开发环境是指用于嵌入式软件开发的所有工具软件的集合,一般包括:文本编辑器交叉编译器交叉调试器仿真器下载器等交叉开发环境由宿主机和目标机组成,宿主机与目标机之间在物理连接的基础上建立起逻辑连接。,39,交叉开发环境,目标机硬件,目标机应用系统,应用软件,应用中间件,目标机,OS,宿主机硬件,宿主机,OS,调,试,代,理,运,行,库,宿主机开发环境,编辑,编译,连接,调试,运行平台,Target,开发平台,Host,DownLoad,40,嵌入式软件的交叉开发环境,宿主机(Host):是用于开发嵌入式系统的计算机。一般为PC机(或者工作站),具备丰富的软硬件资源,为嵌入式软件的开发提供全过程支持。目标机(Target):即所开发的嵌入式系统,是嵌入式软件的运行环境,其硬件软件是为特定应用定制的。在开发过程中,目标机端需接收和执行宿主机发出的各种命令如设置断点、读内存、写内存等,将结果返回给宿主机,配合宿主机各方面的工作。,41,嵌入式软件的交叉开发环境,物理连接和逻辑连接物理连接是指宿主机与目标机通过物理线路连接在一起,连接方式主要有三种:串口以太口OCD(OnChipDebug)方式,如JTAG等物理连接是逻辑连接的基础。逻辑连接指宿主机与目标机间按某种通信协议建立起来的通信连接,目前逐步形成了一些通信协议的标准。,42,嵌入式软件实现阶段的开发过程,设计完成后,嵌入式软件的开发进入实现阶段,可分为三个步骤:生成、调试和固化运行。软件的生成主要是在宿主机上进行,利用各种工具完成对应用程序的编辑、交叉编译和链接工作,生成可供调试或固化的目标程序。调试是通过交叉调试器完成软件的调试工作。调试完成后还需进行必要的测试工作。固化运行是先用一定的工具将应用程序固化到目标机上,然后启动目标机,在没有任何工具干预的情况下应用程序能自动地启动运行。,43,嵌入式软件生成阶段,三个过程源代码程序的编写编译成各个目标模块链接成可供下载调试或固化的目标程序,编辑器,交叉编译器,交叉链接器,源程序,目标模块,可供调试/固化,库文件,44,交叉编译,把在宿主机上编写的高级语言程序编译成可以运行在目标机上的代码,即在宿主机上能够编译生成另一种CPU(嵌入式微处理器)上的二进制程序。,45,嵌入式软件的调试,交叉调试器是指调试程序和被调试程序运行在不同机器上的调试器;调试器通过某种方式能控制目标机上被调试程序的运行方式;通过调试器能查看和修改目标机上的内存、寄存器以及被调试程序中的变量等。,46,47,嵌入式软件的调试,交叉调试方式CrashandBurnRomMonitorRomEmulatorInCircuitEmulatorOnChipDebuggingSimulator方式(非交叉),48,CrashandBurn,最早的嵌入式应用软件调试方法。,在宿主机上编写代码,反复检查代码,直到编译通过,生成可执行程序,将程序固化(Burn)到目标机的非易失性存储器(E2PROM、FLASH等)中,在宿主机上反复检查码,查找问题根源,改写代码,启动目标机运行,观察程序是否正常工作,N,Y,结束,49,ROMMonitor,ROMMonitor是被固化且运行在目标机上的一段程序,负责监控目标机上被调试程序的运行,与宿主机端的调试器一起完成对应用程序的调试。调试器与ROMMonitor之间的通信遵循远程调试协议。,50,ROMMonitor调试方式,调试器Windows或其它桌面操作系统PC机等硬件,嵌入式硬件,监控程序(ROMMonitor),被调试程序,宿主机,目标机,逻辑上的连接,物理上的连接,51,ROMMonitor,在目标机上电或复位后首先执行的就是ROMMonitor,它对目标机进行一些必要的初始化初始化要求的外围设备,如最基本的串口和用于内存刷新的系统计时器芯片;初始化用于下载映像的内存系统;初始化中断控制器和安装中断处理程序。初始化自己的程序空间等待宿主机端的命令,52,ROMMonitor,ROMMonitor能配合调试器完成:程序映像下载对目标机系统内存的读写对寄存器的读写设置和清除不同类型的断点单步执行指令复位系统等调试功能,53,ROMMonitor,调试过程(1)启动目标机,监控器掌握对目标机的控制,等待和调试器建立连接;(2)启动调试器,并和监控器建立起通信连接;(3)使用调试器将应用程序下载到目标机上的RAM空间中;(4)使用调试器进行调试,发出各种调试命令,监控器解释并执行这些命令,通过目标机上的各种异常来获取对目标机的控制,将命令执行结果回传给调试器;(5)如果程序有问题,在调试器的帮助下定位错误;修改之后再重新编译链接并下载程序,开始新的调试,如此反复直至程序正确运行为止。,54,ROMMonitor,优点:提高调试程序的效率,缩短开发周期,降低成本;简单、方便;可扩展性强,可支持许多高级调试功能;成本低廉,不需专门的调试硬件支持;几乎所有的交叉调试器都支持这种方式。,55,ROMMonitor,缺点:DebugMonitor需要用CrashandBurn方法开发;当ROMMonitor占用CPU时,应用程序不响应外部的中断,因此不便调试有时间特性的程序;某些调试功能依赖于CPU硬件的支持(如硬件断点功能);ROMMonitor要占用目标机一定数量的资源,如CPU、RAM、ROM和通信设备等资源;调试环境不同于实际目标环境。,56,仿真开发方式,嵌入式应用的开发经常会遭遇缺少目标机环境、缺乏目标机芯片等资源的问题,而开发过程又不可能停止,因此自然就提出了根据不同的应用需要,利用仿真器件、仿真环境进行开发的方法。,硬件仿真开发ROMEmulatorICEOCD软件仿真开发,57,ROMEmulator(软硬结合仿真器),ROMEmulator是一种用于替代目标机上的ROM芯片的设备,即ROM仿真器。利用这种设备,目标机可以没有ROM芯片,但目标机的CPU可以读取ROMEmulator设备上ROM芯片的内容:ROMEmulator设备上的ROM芯片的地址可以实时地映射到目标机的ROM地址空间,从而仿真(Emulation)目标机的ROM。,58,ROMEmulator,ROMEmulator的调试方式是一种不完全的调试方式:ROMEmulator设备只是为目标机提供ROM芯片和在Target和Host间建立一条高速的通信通道,因此它经常和前面两种调试方式结合起来形成一种完备的调试方式。ROMEmulator的典型应用就是和ROMMonitor的调试方式相结合。,59,ROMEmulator,优点:目标机可以没有ROM芯片、可以使用ROMEmulator提供的ROM空间且不需要用别的工具来写ROM。缺点:目标机必须能支持外部ROM存储空间,而且由于其通常要和ROMMonitor配合使用,因此它拥有ROMMonitor的所有缺点。另外,现在的嵌入式微处理器一般都有集成的ROM,因此不能用这种方法了。,60,ICE,ICE(In-CircuitEmulator)是一种用于替代目标机上CPU的设备,即在线仿真器;它比一般的CPU有更多的引出线,能够将内部的信号输出到被控制的目标机;ICE上的Memory也可以被映射到用户的程序空间,这样即使目标机不存在的情形下也可以进行代码的调试。,61,ICE调试结构,连接ICE和目标机时,一般是将目标机的CPU取下,而将ICE的CPU引出线接到目标机的CPU插槽。用ICE进行调试时,在Host端运行的调试器通过ICE来控制目标机上运行的程序。,ICE,62,ICE,功能特点同时支持软断点和硬件断点的设置;设置各种复杂的断点和触发器;实时跟踪目标程序的运行,并可实现选择性的跟踪;支持“TimeStamp”;允许用户设置“Timer”;提供“ShadowRAM”,能在不中断被调试程序的运行下查看内存和变量即非干扰调试查询。,63,ICE,适用于:调试实时的应用系统调试设备驱动程序对硬件进行功能和性能的测试实时性能分析缺点:价格太昂贵,不利于团队开发所仿CPU有限,64,OCD,OCD(OnChipDebugging)是CPU芯片提供的一种调试功能(片上调试),可以认为是一种廉价的ICE功能:OCD的价格只有ICE的20%,但提供了ICE80%的功能。,65,OCD调试结构,66,OCD,调试方法将CPU的模式分为一般模式和调试模式一般模式下,CPU从内存读取指令执行调试模式下,CPU首先从调试端口读取指令,通过调试端口可以控制CPU进入和退出调试模式;Host端的调试器可以直接向目标机发送要执行的指令,读写目标机的内存和各种寄存器,控制目标程序的运行以及完成各种复杂的调试功能。,67,OCD,优点:不占用目标机的资源;调试环境和最终的程序运行环境基本一致;支持软硬断点、Trace功能;精确计量程序的执行时间;提供时序分析功能。,68,OCD,缺点:调试的实时性不如ICE;不支持非干扰调试查询;CPU必需具有OCD功能。,69,各种OCD仿真器实例,70,边界扫描技术(JTAG),JTAG标准测试访问接口与边界扫描结构(StandardTestAccessPortandBoundaryScanArchitecture),已被IEEE1149.1标准所采纳,是面向用户的测试接口。该接口一般由4个引脚组成:测试数据输入(TDI)测试数据输出(TDO)测试时钟(TCK)测试模式选择引脚(TMS)异步测试复位引脚(TRST,可选),71,边界扫描技术(JTAG),优点:可以通过边界扫描操作测试整个板的电气连接,特别为表面贴元件提供方便;各个引脚信号的采样,并可强制引脚输出用以测试外围芯片;可以软件下载、执行、调试和控制,为复杂的实时跟踪调试提供路径;可以进行多内核和多处理器的板级和芯片级的调试,通过串接,为芯片制造商提供芯片生产、测试途径;不占用系统资源,能够调试没有外部总线的芯片,代价小。,72,边界扫描技术(JTAG),缺点:通过串口依次传递数据,速度比较慢;只能进行软件断点级别的调试;不能完成实时跟踪和多种事件触发等复杂调试功能。,73,边界扫描技术(JTAG),74,Simulator,交叉开发方式存在如下缺点:硬件支持必须有目标机或评估板易使用性普通编程人员不熟悉廉价性成本高可移植性、可扩展性不高团队开发较难开发周期较长,75,Simulator(全软件模拟器),一种软件模拟器,在宿主机上创建一个虚拟的目标机环境,再将应用系统下载到这个虚拟目标机上运行调试。软件模拟的对象仿真处理器仿真外设仿真环境软件仿真的级别指令级仿真开发API级仿真开发,76,应用仿真开发环境示意图,77,结合了仿真的软件开发过程,78,Simulator,优点最大好处就是可以不用真正的目标机,可以在目标机环境并不存在的条件下开发目标机上的应用系统,并且在调试时可以利用Host资源提供更详细的错误诊断信息。,79,Simulator,缺点和实际的运行环境差别很大设备模拟的局限性较大实时特性较差对Host的资源要求较高适用范围对时间特性没有严格要求、没有特殊外设、只需要验证逻辑正确的应用程序。,80,嵌入式软件的测试,测试工具能够用来辅助测试的工具,主要用来支持测试人员的工作,本身不能直接用来进行测试。测试工具一般都是通用工具,测试人员应该根据实际情况对它们进行适当的调整。嵌入式软件测试中经常用到的测试工具有:内存分析工具性能分析工具覆盖分析工具缺陷跟踪工具等,81,嵌入式软件的测试,内存分析工具嵌入式系统的内存资源通常是受限的,内存分析工具可以用来处理在进行动态内存分配时产生的缺陷。当动态分配的内存被错误地引用时,产生的错误通常难以再现,出现的失效难以追踪,使用内存分析工具可以很好地检测出这类缺陷。目前常用的内存分析工具有软件和硬件两种:基于软件的内存分析工具可能会对代码的执行性能带来很大影响,从而影响系统的实时性;基于硬件的

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论