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

相关推荐
2601_9545267539 分钟前
【工控底层架构】进口阀门和国产阀门哪个性价比高?从TCO模型到边缘诊断源码的全栈解析
人工智能·架构·硬件工程
an317421 小时前
弹窗数据流设计的两种高阶架构实践
前端·vue.js·架构
熊猫钓鱼>_>2 小时前
智能革命的巨浪——AI时代的社会重构与生存之道
大数据·人工智能·重构·架构·llm·agent·ai-native
doiito(Do It Together)2 小时前
我用 Rust 写了个 AI 媒体管家:Gliding Horse 赋能 media_agent,目标是让 ComfyUI 工作流彻底自动化
人工智能·架构·rust·媒体
Xiaoda112 小时前
vLLM Scheduler:为什么 Continuous Batching 是 LLM Serving 的核心?
架构
江畔柳前堤2 小时前
第07章:Docker 网络模型
运维·网络·git·elasticsearch·docker·容器·架构
AI-好学者3 小时前
RAG知识点_3_高级实践
人工智能·ai·架构·langchain·ai编程
禅思院4 小时前
AI对话前端从入门到崩溃:一个长对话引发的五层优化战争【引子】
前端·面试·架构
mONESY5 小时前
AI界的通用USB-C!一文吃透爆火的MCP协议,重构AI智能体底层架构
架构
杉氧5 小时前
兼容与共生:如何在旧项目中优雅地引入 Compose?
android·架构·android jetpack