FlexRay总线原理及应用

汽车电子与软件 2021-10-31 21:06
由于传统的CAN解决方案不能满足汽车线控系统(X-by-Wire) 的要求。于是在 2000 年 9 月,宝马和戴姆勒克莱斯勒联合飞利浦和摩托罗拉成立了 FlexRay 联盟。该联盟致力于推广 FlexRay 通信系统在全球的采用, 使其成为高级动力总成、 底盘、 线控系统的标准协议。其具体任务为制定 FlexRay 需求定义、 开发 FlexRay协议、 定义数据链路层、 提供支持 FlexRay 的控制器、 开发 FlexRay 物理层规范并实现基础解决方案。

1 FlexRay 特点

FlexRay 提供了传统车内通信协议不具备的大量特性, 包括:

(1)高传输速率:FlexRay 的每个信道具有 10Mbps 带宽。由于它不仅可以像 CAN 和 LIN 网络这样的单信道系统一般运行, 而且还可以作为一个双信道系统运行, 因此可以达到 20Mbps 的最大传输速率, 是当前 CAN 最高运行速率的 20 倍。

(2)同步时基:FlexRay 中使用的访问方法是基于同步时基的。该时基通过协议自动建立和同步,并提供给应用。时基的精确度介于 0.5μs 和 10μs 之间(通常为 1~2μs)。

(3)确定性:通信是在不断循环的周期中进行的, 特定消息在通信周期中拥有固定位置, 因此接收器已经提前知道了消息到达的时间。到达时间的临时偏差幅度会非常小, 并能得到保证。

(4)高容错:强大的错误检测性能和容错功能是 FlexRay 设计时考虑的重要方面。FlexRay 总线使用循环冗余校验 CRC(Cyclic redundancy cheek)来检验通信中的差错。FlexRay 总线通过双通道通信,能够提供冗余功能, 并且使用星型拓扑可完全解决容错问题。

(5)灵活性:在 FlexRay 协议的开发过程中, 关注的主要问题是灵活性, 反映在如下几个方面:①支持多种方式的网络拓扑结构;②消息长度可配置:可根据实际控制应用需求, 为其设定相应的数据载荷长度;③使用双通道拓扑时, 即可用以增加带宽, 也可用于传输冗余的消息;④周期内静态、 动态消息传输部分的时间都可随具体应用而定。

2 FlexRay 通讯协议和机制原理

2.1 节点架构

ECU(Electronic Control Unit), 即节点 node, 是接入车载网络中的独立完成相应功能的控制单元。主要由电源供给系统(Power Supply)、主处理器(Host)、固化 FlexRay 通信控制器(Communication Controller)、 可选的总线监控器(Bus Guardian) 和总线驱动器(Bus Driver) 组成, 如图所示。主处理器提供和产生数据, 并通过 FlexRay 通信控制器传送出去。其中 BD 和 BG 的个数对应于通道数,与通讯控制器和微处理器相连。总线监控逻辑必须独立于其他的通讯控制器。总线驱动器连接着通信控制器和总线, 或是连接总线监控器和总线。


节点的两个通讯过程为:
(1)发送数据:Host 将有效的数据送给 CC,在CC中进行编码,形成数据位流,通过BD发送到相应的通道上。
(2)接受数据:在某一时刻,由BD访问栈,将数据位流送到CC进行解码, 将数据部分由 CC传送给 Host。

2.2 拓扑结构

FlexRay 的拓扑主要分为 3 种:总线式、 星型、 总线星型混合型。

通常, FlexRay 节点可以支持两个信道, 因而可以分为单信道和双信道两种系统。在双信道系统中, 不是所有节点都必须与两个信道连接。

与总线结构相比, 星状结构的优势在于:它在接收器和发送器之间提供点到点连接。该优势在高传输速率和长传输线路中尤为明显。另一个重要优势是错误分离功能。例如, 如果信号传输使用的两条线路短路, 总线系统在该信道不能进行进一步的通信。如果使用星状结构, 则只有到连接短路的节点才会受到影响, 其它所有节点仍然可以继续与其它节点通信。


2.3 数据帧

一个数据帧由头段(Header Segment)、 有效负载段(Payload Segment) 和尾段(Trailer Segment)三部分组成。FlexRay 数据帧格式如图 2.5 所示。

(1)头段共由 5 个字节(40 位) 组成, 包括以下几位:
1.保留位(1 位):为日后的扩展做准备;
2.负载段前言指示(1 位):指明负载段的向量信息;
3.无效帧指示(1 位):指明该帧是否为无效帧;
4.同步帧指示(1 位):指明这是否为一个同步帧;
5.起始帧指示(1 位):指明该帧是否为起始帧;
6.帧 ID(11 位):用于识别该帧和该帧在时间触发帧中的优先级;
7.负载段长度(7 位):标注一帧中能传送的字数;
8.头部 CRC(11 位):用于检测传输中的错误;
9.周期计数(6 位):每一通信开始, 所有节点的周期计数器增 1。

(2)负载段是用于传送数据的部分, FlexRay 有效负载段包含 0~254 个字节数据。
对于动态帧, 有效负载段的前两个字节通常用作信息 ID, 接受节点根据接受的 ID 来判断是否为需要的数据帧。

对于静态帧, 有效负载段的前 13 个字节为网络管理向量(NM), 用于网络管理。
(3)尾段只含有 24 位的校验域, 包含了由头段与有效负载段计算得出的 CRC 校验码。计算 CRC时, 根据网络传输顺序将从保留位到负载段最后一位的数据放入 CRC 生成器进行计算。

2.4 编码与解码

编码的过程实际上就是对要发送的数据进行相应的处理“打包”的过程, 如加上各种校验位、 ID符等。编码与解码主要发生在通讯控制器与总线驱动器之间, 如图 2.6。


其中 RxD 位接受信号, TxD 为发送信号, TxEN 为通讯控制器请求数据信号。信息的二进制表示采用“不归零”码。对于双通道的节点, 每个通道上的编码与解码的过程是同时完成的。


TSS(传输启动序列):用于初始化节点和网络通信的对接, 为一小段低电平。
FSS(帧启动序列):用来补偿 TSS 后第一个字节可能出现的量化误差, 为一位的高电平BSS(字节启动序列):给接受节点提供数据定时信息, 由一位高电平和一位低电平组成。
FES(帧结束序列):用来标识数据帧最后一个字节序列结束, 由一位低电平和一位高电平组成。


DST(动态段尾部序列):仅用于动态帧传输, 用来表明动态段中传输时隙动作点的精确时间点,并防止接受段过早的检测到网络空闲状态。由一个长度可变的低电平和一位高电平组成。

将这些序列与有效位(从最大位 MSB 到最小位 LSB) 组装起来就是编码过程, 最终形成能够在网络传播的数据位流。

2.5 媒体访问方式

在媒体接入控制中, 一个重要的概念就是通信周期(Communication Cycle), 如图所示。一个通信周期由静态段(Static Segment)、 动态段(Dynamic Segment)、 特征窗(Symbol Window) 和网络空闲时间(Network Idle Time) 4 个部分组成。FlexRay 提供两种媒体接入时序的选择:静态段采用时分多址方式(TDMA), 由固定的时隙数组成, 不可修改, 且所有时隙的大小一致。用来传输周期性的数据信息;动态段采用灵活的时分多址(FTDMA), 由较小的时隙组成, 可根据需要扩展变动, 一般用于传输事件控制的消息。符号窗用于传输特征符号。网络空闲时间用于时钟同步处理。


仲裁层包含有仲裁网络, 它构成了 FlexRay 媒介仲裁的主干部分。在静态段中, 仲裁网络由叫做静态时槽(Static Slots)的连续时间间隔组成, 在动态段中, 由称为微型时槽(Minislots)的连续时间间隔组成。

仲裁网络层是建立在由宏节拍(Marcotick)组成的宏节拍层之上的。每个本地宏节拍的时间都是一个整数倍的微节拍的时间。已分配的宏节拍边缘叫做行动点(Action points)。行动点是一些特定的时刻, 在这些时刻上, 将会发生传输的开始和结束。
微节拍层是由微节拍组成的。微节拍是由通信控制器外部振荡器时钟刻度,选择性地使用分频器导出的时间单元。微节拍是控制器中的特殊单元, 它在不同的控制器中可能有不同的时间。节点内部的本地时间间隔尺寸就是微节拍。

2.6 时钟同步

如果使用基于 TDMA 的通信协议, 则通信媒介的访问在时间域中控制。因此, 每个节点都必须保持时间同步, 这一点非常重要。所有节点的时钟必须同步, 并且最大偏差(精度)必须在限定范围内,这是实现时钟同步的前提条件。

时钟偏差可以分为相位和频率偏差。相位偏差是两个时钟在某一特定时间的绝对差别。频率偏差是相位偏差随时间推移的变化, 它反映了相位偏差在特定时间的变化。

FlexRay 使用一种综合方法, 同时实施相位纠正和频率纠正, 包含两个主要过程:时间同步校正机制(最大时间节拍生成 MTG)和时钟同步计算机制(时钟同步进程 CSP)。MTG 控制时隙初值, 即周期计数器和最大时钟节拍的计数器, 并对其进行修正。CSP 主要完成一个通信循环开始的初始化,测量并存储偏差值, 计算相位和频率的修正值。


相位修正仅在奇数通信周期的 NIT 段执行, 在下一个通信周期起始前结束。相位改变量指明了添加到 NIT 相位修正段的微节拍数目, 它的值由时钟同步算法决定, 并有可能为负数。相位改变量的计算发生在每个周期内, 但修正仅应用在奇数通信周期的末尾。

在频率纠正中, 需要使用两个通信循环的测量值。这些测量值之间的差值反映每个通信循环中的时钟偏差变化。它通常用于计算双循环结束时的纠正值。在整个后来的两个通信周期中, 都使用该纠正值。

2.7 唤醒与启动

为了节省资源, 部分节点处于不工作状态时, 进入“节电模式”。当这些节点需要再次工作时,就需要“唤醒”它们。主机可以在通信信道上传输唤醒模式, 当节点接收到唤醒特征符(Wakeup Symbol)后, 主机处理器和通信控制器才进行上电。

在通信启动执行之前, 整个簇需要被唤醒。启动节点工作需要在所有通道上同步执行。初始一个启动过程的行为被称为冷启动(Coldstart), 能启动一个起始帧的节点是有限的, 它们称作冷启动节点(Coldstart Node)。在至少由三个节点组成的簇中, 至少要有三个节点被配置为冷启动节点。冷启动节点中, 主动启动簇中消息的节点称之为主冷启动节点(Leading Coldstart Node), 其余的冷启动节点则称之为从冷启动节点(Following Coldstart Node)。

当节点被唤醒并完成初始化后, 它就可以在相应的主机控制命令发出之后进入启动程序。在非冷启动节点接收并识别至少两个相互通信的冷启动节点前, 非冷启动节点一直等待。同时, 冷启动节点监控两个通信通道, 确定是否有其他的节点正在进行传输。当检测到通信信道没有进行传输时,该节点就成为主冷启动节点。

冷启动尝试以冲突避免操作符(Collision Avoidance Symbol)开始, 只有传输 CAS 的冷启动节点能在最开始的四个周期传输帧。主冷启动节点先在两个通道上发送无格式的符号(一定数量的无效位),然后启动集群。在无格式符号发送完毕后, 主冷启动节点启动该节点的时钟, 进入第一个通信周期。从冷启动节点可以接收主冷启动节点发送的消息, 在识别消息后, 从冷启动节点便可确认主冷启动节点发送的消息的时槽位置。然后等待下一个通信周期, 当接收到第二个消息后, 从冷启动节点便开始启动它们的时钟。根据两条消息的时间间隔, 测量与计算频率修正值,尽可能地使从启动节点接近主冷启动节点的时间基准。为减少错误的出现, 冷启动节点在传输前需等待两个通信周期。在这期间, 其余的冷启动节点可继续接收从主冷启动节点及已完成集群冷启动节点的消息。

从第五个周期开始, 其余的冷启动节点开始传输起始帧。主冷启动节点接收第五与第六个周期内其余冷启动节点的所有消息, 并同时进行时钟修正。在这个过程中没有故障发生, 且冷启动节点至少收到一个有效的起始帧报文对, 主冷启动节点则完成启动阶段, 开始进入正常运行状态。

非冷启动节点首先监听通信信道, 并接收信道上传输的信息帧。若接收到信道上传输的信息帧,便开始尝试融入到启动节点。在接下来的两个周期内, 非冷启动节点要确定至少两个发送启动帧的冷启动节点, 并符合它们的进度。若无法满足条件, 非冷启动节点将退出启动程序。非冷启动节点接收到至少两个启动节点连续的两组双周期启动帧后, 开始进入正常运行状态。非冷启动节点进入正常工作状态, 比主冷启动节点晚两个周期。

如下图所示, 描述了正确的启动过程。其中, A 是主冷启动节点, B 是从冷启动节点, C是非冷启动节点。


3 FlexRay 的应用

3.1 FlexRay 总线在 BMW 车系中的应用

(1)FlexRay 总线应用概述 

在 BMW 车系 F01 / F02 车型中, 通过 FlexRay 总线系统以跨系统方式实现汽车行驶动态 管理系统和发动机管理系统的联网。同时, FlexRay 是行驶动态管理系统的综合性 主总线系统 (图3.1), 中央网关模块用于不同总线系统与 FlexRay 之间的连接 (图3.2)。

图3.1 FlexRay 是行驶动态管理系统的综合性主总线系统
图3.2 中央网关模块 (ZGM) 用于不同总线系统与 FlexRay 之间的连接

F01 / F02 车型 FlexRay 总线系统的拓扑结构如图3.3所示。根据车辆配置情况, ZGM 带有一个或两个星形连接器, 每个星形连接器都有 4 个总线驱动器。总线驱动器将控制单元 数据通过通信控制器传输给中央网关模块 (ZGM)。根据 FlexRay 控制单元的终端形式, 总 线驱动器通过两种方式与这些控制单元相连。

图3.3 F01 / F02 车型 FlexRay 总线系统的拓扑结构 

AL—主动转向系统 BD—总线驱动器 DME—数字式发动机电子系统 DSC—动态稳定控制系统 EDCSHL—左后 电子减振器控制系统卫星式控制单元 EDCSHR—右后电子减振器控制系统卫星式控制单元 EDCSVL—左前电子减 振器控制系统卫星式控制单元 EDCSVR—右前电子减振器控制系统卫星式控制单元 HSR—后桥侧偏角控制系统 ICM—集成式底盘管理系统 SZL—转向柱开关中心 VDM—垂直动态管理系统 ZGM—中央网关模块


(2)终端电阻的设置 

与大多数总线系统一样, 为了避免在导线上产生信号反射, FlexRay 上的数据导线两端 也使用了终端电阻 (作为总线终端)。这些终端电阻的阻值由数据传输速率和导线长度决 定。终端电阻位于各个控制单元内部。 

如果一个总线驱动器上仅连接一个控制单元 (例如 SZL 与总线驱动器 BDO 相连), 则 总线驱动器和控制单元的接口各有一个终端电阻 (图3.4)。中央网关模块的这种连接方式 称为 “终止节点终端”。

图3.4 终止节点终端内部的终端电阻 

如果控制单元上的接口不是物理终止节点 (例如总线驱动器 BD2 上的 IEC、 ICM 和 DME), 而是形成环路, 则每个总线路径端部的两个组件内部必须设置终端电阻(图3.5)。

图3.5 形成环路的 FlexRay 终端电阻的设置

这种连接方式既用于中央网关模块, 也用于一些控制单元。但是形成环路的控制单元还 使用一个 “非终止节点终端” 来获取数据。受这种终端形式的电阻/ 电容器电路所限, 无法 通过测量技术在控制单元插头上对其进行检查。通过测量 (无电流) FlexRay 总线确定导线 或终端电阻时, 必须使用车辆电路图。



来源:道客巴巴,侵删



END
汽车电子与软件 主要介绍汽车电子软件设计相关内容,每天分享一篇技术文章!
评论 (0)
  •   安全生产预警系统作为现代工业与安全管理的重要组成部分,正以前所未有的技术引领力,创新性地塑造着未来的安全管理模式。这一系统通过集成多种先进技术,如物联网、大数据、人工智能、云计算等,实现了对生产环境中潜在危险因素的实时监测、智能分析与及时预警,为企业的安全生产提供了坚实的技术保障。   技术引领:   物联网技术:物联网技术使得各类安全监测设备能够互联互通,形成一张覆盖全生产区域的安全感知网络。传感器、摄像头等终端设备实时采集温度、压力、气体浓度、人员位置等关键数据,为预警系统提供丰富的
    北京华盛恒辉软件开发 2025-04-05 22:18 52浏览
  • 医疗影像设备(如CT、MRI、超声诊断仪等)对PCB的精度、可靠性和信号完整性要求极高。这类设备需要处理微伏级信号、高频数据传输,同时需通过严格的EMC/EMI测试。制造此类PCB需从材料选择、层叠设计、工艺控制等多维度优化。以下是关键技术与经验分享。 1. 材料选择:高频与生物兼容性优先医疗影像设备PCB常采用 Rogers RO4000系列 或 Isola FR4高速材料,以降低介电损耗并保证信号稳定性。例如,捷多邦在客户案例中曾为某超声探头厂商推荐 Rogers RO4350B
    捷多邦 2025-04-07 10:22 68浏览
  • 引言:小型化趋势下的语音芯片需求随着消费电子、物联网及便携式设备的快速发展,产品设计对芯片的小型化、高集成度和低功耗提出了更高要求。厂家凭借其创新的QFN封装技术,推出WTV系列(如WTV380)及WT2003H系列语音芯片,以超小体积、高性能和成本优势,为紧凑型设备提供理想解决方案。产品核心亮点1. QFN封装技术赋能超小体积极致尺寸:WTV380采用QFN32封装,尺寸仅4×4毫米,WT2003H系列同样基于QFN工艺,可满足智能穿戴、微型传感器等对空间严苛的场景需求。高密度集成:QFN封装
    广州唯创电子 2025-04-07 08:47 57浏览
  • 伴随无线技术的迅速发展,无线路由器市场商机日益庞大。现代消费者在选购无线路由器(Wi-Fi AP)时,通常依赖的是该产品在无干扰的实验室环境中,量测得到的数据报告。然而,这些数据往往是在受控的RF隔离环境中进行测试,无法完全反映真实使用场景。这种情况导致许多消费者抱怨,他们购买的产品效能与宣称的数据不符。在实际应用中,消费者常因Wi-Fi讯号不稳定、传输速度不如预期或设备过热而产生客诉。产品仰赖实验室的数据够吗?无线路由器(Wi-Fi AP)ODM供货商遇到什么挑战?一家台湾知名的无线路由器(W
    百佳泰测试实验室 2025-04-05 00:12 44浏览
  • 在科技浪潮奔涌的当下,云计算领域的竞争可谓是如火如荼。百度智能云作为其中的重要参与者,近年来成绩斐然。2024年,百度智能云在第四季度营收同比增长26%,这样的增速在行业内十分惹眼。回顾全年,智能云业务的强劲增长势头也十分明显,2024年第一季度,其收入达到47亿元,同比增长12%;第二季度营收51亿元,同比增长14%。从数据来看,百度智能云在营收方面一路高歌猛进,展现出强大的发展潜力。然而,市场对百度智能云的表现似乎并不完全买账。2024年,尽管百度智能云数据亮眼,但百度股价却在震荡中下行。在
    用户1742991715177 2025-04-06 20:25 61浏览
  • 【拆解】+南孚测电器拆解 之前在天猫上买了一盒南孚电池,他给我送了一个小东西—测电器。今天我们就来拆解一下这个小东西,看看它是怎么设计和工作的。 三颗指示灯显示电池剩余电量。当点亮3颗LED时,则表示点亮充足。当点亮2颗LED时,则表示还能用。当点亮1颗LED时,表示点亮地建议更换,当无法点亮LED时,则表示没电了。外壳上还印有正负极,以免用户将电池放反。 这个小东西拆解也很方便,一个螺丝刀稍微撬几下。外壳就下来了,它是通过卡扣连接。 开盖后,测电线路板清晰呈现在眼前。 让我们看看小小的线路板有
    zhusx123 2025-04-05 15:41 50浏览
  • 【拆解】+沈月同款CCD相机SONY DSC-P8拆解 这个清明假期,闲来无事,给大伙带来一个老古董物品的拆解--索尼SONY DSC-P8 CCD相机。这个产品是老婆好几年前在海鲜市场淘来的,由于显示屏老化,无法正常显示界面了,只有显示背光。但是这也无法阻止爱人的拍照。一顿盲操作依旧可以拍出CCD古董相机的质感。如下实拍: 由于这个相机目前都在吃灰。我就拿过来拆解,看看里面都是怎样个设计,满足下电子爱好者的探索。 首先给大伙展示下这台老相机的全貌。正视图  后视图 
    zhusx123 2025-04-06 17:38 78浏览
  • 在影像软的发展历程中,美图曾凭借着美图秀秀等一系列产品,在“颜值经济”的赛道上占据了领先地位,成为了人们日常生活中不可或缺的一部分,也曾在资本市场上风光无限,2016 年上市时,市值一度超过46亿美元,备受瞩目。 然而,随着市场的不断发展和竞争的日益激烈,美图逐渐陷入了困境。商业模式单一,过度依赖在线广告收入,使得其在市场波动面前显得脆弱不堪;多元化尝试,涉足手机、电商、短视频、医美等多个领域,但大多以失败告终,不仅未能带来新的增长点,反而消耗了大量的资源。更为严峻的是,用户流失问题日
    用户1742991715177 2025-04-05 22:24 61浏览
  • 引言:POPO声的成因与影响在语音芯片应用中,WT588F08A作为一款支持DAC+功放输出的高集成方案,常因电路设计或信号处理不当,在音频播放结束后出现POPO声(瞬态噪声)。这种噪声不仅影响用户体验,还可能暴露电路设计缺陷。本文将基于实际案例,解析POPO声的成因并提供系统化的解决方案。一、POPO声的根源分析1. 功放电路状态切换的瞬态冲击当DAC输出的音频信号突然停止时,功放芯片的输入端若处于高阻态或无信号状态,其内部放大电路会因电源电压突变产生瞬态电流,通过喇叭表现为POPO声。关键因
    广州唯创电子 2025-04-07 09:01 75浏览
  • 在追求环境质量升级与产业效能突破的当下,温湿度控制正成为横跨多个行业领域的核心命题。作为环境参数中的关键指标,温湿度的精准调控不仅承载着人们对舒适人居环境的期待,更深度关联着工业生产、科研实验及仓储物流等场景的运营效率与安全标准。从应用场景上看,智能家居领域要求温湿度系统实现与人体节律的协同调节,半导体洁净车间要求控制温湿度范围及其波动以保障良品率,而现代化仓储物流体系则依赖温湿度的实时监测预防各种产品的腐损与锈化。温湿度传感器作为实现温湿度监测的关键元器件,其重要性正在各行各业中凸显而出。温湿
    华普微HOPERF 2025-04-07 10:05 66浏览
  • 及时生产 JIT(Just In Time)的起源JIT 起源于 20 世纪 70 年代爆发的全球石油危机和由此引发的自然资源短缺,这对仰赖进口原物料发展经济的日本冲击最大。当时日本的生产企业为了增强竞争力、提高产品利润,在原物料成本难以降低的情况下,只能从生产和流通过程中寻找利润源,降低库存、库存和运输等方面的生产性费用。根据这种思想,日本丰田汽车公司创立的一种具有特色的现代化生产方式,即 JIT,并由此取得了意想不到的成果。由于它不断地用于汽车生产,随后被越来越多的许多行业和企业所采用,为日
    优思学院 2025-04-07 11:56 79浏览
我要评论
0
0
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦