版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
第1章汽车嵌入式计算机系统基础概述2023/11/28汽车嵌入式系统设计11.1嵌入式系统概述1.1.1嵌入式系统的定义与组成1.嵌入式系统的定义我国GB/T22033-2017《信息技术——嵌入式系统术语》中对嵌入式系统的定义是:“置入应用对象内部,起信息处理或控制作用的专用计算机系统。”可见,嵌入式系统是一种专用的计算机系统,作为装置或设备的一部分。事实上,所有带有数字功能与接口的设备,如电子手表、微波炉、空调、洗衣机、智能电饭煲、录像机、汽车、电动自行车、巡航导弹、跑步机、GPS接收模块等,都使用了嵌入式系统,尤其像汽车等复杂系统为了满足各种特定功能的需求采用很多套嵌入式系统。2023/11/28汽车嵌入式系统设计2从应用角度来说,嵌入式系统是软件和硬件的综合体,还可以涵盖机械等附属装置。普遍认同的嵌入式系统定义为:“以应用为中心,以计算机技术为基础,软硬件可裁剪,适应应用系统对功能、可靠性、成本、体积、功耗等有严格要求的专用计算机系统。”嵌入式系统所用的计算机:嵌入到被控对象中的专用微处理器,功能比通用计算机专门化,具有通用计算机所不具备的专门性能和功用,是针对某个方面特别设计的、合适的运算速度、高可靠性和较低成本的专用计算机系统。嵌入式系统形式:(1)单个程序实现整个控制逻辑(大多数)(2)包含操作系统的嵌入式系统(少部分)2023/11/28汽车嵌入式系统设计32.嵌入式系统的组成嵌入式系统是专用计算机系统,同样遵循冯·诺依曼提出的“程序存储”和“程序控制”计算机基本工作原理,其内部也采用计算机经典结构,如图1-1所示。2023/11/28汽车嵌入式系统设计4图1-1计算机经典结构示意图中央处理器(CPU,CentralProcessingUnit)是计算机的核心,是整个系统的运算和指挥控制中心,由运算器、控制器、寄存器组等组成。运算器的核心是算术逻辑运算单元(ALU,ArithmeticandLogicUnit),它以加法器为基础,辅以移位寄存器和相应的控制逻辑组合而成,在控制信号的作用下完成加、减、乘、除、各种逻辑运算等操作。控制器(CU,ControlUnit)一般由指令寄存器、指令译码器和操作控制电路组成,是处理器的指挥控制中心,协调处理器有序工作,根据时序产生相应的控制信号,协调各部件工作。寄存器(R,Registers)是处理器内部若干个存储单元。2023/11/28汽车嵌入式系统设计5嵌入式系统装置一般由嵌入式计算机系统和感知元件、执行装置组成,其基本架构见图1-2所示。2023/11/28汽车嵌入式系统设计6图1-2嵌入式系统的基本架构嵌入式计算机系统主要有硬件层、中间层和系统软件层等几部分组成。(1)硬件层硬件层中包含嵌入式微处理器,存储器(SDRAM、ROM、Flash、EEPROM等),通用设备通信接口(SCI、SPI、IIC、CAN、LAN等)和输入输出接口(I/O、A/D、D/A、C/T等)。1)嵌入式微处理器嵌入式微处理器是嵌入式系统硬件层的核心,与通用CPU最大的区别在于它大多工作在为特定用户群专用设计的系统中,将通用CPU许多由板卡完成的任务集成在芯片内部,从而有利于嵌入式系统在设计时趋于小型化,同时还具有很高的效率和可靠性。2023/11/28汽车嵌入式系统设计72)存储器存储器用来存放数据和程序。嵌入式系统的存储器包含主存和辅存。主存可以被嵌入式微处理器直接访问,用来存放系统和用户的程序及数据;辅存用来存放大数据量的程序代码或信息,它的容量大、但读取速度与主存相比要慢很多,一般用来长期保存用户的信息。3)通用设备通信接口和通用输入输出接口通用设备通信接口和输入输出接口是嵌入式计算机系统和外界交互的接口,通过与外部其他设备、传感器、执行器等连接来实现微处理器的输入/输出功能。2023/11/28汽车嵌入式系统设计8(2)中间层硬件层与软件层之间为中间层,也称为硬件抽象层(HAL,HardwareAbstractLayer)或板级支持包(BSP,BoardSupportPackage),它将系统上层软件与底层硬件分离开来,使系统的底层驱动程序与硬件无关,上层软件开发人员无需关心底层硬件的具体情况,根据BSP层提供的接口即可进行开发。该层一般包含相关底层硬件的初始化、数据的输入/输出操作和硬件设备的配置功能。BSP具有以下两个特点:①硬件相关性:因为嵌入式实时系统的硬件环境具有应用相关性,而作为上层软件与硬件平台之间的接口,BSP需要为操作系统提供操作和控制具体硬件的方法。②操作系统相关性:不同的操作系统具有各自的软件层次结构,因此,不同的操作系统具有特定的硬件接口形式。2023/11/28汽车嵌入式系统设计9系统初始化过程可以分为3个主要环节,按照自底向上、从硬件到软件的次序依次为:片级初始化、板级初始化和系统级初始化。片级初始化:完成嵌入式微处理器的初始化,包括设置嵌入式微处理器的核心寄存器和控制寄存器、嵌入式微处理器核心工作模式和嵌入式微处理器的局部总线模式等。板级初始化:完成嵌入式微处理器以外的其他硬件设备的初始化。系统初始化:该初始化过程以软件初始化为主,主要进行操作系统的初始化。2023/11/28汽车嵌入式系统设计10与硬件相关的驱动程序是BSP设计与开发中非常关键的环节。尽管BSP中包含硬件相关的设备驱动程序,但是这些设备驱动程序通常不直接由BSP使用,而是在系统初始化过程中由BSP将他们与操作系统中通用的设备驱动程序关联起来,并在随后的应用中由通用的设备驱动程序调用,实现对硬件设备的操作。(3)软件层软件层由实时多任务操作系统(RTOS,Real-TimeOperationSystem)、文件系统、图形用户接口(GUI,GraphicUserInterface)、网络系统及通用组件模块组成。RTOS是嵌入式应用软件的基础和开发平台。2023/11/28汽车嵌入式系统设计111.1.2嵌入式系统的分类1.嵌入式系统根据复杂程度分:(1)小型嵌入式系统采用8位(如采用MCS-51系列单片机)或者16位的微控制器(MCU,MicroControllerUnit)设计,应用对象的要求较低、功能较简单,控制逻辑也不复杂。(2)中型嵌入式系统采用16位或者32位的微控制器、数字信号处理器(DSP,DigitalSignalProcessor)或者精简指令集RISC计算机等设计,硬件和软件复杂度都比较大。(3)复杂嵌入式系统其软件和硬件都非常复杂,需要可升级的处理器或者可配置的处理器和可编程逻辑阵列(如FPGA、CPLD等器件)。2023/11/28汽车嵌入式系统设计12由于嵌入式系统由硬件和软件两大部分组成,因此,也可以从硬件和软件方面进行分类。2.嵌入式系统根据硬件(嵌入式处理器)分类(1)嵌入式微处理器(MPU,MicroMicro-ProcessorUnit)(2)嵌入式微控制器(MCU,Micro-ControllerUnit)(3)嵌入式DSP处理器(EDSP,EmbeddedDigitalSignalProcessor)(4)嵌入式片上系统(SoC,SystemonChip)2023/11/28汽车嵌入式系统设计133.嵌入式系统根据软件(操作系统)分类(1)实时系统实时系统又分为硬实时系统和软实时系统两类。(2)分时系统4.嵌入式系统根据应用形态分类(1)由单个程序实现整个控制逻辑(2)带有操作系统的嵌入式系统2023/11/28汽车嵌入式系统设计14一般带有操作系统的嵌入式系统具有以下特点:1)可裁剪性。支持开放性和可伸缩性的体系结构。2)强实时性。实时性一般较强,可用于各种设备控制中。3)统一的接口。提供设备统一的驱动接口。4)操作方便、简单、提供友好的图形GUI和图形界面,追求易学易用。5)提供强大的网络功能,支持TCP/IP协议及其他协议,提供TCP/UDP/IP/PPP协议支持及统一的MAC访问层接口,为各种移动计算设备预留接口。2023/11/28汽车嵌入式系统设计156)强稳定性,弱交互性。嵌入式系统一旦开始运行就不需要用户过多的干预、这就要求系统管理的稳定性要强。嵌入式操作系统的用户接口一般不提供操作命令,它通过系统的调用命令向用户程序提供服务。7)固化代码。在嵌入式系统中,嵌入式操作系统和应用软件被固化在嵌入式系统计算机的ROM中。8)更好的硬件适应性,也就是良好的移植性。9)嵌入式系统和具体应用有机结合在一起,它的升级换代也是和具体产品同步进行,因此嵌入式系统产品一旦进入市场,应具有较长的生命周期。2023/11/28汽车嵌入式系统设计161.1.3嵌入式系统的发展历史1.计算机系统发展方向及其产品(1)面向科学运算和海量数据处理的超级计算机或服务器。(2)面向个人应用的PC(PersonComputer)计算机(3)面向嵌入式应用的嵌入式计算机系统2.嵌入式计算机系统的发展经历(1)初级阶段(单芯片微机形成阶段)(2)成熟阶段(性能完善提高阶段)(3)高速发展阶段(微控制器化阶段)2023/11/28汽车嵌入式系统设计17嵌入式系统将先进的计算机技术、半导体技术和电子技术嵌入到对象体系中,是实现对象体系智能化控制的计算机系统。不同于通用计算机体系结构,嵌入式系统采用了系统芯片化的独立发展道路,力求将CPU、各类存储器、各种接口在内的计算机系统集成在一个芯片上。2023/11/28汽车嵌入式系统设计181.1.4嵌入式系统的应用嵌入式系统的应用前景非常广泛,占据着电子产业神经中枢的地位,其应用可谓“无所不在,无所不为”。(1)智能交通(2)环境工程与自然(3)机器人(4)工业控制(5)智能汽车(6)网络管理(7)智能医疗(8)智慧家庭2023/11/28汽车嵌入式系统设计191.1.5嵌入式系统的发展趋势信息时代使得嵌入式产品获得了巨大的发展契机,为嵌入式系统的市场展现了美好的前景,同时也对嵌入式系统生产厂商提出了新的挑战,未来嵌入式系统的几大发展趋势:1)嵌入式系统开发是一项系统工程,因此要求嵌入式系统厂商不仅要提供嵌入式软硬件系统,同时还需要提供强大的硬件开发工具和软件包支持。2)网络互联成为必然趋势。未来的嵌入式设备为了适应网络发展的要求,必然要求硬件上提供各种网络通信接口。2023/11/28汽车嵌入式系统设计203)网络化、信息化的要求随着因特网技术的成熟、带宽的提高日益提高,使得以往单一功能的设备如电话、手机、冰箱、微波炉等功能不再单一,结构更加复杂。这就要求芯片设计厂商在芯片上集成更多的功能,为了满足应用功能的升级。4)精简系统内核、算法,降低功耗和软硬件成本。未来的嵌入式产品是软硬件紧密结合的设备,为了减低功耗和成本,需要设计者尽量精简系统内核,只保留和系统功能紧密相关的软硬件,利用最低的资源实现最适当的功能。5)提供友好的多媒体人机界面。嵌入式设备能与用户亲密接触,最重要的因素是它能提供非常友好的用户界面,使得嵌入式软件设计者要在图形界面、多媒体技术上多下苦功。2023/11/28汽车嵌入式系统设计211.2汽车嵌入式系统概述汽车是全球经济的支柱产业,汽车机械结构更新越来越慢,随着汽车电动化、智能化、网联化、共享化等技术的发展,汽车电子技术得到迅猛发展与普及,给汽车的技术发展注入了新的动力。众所周知嵌入式系统具有体积小、低功耗、集成度高、子系统间能通信融合的优点,这就决定了它非常适合应用于汽车工业领域。目前,车身控制、底盘控制、发动机管理、主被动安全系统、车载娱乐、信息系统都离不开嵌入式技术的支持。嵌入式技术使汽车更安全、更节能、更环保、更舒适、更智能、控制更精准,将驾驶员从繁杂紧张的驾驶作业中不断解放出来,最终实现无人驾驶。嵌入式系统是实现汽车智能化和无人驾驶的关键技术。嵌入式系统引入汽车行业后,给汽车行业的发展带来了新的方向,同时汽车行业的不断发展也促进了嵌入式系统的发展,从其中总结出的开发方法、体系结构、开发流程是值得各种嵌入式系统开发借鉴的。2023/11/28汽车嵌入式系统设计221.2.1汽车电子系统划分汽车电子系统的划分如图1-3所示,汽车电子产品可分为两大类:1)汽车电子控制装置。包括动力总成控制系统、底盘和车身电子控制系统、乘坐舒适和防盗系统。2)车载汽车电子装置。包括汽车信息系统(车载电脑)、导航系统、汽车视听娱乐系统、车载通信系统、车载网络等。2023/11/28汽车嵌入式系统设计23图1-3汽车电子系统1.2.2汽车嵌入式系统发展的三个阶段第一阶段:SCM(SingleChipMicrocomputer)单片机系统。以4位和低档8位微处理器为核心,将CPU和外围电路集成到一个芯片上,配置了外部并行总线、串行通讯接口、SFR模块和布尔指令系统。硬件结构和功能相对单一、处理效率低、存储容量小、软件结构也比较简单,不需要嵌入操作系统。这种底层的汽车SCM系统主要用于任务相对简单、数据处理量小和实时性要求不高的控制场合,如雨刷、车灯系统、仪表盘以及电动门窗等。第二阶段:MCU(MicroControllerUnit)微控制器系统。以高档的8位和16位处理器为核心,集成了较多外部接口功能单元,如A/D转换、PWM、Watchdog、高速I/O口等,配置了芯片间的串行总线,软件结构比较复杂,程序数据量有明显增加。第二代汽车嵌入式系统能够完成简单的实时任务,目前在汽车电控系统中已得到最广泛的应用,如ABS系统、智能安全气囊、主动悬架以及发动机管理系统EMS(EngineManagementSystem)等。2023/11/28汽车嵌入式系统设计24第三阶段:SoC(SystemonChip)系统。以性能极高的32位甚至64位嵌入式处理器为核心,在对海量离散时间信号要求快速处理的场合使用DSP作为协处理器。为满足汽车系统不断扩展的嵌入式应用需求,不断提高处理速度,增加存储容量与集成度。在嵌入式操作系统的支持下具有实时多任务处理能力,同时与网络的耦合更为紧密。汽车SoC系统是嵌入式技术在汽车电子上的高端应用,满足了现代汽车电控系统功能不断扩展、逻辑渐趋复杂、子系统间通信频率不断提高的要求,代表着汽车电子技术的发展趋势。汽车嵌入式SoC系统主要应用在混合动力总成、汽车复杂ADAS系统、无人驾驶、底盘综合控制、汽车定位导航、车辆状态记录与监控等领域。2023/11/28汽车嵌入式系统设计25汽车嵌入式SoC系统是嵌入式系统向实时多任务管理、网络耦合与通信的高端应用过渡的产物,大大提高了汽车电子系统的实时性、可靠性和智能化程度。除了具备普通嵌入式系统的共有特性之外,还具有以下几个优点:1)对实时多任务处理有很强的支持能力,中断响应时间1~2μs;2)具有很强的存储区保护功能;3)在嵌入式实时操作系统的支持下能合理进行任务调度,利用系统资源;2023/11/28汽车嵌入式系统设计264)硬件结构和软件功能都有很强的扩展能力,系统集成度大大提高;5)超低功耗,静态功耗为毫瓦级;6)系统硬件抗干扰能力增强,适应高温、潮湿、振动和辐射等各种工作环境;7)提供强大的网络通信功能,具备IEEE1394、USB、CAN、Bluetooth或IrDA通信接口,支持相应的通信组网协议软件和物理层驱动软件,提供容错数据传输能力和更大通信带宽。2023/11/28汽车嵌入式系统设计271.2.3基于网络技术的分布式汽车嵌入式系统汽车集成了大量的嵌入式系统,包括各类传感器、各类执行器、大量不同架构的微处理器和控制器。带来一系列问题:1)整车布线十分复杂、凌乱;2)有限的汽车空间限制了功能的扩展;3)电路的复杂性大大降低了汽车电子与控制系统的可靠性;4)维护维修非常困难、麻烦,增加了维修的难度。为了使汽车复杂多嵌入式电子系统能够在一个共同的环境下协调工作,减少导线数量、进步降低成本、提高电信号传输的可靠性,车载嵌入式系统的分布式网络应运而生。2023/11/28汽车嵌入式系统设计282023/11/28汽车嵌入式系统设计292023/11/28汽车嵌入式系统设计30为了使汽车复杂多嵌入式电子系统能够在一个共同的环境下协调工作,减少导线数量、进步降低成本、提高电信号传输的可靠性,车载嵌入式系统的分布式网络应运而生。伴随着计算机软件、硬件技术以及通信技术的发展,汽车嵌入式系统经历了中央计算机集中控制、多嵌入式系统分散控制和多嵌入式系统分布式网络控制三个阶段。目前车载网络的主流协议标准分为以下几种。(1)中速网络协议标准(2)低速网络协议标准(3)多媒体网络协议标准2023/11/28汽车嵌入式系统设计31(1)中速网络协议标准在各种汽车网络中,CAN(ControllerAreaNetwork)控制器局域网络以其独特的设计、优异的性能和极高的可靠性得到了最为广泛的应用。CAN是一种串行数据通信协议,它是一种多主总线,通信介质可以是双绞线、同轴电缆或光导纤维。其特点有:1)数据通信没有主从之分,任意一个节点可以向任何其他(一个或多个)节点发起数据通信,靠各个节点信息优先级先后顺序来决定通信次序;2)多个节点同时发起通信时,优先级低的避让优先级高的,不会对通信线路造成拥塞;2023/11/28汽车嵌入式系统设计323)通信距离最远可达10km(速率低于5Kbit/sbps)、通信速率可达到1Mbit/sbps(通信距离小于40m);4)CAN总线传输介质可以是双绞线,同轴电缆。CAN总线适用于大数据量短距离通信或者长距离小数据量,实时性要求比较高,多主多从或者各个节点平等的现场中使用。2023/11/28汽车嵌入式系统设计33(2)低速网络协议标准本地互连网络(LIN,LocalInterconnectNetwork)就是为适应不需要CAN这样高速率和高可靠性的通信的一些控制而设计的低成本解决方案。LIN协议已经成为汽车低端控制网络的应用标准。LIN标准包括了传输协议的定义、传输媒质、开发工具间的接口、以及和软件应用程序间的接口。LIN提升了系统结构的灵活性,并且无论从硬件还是软件角度而言,都为网络中的节点提供了相互操作性,并可预见获得更好的EMC(电磁兼容)特性。LIN补充了当前的车辆内部多重网络,并且为实现车内网络的分级提供了条件,这可以有助于车辆获得更好的性能,并降低成本。LIN协议致力于满足分布式系统中快速增长的对软件的复杂性、可实现性、可维护性所提出的要求,它将通过提供一系列高度自动化的工具链来满足这一要求。2023/11/28汽车嵌入式系统设计34(3)多媒体网络协议标准汽车除了面向控制的嵌入式系统以外,还有其他多种面向信息及娱乐的设备,这些设备之间的通信需要更大的信息量,因此其互连需要更高速的通信协议。面向媒体系统的传输协议(MOST,MediaOrientedSystemTransport)是目前车载信息娱乐系统普遍接受的高速通信协议。MOST网络以光纤为载体,通常是环型拓扑。MOST可提供高达25Mbit/sbps的集合带宽,远远高于传统汽车网络,也就是说,可以同时播放15个不同的音频流。因此,MOST网络主要应用在汽车信息娱乐系统。2023/11/28汽车嵌入式系统设计35(4)高安全性网络协议标准汽车线控系统(X-by-Wire)使传统的汽车机械系统(如制动、转向等驾驶系统)变成通过高速容错通信总线与高性能CPU相连的电子系统。这些涉及汽车主动安全控制的系统对于通信的实时性、可靠性方面要求极高,在高安全性的系统中,CAN缺乏必要的确定性、同步性和容错性,因此在此类应用中,传统的CAN总线系统不再适用。为了满足线控汽车设计的要求出现了FlexRay、TTCAN和TTP等新一代汽车主干通信网络。2023/11/28汽车嵌入式系统设计36新一代汽车主干通信网络FlexRay的优点:FlexRay可以为下一代的车内控制系统提供所需的速度和可靠性。FlexRay两个信道上的数据速率最大可达到10Mbit/s,总数据速率可达到20Mbit/s。FlexRay具备的冗余通信能力可实现通过硬件完全复制网络配置,并进行进度监测。FlexRay提供灵活的配置,可支持各种拓扑,如总线、星型和混合拓扑。设计人员可以通过结合两种或两种以上的该类型拓扑来配置分布式系统。2023/11/28汽车嵌入式系统设计37FlexRay可以进行同步(实时)和异步的数据传输,来满足车辆中各种系统的需求。譬如说,分布式控制系统通常要求同步数据传输。FlexRay在每个通信周期内都提供静态和动态通信段。静态通信段可以提供有界延迟,而动态通信段则有助于满足在系统运行时间内出现的不同带宽需求。FlexRay帧的固定长度静态段用固定时间触发的方法来传输信息,而动态段则使用灵活时间触发的方法来传输信息。FlexRay不仅可以像CAN和LIN网络这样的单信道系统一般运行,而且还可以作为一个双信道系统运行。双信道系统可以通过冗余网络传输数据——这也是高可靠系统的一项重要性能。2023/11/28汽车嵌入式系统设计38BMW已经在X5车型中有5个ECU(电控主控悬架系统等)应用了FlexRay通讯技术。随着汽车局域网技术和智能交通技术的发展,汽车嵌入式系统将会形成以C级或D级网络为基础的整车分布式控制系统和以无线通信为基础的远程高频网络通信系统。图1-4是目前常用汽车常用网络通讯技术的成本对速度对比。2023/11/28汽车嵌入式系统设计39图1-4汽车用网络通讯技术成本与传输速度对比1.2.4面向汽车嵌入式系统的体系架构1.汽车嵌入式系统的传统开发体系汽车电子控制系统的发展经历了近半个世纪,早期由于汽车电子系统开发手段的相对落后和认识的制约,汽车嵌入式系统基本上是围绕单一功能的ECU的开发,开发流程大多是自发且不成系统。传统基于代码的汽车嵌入式系统开发大致流程如图1-5所示。传统的汽车嵌入式系统开发主要包括硬件和软件的设计与开发两部分,再加上一些必要的试验验证等。2023/11/28汽车嵌入式系统设计402023/11/28汽车嵌入式系统设计41图1-5传统汽车ECU开发流程传统汽车ECU开发流程存在以下不足:(1)系统设计的错误不易发现;(2)排除错误花费时间较长;(3)软件与硬件协同调试困难;(4)系统仿真阶段和实现阶段脱离;(5)移植性差。2.汽车嵌入式系统的现代开发体系2003年9月德国的汽车制造商和汽车电子产品供应商成立了汽车开放系统架构AUTOSAR(AUTOmotiveOpenSystemARchitecture)组织,旨在推动建立汽车电气/电子(E/E)架构的开放式标准,使其成为汽车嵌入式应用功能管理的基础架构,并规范汽车电子产品、软件和元器件的互通性。2023/11/28汽车嵌入式系统设计42AUTORAR的产生原因与实施方法(2)AUTOSAR采取的主要技术1)标准化的规范交换格式;2)基础软件核;3)微控制器抽象;4)运行时环境;5)接口标准化。2023/11/28汽车嵌入式系统设计43(1)AUTOSAR的主要驱动力1)管理随着功能的不断提升、复杂程度不断增加的E/E设备;2)提高产品更改、升级和更新的灵活性;3)提升生产线内或者跨生产线的可度量性;4)提升E/E系统的质量和可靠性;5)能够在早期设计阶段检测错误。AUTOSAR是面向汽车工业的通用嵌入式系统架构,实现标准的接口、高质量的无缝集成、高效的开发以及通过新的模型来管理复杂的系统。AUTOSAR定义一个软件架构以支持汽车电子系统的集成。其体系架构从上至下依次为应用层、运行环境层(RTE,Run-TimeEnvironment)、系统服务层、ECU抽象层和微控制器抽象层以及复杂驱动模块,一般情况下,每一层只能使用下一层的接口,并向上一层提供服务接口。图1-6为AUTOSAR的体系架构。2023/11/28汽车嵌入式系统设计44应用层运行环境层系统服务层ECU抽象层微控制器抽象层复杂驱动模块2023/11/28汽车嵌入式系统设计45AUTOSAR方法论的开发涉及系统级、ECU级和软件组件级。系统级主要考虑系统功能需求、硬件资源、系统约束,然后建立系统架构;ECU级根据抽象后的信息对ECU进行配置;系统级和ECU级设计的同时,伴随着软件组件级的开发。上述每个环节都有良好的通信接口,并使用统一的arxml(AUTOSAReXtensibleMarkupLanguage)描述文件,以此构建了AUTOSAR方法论。2023/11/28汽车嵌入式系统设计461.2.5面向汽车嵌入式系统的开发方法汽车电子产品是软硬件结合的嵌入式系统。为了节约资源,缩短产品开发周期,一般应采取软硬件同步开发的方案。汽车电子产品的软件开发分为功能描述、软件设计、代码生成、操作系统环境下的高级调试等步骤。汽车电子产品的硬件开发分为硬件描述、硬件设计、硬件调试等步骤。当软件设计完成后,通过使用相应的工具,完成在虚拟ECU平台上的验证。当硬件设计完成后,与硬件一起进行软硬件集成调试。1.汽车电子产品软件开发方法随着汽车嵌入式系统越来越复杂,系统开发的时间和空间的跨度也相应变大,基于模型的开发方法(MBD,Model-BasedDevelopment)也得到了越来越广泛的应用。2023/11/28汽车嵌入式系统设计47MBD的应用与优点基于模型的软件设计方法是一种以模型为中心的软件设计方法。该方法通过采用特定的建模语言对系统进行建模,抽象出软件系统的关键问题,并描述系统的解决方案;通过采用形式化的工具对系统模型进行验证,以保证系统设计的正确性。基于模型的开发方法在汽车嵌入式系统开发中主要用于四个方面:概念设计与交流;设计信息的文档化与管理;系统分析;系统综合。基于模型的开发方法的优势所在:精确简明的对象描述;文档的管理、分析和综合简单;产品开发周期短;设计成本低;产品质量高。2023/11/28汽车嵌入式系统设计482.开发流程主要的开发流程模型有:(1)V模型如图1-7,“V”形开发流程分为五个阶段:需求定义与功能设计快速控制原型(RCP,RapidControlPrototype)目标代码生成硬件在环(HIL,HardwareInLoop)测试与标定2023/11/28汽车嵌入式系统设计49图1-7汽车控制类电子产品软件开发V流程V模式开发流程的特点:无论进行开发、编程或测试总是在同一环境下工作,开发过程的每一步都可以得到验证,使用这一方法最直接的效果就是加速和简化了开发流程。从功能分析的角度而言,V模式的开发流程可以分为功能分解和功能集成2个部分:V模式的左侧(从功能设计到自动代码生成)表示的是系统功能的分析和分解;V模式的右侧(从自动代码生成到标定)表示的是系统功能的整合和综合。V模型中的过程从左到右,描述了基本的开发过程和测试行为。V模型的价值在于它非常明确地标明了测试过程中存在的不同级别,并且清楚地描述了这些测试阶段和开发过程期间各阶段的对应关系。其局限性为:把测试作为编码之后的最后一个活动,需求分析等前期产生的错误直到后期的验收测试才能发现。2023/11/28汽车嵌入式系统设计50(2)W模型V模型的局限性在于没有明确地说明早期的测试,无法体现“尽早地和不断地进行软件测试”的原则。在V模型中增加软件各开发阶段应同步进行的测试,演化为W模型,见图1-8。在模型中不难看出,开发是“V”,测试是与此并行的“V”。2023/11/28汽车嵌入式系统设计51图1-8W模式开发流程W模型是V模型的发展,强调的是测试伴随着整个软件开发周期,而且测试的对象不仅仅是程序,需求、功能和设计同样要测试。测试与开发是同步进行的,从而有利于尽早地发现问题。W模型也有局限性:W模型和V模型都把软件的开发视为需求、设计、编码等一系列串行的活动,无法支持迭代、自发性以及变更调整。2023/11/28汽车嵌入式系统设计52(3)X模型X模型也是对V模型的改进X模型的左边描述的是针对单独程序片段进行的相互分离的编码和测试,此后进行频繁的交接,通过集成最终成为可执行的程序,然后再对这些可执行程序进行测试。已经通过集成测试的成品可以进行封装并提交给用户,也可以作为更大规模和范围内集成的一部分。多根并行的曲线表示变更可以在各个部分发生。见图1-9。2023/11/28汽车嵌入式系统设计53X模型还定位了探索性测试,这是不进行事先计划的特殊类型的测试,这一方式往往能帮助有经验的测试人员在测试计划之外发现更多的软件错误。但这样可能对测试造成人力、物力和财力的浪费,对测试员的熟练程度要求比较高。(4)H模型H模型中,软件测试过程活动完全独立,贯穿于整个产品的周期,与其他流程并发地进行,某个测试点准备就绪时,就可以从测试准备阶段进行到测试执行阶段。软件测试可以尽早的进行,并且可以根据被测物的不同而分层次进行,见图1-10。2023/11/28汽车嵌入式系统设计54图1-10开发流程的H模型H模型揭示了一个原理:软件测试是一个独立的流程,贯穿产品整个生命周期,与其他流程并发地进行。H模型指出软件测试要尽早准备,尽早执行。不同的测试活动可以是按照某个次序先后进行的,但也可能是反复的,只要某个测试达到准备就绪点,测试执行活动就可以开展。1.2.6面向汽车嵌入式系统开发的工具链汽车电子与嵌入式系统的开发经过几十年的发展,在控制系统建模、代码自动生成、硬件在环仿真测试、系统标定等环节,已经形成了体系比较完备的开发工具链。表1-1是现阶段主要的面向AUTOSAR的开发工具。2023/11/28汽车嵌入式系统设计55工具软件:1.控制系统建模MATLAB/Simulink、StateflowMATLAB是美国MathWorks公司出品的商业数学软件,用于算法开发、数据可视化、数据分析以及数值计算的高级技术计算语言和交互式环境。Simulink是MATLAB中的一种可视化仿真工具,是一种基于MATLAB的框图设计环境,Simulink提供一个动态系统建模、仿真和综合分析的集成环境;Stateflow是一个基于有限状态机和流程图来构建组合和时序逻辑决策模型并进行仿真的环境。2.硬件在环仿真工具dSPACEdSPACE实时仿真系统一套基于MATLAB/Simulink的控制系统开发及半实物仿真的软硬件工作平台,实现了和MATLAB/Simulink/RTW的完全无缝连接。2023/11/28汽车嵌入式系统设计563.汽车网络仿真工具CANoe(CANopenenvironment)CANoe是德国Vector公司面向汽车总线开发的系统,是网络和ECU开发、测试和分析的专业工具,支持从需求分析到系统实现的整个系统的开发过程。在开发的初期阶段,CANoe可以用于建立仿真模型,在此基础上进行ECU的功能评估。在完成了ECU的开发后,该仿真模型可以用于整个系统的功能分析、测试以及总线系统和ECU的集成,这样就可以尽早地发现问题并解决问题。4.ECU测量、标定和诊断的综合工具CANapeCANape是德国Vector公司为汽车ECU开发、标定、诊断和测量数据采集的综合性工具。CANape主要用于电控单元(ECU)的参数优化(标定)。2023/11/28汽车嵌入式系统设计571.3数进制及其相互转换1.3.1数的常用进制1.十进制数主要特点:1)它由0、1、2、3、4、5、6、7、8、9不同的基本数码符号构成,基数为10。2)进位规则是“逢十进一”,一般在数的后面加符号D表示十进制数。(十进制符号可省略)注:所谓基数,在数学中指计数制中所用到的数码的个数。2023/11/28汽车嵌入式系统设计582.二进制数二进制数是计算机内的基本数制,其主要特点是:1)任何二进制数都只由0和1两个数码组成,其基数是2。2)进借位规则是“逢二进一,借一当二”。3)字节(byte):8位二进制数约定为1字节,如图1-11所示。一个字节可表示28个值(0~255)。LSB:最低有效位,D0位;MSB:最高有效位,D7位。一般在数的后面用符号B或b表示这个数是二进制数。二进制数同样可以用幂级数形式展开。4)字(word):2字节,16位二进制数。高8位为高字节,低8位为低字节。一个字有216个值(0~65535),LSB:最低有效位,D0位。MSB:最高有效位,D15位。2023/11/28汽车嵌入式系统设计593.十六进制数在计算机软件编程时,十六进制数常用于代码和数据的缩写,其主要特点是:1)十六进制数由16个数符构成:0、1、2、…、9、A、B、C、D、E、F,其中A、B、C、D、E、F分别代表十进制数的10、11、12、13、14、15,其基数是16。2)进借位规则是“逢十六进一,借一当十六”。一般在数的后面加一个字母H表示是十六进制数。4.各种进位制的对应关系表1-2反映了各种进位制的对应关系。2023/11/28汽车嵌入式系统设计602023/11/28汽车嵌入式系统设计611.3.2数制间的转换1.二进制数与十六进制数的转换(1)二进制数转化成十六进制数采用四位二进制数合成一位十六进制数的方法,以小数点开始分成左侧整数部分和右侧小数部分。(2)十六进制数转换成二进制数将十六进制数的每位分别用四位二进制数码表示,然后把它们连在一起即为对应的二进制数。2023/11/28汽车嵌入式系统设计622.二进制数与十进制数间的转换(1)二进制数转换成十进制数将二进制数按权展开后相加即得到对应的十进制数。(2)十进制数转化成二进制数十进制数的整数部分和小数部分转化成二进制数的方法不同,要将它们分别转换,然后将结果合并到一起即得到对应的二进制数。①十进制整数转成二进制整数的常用方法是“除2取余法”。②十进制小数转换成二进制小数的常用方法是“乘2取整法”。2023/11/28汽车嵌入式系统设计633.十六进制数和十进制数间的转换(1)十六进制数转换成十进制数将十六进制数按权展开后相加即得到对应的十进制数。(2)十进制数转换成十六进制数与十进制数转换成二进制数类似,十进制整数部分采用“除16取余逆排法”,十进制小数部分采用“乘16取整顺排法”。2023/11/28汽车嵌入式系统设计642023/11/28汽车嵌入式系统设计651.4二进制数的算术运算与逻辑运算1.4.1算术运算1.加法运算运算规则为:0+0=0、1+0=0+1=1、1+1=10(向高位有进位)。2.减法运算运算规则为:0-0=0、1-0=1、1-1=0、0-1=1(向高位借1当作2)。 3.乘法运算
运算规则为:0×0=0、0×1=1×0=0、1×1=1。 4.除法运算
除法运算是乘法运算的逆运算。与十进制类似,从被除数最高位开始取出与除数相同的位数,减去除数。2023/11/28汽车嵌入式系统设计661.4.2逻辑运算二进制数的逻辑运算主要有与、或、异或、非等。逻辑运算是按位运算的。1.非(not)运算逻辑符号:,函数表达式:非操作逻辑表:,非运算用于按位取反(反相器)2.与(and)运算逻辑符号:,函数表达式:与操作逻辑表:与“0”相与,指定位为0;与“1”相与,保留指定位。与运算常用于屏蔽某些位。如:0011,0011B^0000,1111B=0000,0011B,使得高四位清零,低四位保留。2023/11/28汽车嵌入式系统设计673.或(or)运算逻辑符号:,函数表达式:或操作逻辑表:与“1”相或,指定位为1;与“0”相或,保留指定位。或运算常用于置位某些位。如:0011,0011B∨0000,1111B=0011,1111B,使得高四位保留,低四位置1。2023/11/28汽车嵌入式系统设计684.异或(xor)运算逻辑符号:,函数表达式:异或操作逻辑表:
与“0”相异或,保留指定位;与“1”相异或,指定位取反。异或运算常用于某些位取反。如:0011,0011B⊕0000,1111B=0011,1100B,使得高四位保留,低四位取反。2023/11/28汽车嵌入式系统设计695.组合逻辑操作(1)或非门逻辑符号:,函数表达式:(2)与非门逻辑符号:,函数表达式:2023/11/28汽车嵌入式系统设计706.专用的逻辑器件为了实现逻辑操作,专门设计了大量的逻辑运算器件。如74LS138译码器,见图1-12。74LS138真值表见表1-3。图1-1274LS138引脚3线-8线译码器2023/11/28汽车嵌入式系统设计711.4.3有符号数的码制自然界的数分整数和实数,整数中又分无符号整数和有符号整数。在计算机内数都是有限字长的二进制格式表示。1.机器数及其真值机器数中分有符号数和无符号数,而整数又分为8位、16位、32位、64位有符号或无符号整数,对于实数,又分单精度(32位)、双精度(64位)。必须弄清楚计算机内部是如何表示这些数的。2023/11/28汽车嵌入式系统设计72(1)无符号整数的表示
对于无符号整数,二进制的所有位均为数值位。如:8位二进制数10001111B(8FH),表示无符号数时,代表数143。对于n位二进制,其无符号数的表示范围是:0~2n-1。如8位二进制无符号数的范围是0~255,16位二进制无符号数的范围是0~65535。对于有限字长的无符号数,进行加法和减法运算时,均存在溢出问题。两个无符号数相加,超出有限位的表示范围,即产生溢出。两个无符号数相减,被减数小于减数的问题。一般是通过最高位有无进位(借位)进行判断。Cn-1=1,最高位有进位(借位),溢出,Cn-1=0,最高位无进位(借位),无溢出。2023/11/28汽车嵌入式系统设计73(2)有符号整数的表示把二进制数的最高位定义为符号位,符号位为0表示正数,符号位为1表示负数。连同符号位一起数值化了的数,称为机器数。机器数所表示的真实的数值,称为真值。数在计算机内的表示形式称为机器数(二进制数)这个数本身称为真值。如:正数+1000101B(+45H)。上面表示方式是数的真值表达式;机器数的表示:01000101B(45H)。如:负数-1010101B(-55H)上面表示方式是数的真值表达式;机器数的表示:11010101B(D5H)。2023/11/28汽车嵌入式系统设计742.有符号数的原码、反码和补码在微型计算机中约定,最高位用来表示符号,而其他位用于表示数值。对于8位二进制数用D7=0表示正数,D7=1表示负数;对于16位二进制数用D15=0表示正数,D15=1表示负数。(1)原码
最高位为符号位,数值为绝对值。n位原码表示数值的范围是:-(2n-1-1)~+(2n-1-1)。8位对应的原码是1111,1111B~0111,1111B,即-127~127。如:X=+18=+0010010B,其原码为[X]原=00010010B;X=-18=-0010010B,其原码为[X]原=10010010B;需要注意数0的原码:+0=00000000;-0=10000000,即:数0的原码不唯一。2023/11/28汽车嵌入式系统设计75(2)反码正数的反码与其原码相同。负数的反码符号位为1,数值位为其原码数值位逐位取反。如:X=-52=-0110100B,[X]原
=10110100B,[X]反
=11001011B。如:X=+18=+0010010B,其反码为[X]原=00010010B;X=-18=-0010010B,其反码为[X]原=11101101B;n位反码表示数值的范围是:-(2n-1-1)~+(2n-1-1)。8位对应的反码是1000,0000B~0111,1111B,即-127~127。数0的反码也不是唯一的,[+0]反=00000000B,[-0]反=11111111B。采用原码和反码表示时,符号位不能同数值一道参加运算。2023/11/28汽车嵌入式系统设计76(3)补码正数的补码与其原码相同,负数的补码为其反码加1。计算机中,带符号数的运算均采用补码。若X>0,
则[X]补=[X]反=[X]原若X<0,
则[X]补=[X]反+1如:X=-52=-0110100B,[X]原=10110100B,[X]反=11001011B,[X]补=[X]反+1=11001100B。n位补码表示数值的范围是-(2n-1)~+(2n-1-1)。8位对应的补码是10000000B~01111111B,对应-128~127。需要注意:[+0]补=[-0]补=00000000B;[-128]补=10000000B。由补码求其真值的方法:求补得到原码(符号位+数值位),依据原码求真值。如:某数的补码为:10101011B,求补得:11010101B,真值为:-55H。补码的优点:将减法运算转换为加法,且数值连同符号位可一起参与运算。如:45H-55H=-10H;[45H]补:01000101B,+[-55H]补:10101011B;[-10H]补:11110000B;求补得原码:10010000B,真值:-0010000B(-10H)。2023/11/28汽车嵌入式系统设计771.4.4有符号二进制数运算1.有符号二进制数运算对用补码表示的二进制数:(1)求出真值。先判断是正数还是负数,求真值(2)进行转换。如:[X]补=00101110B,符号位为0,即X为正数,真值为:+0101110B,所以:X=+46。如:[X]补=11010010B,符号位为0,即X为负数,X=[[X]补]补=[1101
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 三合一工作室制度规范
- 长治市医院管理制度规范
- 规范双随机行政检查制度
- 规范换药室管理制度范本
- 食品外包装装箱制度规范
- 学校规范用字工作制度
- 医院病房门岗制度规范
- 小型泵站操作制度规范
- 后勤人员规范管理制度
- 进一步规范手机统管制度
- 高一物理(人教版)试题 必修二 阶段质量检测(一) 抛体运动
- 2026瑞众保险全国校园招聘参考笔试题库及答案解析
- 2025年山东省枣庄市检察院书记员考试题(附答案)
- 医药连锁年终总结
- 2025-2026学年人教版七年级生物上册知识点梳理总结
- 工业设计工作流程及标准教程
- 《好睡新的睡眠科学与医学》阅读笔记
- 寒假安全教育课件模板
- GB 20101-2025涂装有机废气净化装置安全技术要求
- 熔铝炉施工方案及流程
- 折弯工技能等级评定标准
评论
0/150
提交评论