AutoSAR通信概述-通信服务架构

一、BSW基础软件层概述

  BSW基础软件有IO功能、通信诊断功能、存储功能、看门狗功能、其他驱动功能,OS服务。

  MCAL层 :MCU驱动、看门狗驱动、存储驱动、通信驱动、IO驱动

  ECU抽象层 :其他板载设备抽象、看门狗硬件抽象、存储硬件抽象、通信硬件抽象、IO硬件抽象

  服务层 :OS服务、BswM、EcuM、看门狗服务、存储服务、通信和诊断服务

  BSW基础软件层结构见下图:

二、通信服务架构

  通信服务MCAL层包含了收发器驱动和总线控制器驱动,MCAL向上提供驱动接口供总线接口层(CanIf、LinIf、EthIf)调用。

  总线接口层也就是通信硬件抽象层,主要任务包括向上层模块提供与硬件无关的统一接口,屏蔽下层控制器收发器实现细节。这就是AutoSAR软件分层的最大好处,上层通信诊断服务并不知道下层是LIN总线的数据还是CAN总线的数据,就是通过通信硬件抽象层进行了隔离,所以当CAN总线、LIN总线驱动需要变化的时候,上层的代码都是不需要变的。

  通信软件模块传递:SWC->RTE->COM->PDUR->Bus Interface

  诊断软件模块传递:SWC->RTE->DCM->PDUR-> Bus Tp ->Bus Interface

  Note:通信报文分为业务报文和诊断报文,诊断服务依赖于诊断报文

  Bus Tp层:Tp(Transport Layer)是通信传输层,主要是为诊断使用的。

  PduR层:Pdu Router也就是Pdu路由层,所有的通信收发都会到这一层进行PDU路由。AutoSAR中包含了Can、Lin、Eth等通信,每个通信报文都可以描述成一个PDU(protocal data unit)协议数据单元,通过PduR这一层统一管理每个Pdu收发去处。如果是通信报文,会将报文路由到COM;如果是诊断报文,会把报文路由到DCM,可以把PDU理解为一帧报文。

  IPDU Mux:IPDU多路复用功能,指的是使用同一个I-PDU的同一种PCI,其SDU有多个不同的布局。

  COM:通信报文会到这里。从PDUR接收上来的I-PDU到这里会转成具体信号数据给到应用层使用,应用层通过RTE传下来的信号首先到这里转成I-PDU(一帧报文)发到PduR。应用层无需关注收发数据是通过什么总线传输的,这些收发的数据通过DBC文件或者ARXML文件事先定义好。COM主要起到信号接口(将一帧报文里面的所有信号拿出来给应用层)和网关作用。

  DCM:诊断报文会到这里,根据诊断要求做具体诊断服务。

三、通信服务传输数据流

  这个图把AutoSAR的通信服务很细致的面描述出来了。包括Eth、FlexRay、CAN、LIN 4种总线通信协议栈。

  L-PDU:Data Link Layer PDU(数据链路层PDU)

  N-PDU:Network Layer PDU网络层(也就是传输TP层)PDU,一般诊断报文会走TP层,通信报文直接从IF层转到PduR层,当诊断是多帧传输的时候,一个I-PDU就会被分段成多个N-PDU、通信报文一个I-PDU就是一个N-PDU

  I-PDU:Interaction Layer PDU交互层PDU,PDUR路由转发I-PDU。

  三种PDU代表在通信协议栈不同分层的协议数据单元,例如,I-PDU就包含了数据buffer指针、数据长度、和I-PDU ID,本质就是一个结构体

通信报文发送流程:

  Step1:应用层模块通过RTE调用COM模块Com_SendSignal请求发送信号

  Step2:COM写信号进PDUR

  Step3:PDU被事先定义好的PDU路由表(PUDR层定义),发送到指定目的层(根据PDU ID来查找PDU的路由表),比如CAN总线的PDU就会路由到CanIf层,Lin的PDU就会路由到LinIf层

  Step4:Interface层根据不同的通道,把报文写入到不同队列中

  Step5:Driver根据报文优先级发送报文

  注意:这里涉及到PDU的buffer缓存问题,一般情况下上层(COM)到If层都不会有PDU拷贝过程,直接把Buffer缓存指针进行传递。到了驱动层可能会拷贝进入驱动buffer进行发送。这样可以提高传输效率,节省RAM资源。

通信报文接收流程:

  Step1:驱动通过轮询或者中断接收报文

  Step2:驱动调用IF层的RxIndication将数据传递给Interface层(传指针)

  Step3:Interface调用PduR层的RxIndication将数据传递给PduR层

  Step4:PduR根据PDU ID找到路由表,路由到指定上层,通信报文一般都路由到COM层

  Step5:进入COM层之后,根据SWCs的情况,要么直接通过RTE把信号给到SWCs(需定义信号的回调函数),要么缓存到自己的Buffer

  注意:这里也涉及到PDU的Buffer缓存问题,一般情况从驱动上来也不会有Buffer拷贝,只有到COM层才会有自己的Buffer(拷贝),这样可以提高传输效率,节省RAM资源。

相关推荐
HavenlonLabs13 小时前
三年内,AI 控制会走向安全的一线
人工智能·安全·金融·架构·安全架构
故渊at13 小时前
第十三板块:Android 综合架构与未来演进 | 第三十一篇:Android 架构演进与 Fuchsia OS 的挑战
android·架构·宏内核·微内核·fuchsia·ipc 性能博弈
咚为13 小时前
Claude Code 深度定制指南:从分层架构到 AI 参谋系统的高级搭建实践
人工智能·架构
X54先生(人文科技)13 小时前
X54先生与“启”关于涌现对话
人工智能·架构·开源·零知识证明
“码”力全开13 小时前
云边端协同架构:基于 Docker 与边缘计算的 GB28181/RTSP 异构视频 AI 管理平台设计(附源码交付)
人工智能·docker·架构
TheRouter13 小时前
LLM 应用的 Guardrails 工程:5 层安全防护架构,为什么一层不够
安全·ai·架构
搞点AI13 小时前
深入理解 vLLM 的 Block 机制
架构
一切皆是因缘际会13 小时前
频域特征解构底层机理与双域融合鉴伪算法优化
人工智能·算法·ai·架构
codeking13 小时前
3 步把 AI 桌面自动化从失控拉回可用
javascript·架构
zyk_computer13 小时前
AI Agent ,让循环收敛的那套闭环控制系统
人工智能·后端·python·ai·架构·agent·ai agent