汽车ECU通讯新平台--FlexRay(V2.1)协议规范 | |
作者:纪光霁 万茂松 | |
一、车载网络概述 汽车电子化程度与日俱增,应用在车上的ECU模块数量也随之增加,从而使线束也增加。汽车电子系统的成本已经超过总成本的20%,并且还将继续增加。由于汽车生产商对制造成本的严格控制,加上对车身质量的控制,减少线束已经成为一个必须要解决的问题。另一方面,以网络通讯为基础的线控技术(X-by-wire)将在汽车上普遍应用。因此,车载网络时代终将来临。 车载网络种类有很多种,应用较多的有LIN,CAN、FlexRay、TIP/C、SAEJ1850、TFCAN、ASRB、MOST等。美国汽车工程师协会(SAE)根据速率将汽车网络划分为A、B、C3类。 A类总线标准包括TTP/A(Time Triggered Protocol/A)和LIN(Local Interconnect Net-work),其传输速率较低。①TTP/A协议最初由维也纳工业大学制定,为时间触发类型的网络协议,主要应用于集成了智能变换器的实时现场总线。②LIN是在1999年由欧洲汽车制造商Audi、BMW、DaimlerChrysler、Volvo、Volkswagen、VCT公司以及Motorola公司组成的LIN协会共同努力下推出的用于汽车分布式电控系统的开放式的低成本串行通讯标准,从2003年开始得到使用。 B类标准主要包括J1850、VAN,低速CAN。①1994年SAE正式将J1850作为B类网络标准协议。最早,SAEJ1850被用在美国Ford,GM以及Chrysler公司的汽车中。现在,J1850协议作为诊断和数据共享被广泛应用在汽车产品中。②VAN标准是ISO1994年6月推出的,它基于ISO11519-3,主要为法国汽车公司所用。但目前就动力与传动系统而言,甚至在法国也集中应用CAN总线。③CAN是德国BOSCH公司从20世纪80年代初为解决现代汽车中众多的控制与测试仪器之间的数据交换而开发的一种串行数据通讯协议。低速CAN具有许多容错功能,一般用在车身电子控制中,而高速CAN则大多用在汽车底盘和发动机的电子控制中。 C类总线标准主要包括TTP/C,FlexRay和高速CAN(ISO11898-2)。都用于与汽车安全相关以及实时性要求比较高的地方。如动力系统,其传输速率比较高,通常在125kb/s到10Mb/s之间,必须支持实时的周期性的参数传输。①TTP/C协议由维也纳工业大学研发,基于TDMA(Time Division Multiple Access)分时多址的访问方式。②FlexRay是BMW、Daimler Chrysler、Motorola和Philips等公司制定的功能强大的网络通讯协议。基于TDMA的确定性访问方式,具有容错功能及确定的通讯消息传输时间,同时支持事件触发与时间触发通讯,具备高速率通讯能力。③欧洲的汽车制造商基本上采用的都是高速CAN总线标准ISO11898。总线传输速率通常在125kb/s~1Mb/s之间。然而,作为一种事件驱动型总线,CAN无法为下一代线控系统提供所需的容错功能或带宽,因为X-by-wire系统实时性和可靠性要求都很高,必须采用时间触发的通讯协议,如TTP/C或F1exRay等。 二、FlexRay协议 FlexRay是由FlexRay共同体(FlexRayConsortium)制定的协议。该共同体为一企业合作组织,成立于2000年。到2005年,FlexRay共同体的7个,核心成员是:BMWGROUP、BOSCH、DaimlerChrysler、GM、Motorola/Freescale、PHILIPS和VWAG。除此之外,它还有超过93个协作和发展成员。从2002年发布的V0.4.3协议规范到2005年的V2.1协议规范,共发布多达7个版本。 F1exRay网络是一种高传输速率(每通道10Mb/s)的时间触发型网络。采用分时多址方式对总线进行访问,具有确定性和容错功能。非常适合于下一代汽车线控系统或分布式控制系统的通讯要求。 (一)拓扑结构(Topology) 共有3种网络拓扑结构,即:总线型(Bus)、星型(Star)和混合型(Hybrid)。而每一种类型都有单通道(SingleChannel)和双通道(DualChannel)之分。在星型结构中,还存在联级方式。总线型如图1所示,单、双通道联级星型如图2、图3所示,单、双通道混合型结构如图4、图5所示。 (二)节点(Node)的内部逻辑结构 主要由电源供给系统(Power Supply),总线驱动器(Bus Driver,简称BD)、总线监控逻辑(Bus Guardian,简称BG)、固化有FlexRay通讯协议的通讯控制器(CommunicationController,简称CC)及主机(Host)5个部分组成,如图6所示。其中BD和BG的个数对应于通道数,而BG是用于避免通道定时错误的一个独立部分,与通讯控制器和微处理器相连。总线监控逻辑必须独立于其他的通讯控制器。节点的两个通讯过程如下。 a.发送数据主机(Host)将有效的数据送给通讯控制器(CC),在通讯控制器中进行编码,形成数据位流(bitstream),通过总线驱动器(BD)发送到相应的通道上。 b.接收数据在某一时刻,由总线驱动器访问总线,将数据位流送到通讯控制器进行解码,将有效数据部分由通讯控制器送给主机Host。 (三)FlexRay网络通讯协议 FlexRay网络通讯协议主要体现在4个核心机制上:编码与解码(encoding and decoding)、媒体接入控制(Media Access Control)、数据帧与特征符处理(frame and symbol processing)和时钟同步(clock synchronization)。除此之外,控制器主机接口(controller Hostinter face,简称CHI)为实现这些机制提供数据传输服务。 1.编码与解码(encoding and decoding) 编码的过程实际上就是对要发送的数据进行相应处理的过程,如加上各种校验位、ID符等。解码的过程就是对接收到的数据帧进行“解包”的过程。编码与解码主要发生在通讯控制器与总线驱动器之间的通讯,如图7所示。 其中RxD为接收信号,TxD为发送信号,TxEN为通讯控制器请求数据信号。信息的二进制表示采用“不归零”码。对于双通道的节点,每个通道上的编码与解码的过程是同时完成的。编码与解码的过程主要由3个过程组成:主编码与解码过程(CODEC)、位过滤(bitstrobing)过程和唤醒模式解码过程(WUPDEC)。以主编码与解码过程(CODEC)为主要过程。 1)帧编码 传输起始序列(transmission start sequence,简称TSS),为一段时间的低电平,用于初始化传输节点与网络的对接。帧起始序列(frame start sequence,简称FSS),为一小段时间的高电平,紧跟在传输起始序列(TSS)之后。 字节起始序列(byte start sequence,简称BSS),由一段高电平和一段低电平组成,位于FSS之后。给接收方节点提供定时信息。 帧结束序列(frame end sequence,简称FES),由一段低电平和一段高电平组成,位于有效数据位之后。如果是在动态时序部分接入网络,则还要在FES后附加上DTS——动态尾部序列(Dynamic trailing sequence)。 将这些序列与有效数据位(从最大位MSB到最小位LSB)“组装”起来就是编码过程,最终形成能够在网络传播的数据位流。此外,低电平的最小持续时间为一个gdBit。图8与图9分别为静态和动态部分的帧编码。 2)特征符编码 F1exRay,协议有3种特征符:冲突避免特征符(collision avoidance symbol,简称CAS)、媒体接入测试特征符(Media access test symbol,简称MTS)和唤醒特征符(wake up symbol,简称WUS)。对CAS和MTS采用完全相同的方式进行编码,对唤醒特征符(WUS)采用另一种模式编码。 节点对传输冲突避免特征符(CAS)和媒体接入测试特征符(MTS)的编码,是跟随在传输起始序列(TSS)之后的一段时间长为cdCAS(为某一具体数值)的低电平,如图10所示。 节点对唤醒特征符(WUS)的编码并没有采用辅助信号TSS,随TxEN的边沿触发同步于TxD信号进行传输一个唤醒特征符(WUS),如图11所示。 帧与特征符解码的过程就是编码的逆过程。这里不再赘述。 2.数据帧格式(FormatofFrame) 一个数据帧由帧头(HeaderSegment)、有效数据(PayloadSegment)和帧尾(TrailerSegment)多个部分组成。FlexRay数据帧格式如图12所示。 1)帧头部分 共由5个字节(40个位)组成。包括保留位(Reserved bit,1位)、数据指示位(Pay load Preamble indicator,1位)、空帧指示位(Null frame indicator,1位)、同步帧指示位(Sync frame indicator,1位)、启动帧指示位(Start up frame indicator,1位)、ID(11位)、有效数据长度(7位)、头部循环校验CRC(11位)和循环计数(6位)。 2)有效数据部分 可由0-254个字节或0-127个字组成。在图12中分别以Data0、Data1…Data253表示。在帧的CRC校验中,有效数据部分的前6个字节设为海明距离(Hamming Distance)。当数据超过248字节时,海明距离为4个字节。 在动态时序部分,有效数据部分的头两个字节通常用作消息识别域(messageIDfield)。消息识别(又叫消息ID)标明应.用数据的物理内容,仅仅用于在动态时序传输的数据帧,长度为16位。在传输节点中,消息ID是由主机将其作为应用数据而写入的,通讯控制器(CC)并不能够对消息ID进行识别。在接收节点中,对一个帧的存储依靠于利用消息ID而进行过滤处理的结果,如图13所示。 在静态时序部分,有效数据部分的头13个字节(DataO-Data12)通常用作网络管理向量(networkmanagementvector,简称NM)。在同一个簇内,所有的节点应具有相同长度的网络管理向量,仅仅用于在静态时序传输的数据帧,长度为8位,如图14所示。 3)帧尾部分 只含有单个的数据域,即一个24位的CRC。FlexRay的CRC计算是遵循一定的运算法则。包括帧头CRC计算和数据帧CRC计算。 3.媒体接入控制(Media Access Control) 在媒体接入控制中,一个重要的概念就是通讯周期(communicationcycle)。在一个通讯周期内,FlexRay提供两种媒体接入时序的选择:一种是静态的分时多址接入时序(TDMA);一种是动态的基于最小时间片(mini-slotting)时序。 在1个通讯周期内,有4个时间等级(timing hierarchy),从最低层到最高层分别是:最小时间节拍层(microtick)、最大时间节拍层(macrotick)、仲裁网格层(arbitrationgrid)和通讯周期层。如图15所示。 在最高层即通讯周期层,由静态部分、动态部分、特征窗和网络闲置时间(NIT)4个部分组成。在静态部分采用的是TDMA方式;在特征窗的这段时间内主要传输的是特征符。 仅次于最高层就是仲裁网格层,仲裁网格层形成FlexRay的媒体接入仲裁的核心,它解决的是采用何种方式接入媒体。在动态部分,仲裁网格由若干个最小时间片(minislot)组成。 1)静态部分 在该时间段内由若干个静态时间片(staticslot)组成,每个时间片的长度都相等。不同的节点根据全局时间判断在某一时刻开始接收或发送某一特定的数据帧(flameID)。为了确定这一时刻每个节点的每一个通道上.都含有一个时间片计数器,两个计数器是同步计数的。例如有3个节点,分别为node1、node2和node3。假设静态部分开始于00:10,节点在时间上的顺序为1-2-3,那么node1将在00:10这一时刻开始在两个通道上传输flameID1;在00:20时刻node2开始在一个通道上传输flameID2;node3在00:30开始传输,即使没有数据帧。如图16所示。 2)动态部分 采用的是基于最小时间片的时序,由若干个最小时间片组成,最小时间片的长度都相等。帧的长度是可变的,而且与静态部分相比,动态部分的两个时间片计数器是独立计数的,在不传输数据帧时,计数器以minislot为周期进行加1计数,在传输数据帧时计数器不工作。两个通讯通道不必同步。一个动态时间片(Dynamicslot)包含一个或多个minislot。如图17所示。 4.时钟同步 簇内所有的节点都应有相同的“时间观”,就好像全国都遵守一个标准的全局时间——北京时间。但这并不意味着节点间具有完全严格的同步时间,只要节点间的时间差保持在允许的误差范围内即可。由上述可知FlexRay的时间等级制度:若干个最小时钟节拍构成一个最大时钟节拍,而若干个最大时钟节拍又构成通讯周期的一个单元。最小时钟节拍是由通讯控制器(CC)的外部晶振提供,对于不同的控制器,最小时钟节拍可能会不相同;在一个簇内所有同步节点的最大时钟节拍都相等。 时钟同步包含两个主要过程:最大时钟节拍产生过程(MTG)和时钟同步过程(CPS)。如图18所示。MTG控制时间片计数器初值,并对其进行修正。时钟同步过程(CPS)主要完成一个通讯周期开始的初始化,测量并存储时间偏差值,计算频率与相位的修正值。时间偏差可以分为相位(offset)和频率(rate)偏差。相位偏差是两个时钟在某一特定时间的绝对差别频率偏差是相位.偏差随着时间推移的变化,它反映了相位偏差在特定时间的变化。FlexRay同时对频率与相位进行修正。节点计算数据帧到达的实际时刻,并与理论上的预测时刻比较,得到的值就是发送节点与接收节点的时间偏差,并采取一定的算法进行修正,最终使簇内的节点上的时间实现“同步”。 5.唤醒与启动(wakeup and startup) 唤醒针对的是电源管理系统。有些节点在不工作时处于“节电”模式(power-savingmode),当再次投入工作时就需要“唤醒”该节点;单个节点可唤醒整个组群;主机可在通讯信道上传输唤醒模式(wakeup-pattern)。节点通过收发器进行唤醒:当节点的收发器接收到唤醒特征符(wakeup-symbol)后,对主机处理器和通讯控制器进行上电。 只有将节点唤醒后,才能启动节点工作。初始化一个启动过程称为“冷启动(coldstart)”,能进行冷启动的节点数目是有限的。系统的启动由两个逻辑步骤组成:①冷启动节点启动;②其他非冷启动节点通过接收启动帧,与冷启动节点整合到一起。 三、FlexRay展望 FlexRay以其确定的网络通讯、高速的数据传输及强大的容错功能,很可能成为将来汽车上的底盘系统、动力系统及线控系统的ECU通讯新的标准,并取代高速TTCAN网络。2005年10月,Philips推出了全球第一个FlexRay系统解决方案,包括一个收发器和一个携带嵌入式FlexRay2.1版本通讯控制器且基于ARM的微控制器。2006年1月,飞利浦半导体公司推出了面向主动安全系统的FlexRay2.1系统解决方案。该解决方案包括两个主要部分:TJA1080收发器和包含一个ARM9微控制器并且完整集成FlexRay2.1版本的SJA2510通讯控制器。目前德国宝马汽车公司承认它将采用FlexRay作为主动悬架中用于节气阀控制的数据高速链路,在2006年末或2007年初基本实现生产。此外,FlexRay的评估套件也已经推出。相信在不久的将来,FlexRay必定成为新一代车载网络的“排头兵”。 |
文章评论(0条评论)
登录后参与讨论