Autosar Com信号收不到排查-基于ETAS软件

文章目录

前言

大家可能在Autosar通讯开发过程中都遇到过报文信号收不到的情况,其中原因有很多,但排查起来有时没有头绪,本文以其中一个问题,梳理一下Com接收的信号链路,并对问题进行分析与处理

Com信号接收数据链

正常Com信号接收的数据链路如下(基于CAN中断):

问题排查

知道了正常的数据传递流程,调试起来就很简单了,发送对应的报文和UB位后,再各个函数打断点即可,此处我们从上层接收往下查,Rte_COMCBK函数打断点 ,确认进不去。在Com_Prv_InvokeRxNotifications 函数中打断点,发现可以进

但是再单步运行就进不到后面的逻辑了,说明Com_GetValue函数check返回无效,该函数是检测PDU中是否有任一signal配置了callback函数

排查到这里,问题已经比较明显了,说明Com中这个Signal没有配置callback函数,且这个Singal对应的PDU中的所有信号都没有配置callback

解决方案

在Com模块中对应的Singal配置COMCbk函数,需要以Rte_COMCbk_ + ComSignal名进行配置,示例如下:

配置完后生成BSW代码,发现除了生成了COMCbk外

还生成了ComPdu的一个Reception type

只有ComPdu的Notify_Cbk使能 之后,才能够进入Com Callback,调试时主要原因就是这个条件没满足

总结

按Com信号接收链路进行排查问题,就顺利多了,另外调试时发现该信号的Rte_COMCbk 函数在Rte.c中是有的,编译生成的map和elf中也有,但该函数实际未被使用。排查发现hightec编译器在一个文件中指定了段section,则该文件中的这个段里的函数,即使是未使用的函数,也是无法被优化删除的,这一点没有GHS做好,目前也没有找到好的优化方法

相关推荐
龙智DevSecOps解决方案4 天前
TESSY AUTOSAR插件详解:从ARXML模型到自动化测试的完整工作流
autosar·tessy
说不得明天6 天前
网络管理:AutoarNM部分
c语言·网络·mcu·汽车·autosar
时光の尘7 天前
【嵌入式大厂面经】·CAN总线常见考点(持续更新中···)
stm32·单片机·mcu·物联网·can·ack
内容为空10 天前
comm网络开启流程
autosar
内容为空10 天前
comm网络关闭流程
autosar
不知秋88011 天前
PCAN-View核心功能使用手册
can·以太网·codesys·peakcan·pcan-view
内容为空13 天前
AUTOSAR COM 发送流程笔记:Com_SendSignal 与 Com_MainFunctionTx
autosar
嵌软小白呗16 天前
Autosar-SecOC功能详解(一)
e2e·can·autosar·crc·secoc
内容为空21 天前
TC397 CAN 模块硬件资源与配置详解笔记
autosar
阿歪i22 天前
EB 配置MCAL (1)
s32k144·autosar·mcal