AUTOSAR联盟在召开架构讨论会上,工程师讲解了AUTOSAR的基本框架(另见《 AUTOSAR架构的故事(干货) 》),同时提出 Communication 部分另外讨论。这次这位工程师准备了丰富的资料将通信服务详细讲解了一番。
1 Communication Services – General
Communication Service 通信服务是一组用于车辆网络通信(CAN,LIN,FlexRay和以太网)的模块。它们通过通信硬件抽象与通信驱动程序接口。
任务: 为车辆网络提供统一的接口以进行通信。 提供统一的网络管理服务提供统一的车辆网络接口以进行诊断通信 在应用程序中隐藏协议和消息属性。 特性:
- 实现了µC和ECU硬件独立,部分取决于总线类型
- 上层接口与µC,ECU硬件和总线类型无关。
- 通信服务将在以下页面中详细介绍每个相关的车辆网络系统。
2 Communication Stack – CAN
CAN通信服务 是一组模块,用于与通信系统CAN进行车辆网络通信。
它提供与CAN网络的统一接口。在应用程序中隐藏协议和消息属性。 CAN通信栈支持,经典CAN通讯(CAN 2.0)和CAN FD通信(如果硬件支持)
特性 :
- 实现了µC和ECU硬件独立,部分取决于CAN。
- AUTOSAR COM,通用NM(网络管理)接口和诊断通信管理器对于所有车辆网络系统都是相同的,每个ECU作为一个实例存在。
- 通用NM接口仅包含一个调度程序, 不包括其他功能。对于网关ECU,它还可以包括NM协调器功能,该功能允许同步多个(相同或不同类型的)不同网络以同步唤醒或关闭它们。
- CAN NM专用于CAN网络,并将在每个CAN车辆网络系统中实例化。
- 特定于通信系统的Can State Manager可以处理依赖于通信系统的启动和关闭功能。此外,它还控制COM的不同选项,以发送PDU并监视信号超时。
Communication Stack Extension – TTCAN
特性:
-
TTCAN是CAN的绝对超集,即支持TTCAN的CAN栈可以同时服务于CAN和TTCAN总线。
-
CanIf和CanDrv是仅有的需要扩展才能为TTCAN通信提供服务的模块。
-
对于具有TTCAN功能的CAN,Communication Stack CAN的属性也适用。
3 Communication Stack Extension – J1939
J1939通信服务 扩展了普通的CAN通信栈,用于重型车辆中的车辆网络通信。
它提供J1939所需的协议服务。在不需要的地方从应用程序隐藏协议和消息属性。 注意,CAN栈中有两个传输协议模块(CanTp和J1939Tp),可以在不同的通道上交替使用或并行使用 它们的用法如下: CanTp:ISO诊断(DCM),标准CAN总线上的大型PDU传输 J1939Tp:J1939诊断,J1939驱动的CAN总线上的大型PDU传输
特性:
- 实现了基于CAN,独立于µC和ECU硬件。
- AUTOSAR COM,通用NM(网络管理)接口和诊断通信管理器对于所有车辆网络系统都是相同的,每个ECU作为一个实例存在。
- 支持在配置时未知的动态帧标识符。
- J1939网络管理可为每个ECU分配唯一的地址,但不支持睡眠/唤醒处理以及诸如部分联网之类的相关概念。
- 提供J1939诊断和请求处理。
4 Communication Stack – LIN
LIN通信服务 是用于与通信系统LIN进行车辆网络通信的一组模块。
它提供到LIN网络的统一接口。在应用程序中隐藏协议和消息属性。
LIN通信服务包含:
- 符合ISO 17987的通信栈
- 计划表管理器,用于处理切换到其他计划表的请求(对于LIN主节点)
- 不同LIN框架类型的通讯处理
- 传输协议,用于诊断
- 唤醒和睡眠界面
- 基本的LIN驱动程序:
- 实施LIN协议并访问特定的硬件
- 同时支持简单的UART和基于复杂帧的LIN硬件
注意将LIN集成到AUTOSAR中的情况:
- LIN接口控制WakeUp / Sleep API,并允许 Slave端 使总线保持唤醒状态(分散式方法)。
- 特定于通信系统的LIN状态管理器处理与通信相关的启动和关闭功能。此外,它控制来自Communication Manager的通信模式请求。LIN状态管理器还通过连接COM来控制I-PDU组。
- 发送LIN帧时,LIN接口在需要数据的时间点(即在发送LIN帧之前)向PDU路由器请求帧(I-PDU)的数据。
5 Communication Stack – FlexRay
FlexRay通信服务 是一组模块,用于与通信系统FlexRay进行车辆网络通信。
它提供与FlexRay网络的统一接口。在应用程序中隐藏协议和消息属性。 注意:
- FlexRay栈中有两个传输协议模块,可以交替使用
- FrTp:FlexRay ISO传输层
- FrArTp:FlexRay AUTOSAR传输层,提供与AUTOSAR R3.x的总线兼容性
特性:
- 实施µC和ECU硬件独立,部分取决于FlexRay。
- AUTOSAR COM,通用NM接口和诊断通信管理器对于所有车辆网络系统都是相同的,每个ECU作为一个实例存在。
- 通用NM接口仅包含一个调度程序。不包括其他功能。对于网关ECU,将其替换为NM协调器,该协调器还提供了同步多个不同网络(相同或不同类型)以同步唤醒或关闭它们的功能。
- FlexRay NM专门用于FlexRay网络,并在FlexRay车载网络系统中实例化。
- 特定于通信系统的FlexRay状态管理器处理与通信系统有关的启动和关闭功能。此外,它还控制COM的不同选项,以发送PDU并监视信号超时。
6 Communication Stack – TCP/IP
TCP/IP通信服务 是一组模块,用于与通信系统TCP/IP进行车辆网络通信。
它提供一个到TCP/IP网络的统一接口。在应用程序中隐藏协议和消息属性。
特性:
- TcpIp模块实现TCP / IP协议家族的主要协议(TCP,UDP,IPv4,IPv6,ARP,ICMP,DHCP)并通过以太网提供基于套接字的动态通信。
- 套接字适配器模块(SoAd)是TcpIp模块的唯一上层模块。
7 Communication Stack – General
General Communication Stack 属性:
- 信号网关是AUTOSAR COM的一部分,用于路由信号。
- 基于PDU的网关是PDU路由器的一部分。
- IPDU复用提供了添加信息的可能性,以实现I-PDU的复用(内容不同,但总线上的ID相同)。
- 多I-PDU到容器的映射提供了将多个I-PDU组合成一个较大的(容器)I-PDU的可能性,以便在一个(特定于总线的)帧中进行传输。
- 上层接口:µC,ECU硬件和网络类型无关。
- 有关GW体系结构的细化,请参阅“示例通信”
8 Off-board Communication Stack – Vehicle-2-X
Off-board Communication Service 是用于通过自组织无线网络进行 Vehicle-to-X 通信的一组模块。
- 实现用于接收和传输标准化 V2X 消息的功能,为特定于车辆的SW-C建立接口
- 基本传输协议=第4层
- 地理网络=第3层(根据地理区域寻址,相应的以太网帧具有自己的以太类型)
- V2X 管理:管理跨层功能(例如动态拥塞控制,安全性,位置和时间)
它提供与无线以太网网络的统一接口。在应用程序中隐藏协议和消息属性。
本文参考AUTOSAR官方架构文档,图片也来源AUTOSAR官方。
|