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资源。

相关推荐
小超同学你好2 小时前
Transformer 23. Qwen 3.5 架构介绍:混合线性/全注意力、MoE 与相对 Qwen 1 / 2 / 3 的演进
人工智能·深度学习·语言模型·架构·transformer
Ulyanov3 小时前
Streamlit基础入门与快速原型开发
python·架构·系统仿真
复园电子3 小时前
KVM与Hyper-V虚拟化环境:彻底解决USB外设映射掉线的底层架构优化
开发语言·架构·php
Kel4 小时前
从Prompt到Response:大模型推理端到端核心链路深度拆解
人工智能·算法·架构
海兰5 小时前
【AI网关】阿里开源的Higress(OpenAPI-to-MCP工具)
人工智能·架构·开源·银行系统
heimeiyingwang5 小时前
【架构实战】数据仓库分层架构(ODS/DWD/DWS/ADS)
数据仓库·架构
名字不好奇5 小时前
Claude Code工作原理深度解析:从技术架构到设计哲学
人工智能·架构
一条咸鱼_SaltyFish6 小时前
DDD 架构重构实践:AI Skills 如何赋能DDD设计与重构
java·人工智能·ai·重构·架构·ddd·领域驱动设计
33三 三like6 小时前
GraphRAG 架构在养老志愿服务推荐中的创新应用:当知识图谱遇见大语言模型
语言模型·架构·知识图谱