CanNm处于PBS状态下接收到一帧诊断报文DCM会响应吗

原创 汽车电子嵌入式 2024-08-07 07:58

前言

我们知道ECU的网络管理是按照AUTOSAR标准开发的话,诊断报文是无法唤醒ECU且唤醒网络的,因为CanNm状态机处于Bus-Sleep Mode的时候,因为ComM-->CanSm-->CanIf-->CanTrcv, CanDriver关闭了Can收发器和控制器则在Bus-Sleep Mode下通信协议栈是无法收到Can报文的,诊断报文也就无法唤醒网络。但是,但CanNm处于Prepare Bus-Sleep ModeCantrcvCanDriver还没被关闭,则诊断报文是可以被通信协议栈收到的,那么CanNm处于Prepare Bus-Sleep Mode时诊断报文是可以唤醒网络的注意:前面这些结论如果不能理解的朋友可以参考以下的文章)。

ECU系统休眠后通过诊断报文唤醒ECU且唤醒网络后快发NM报文

ECU系统休眠后通过诊断报文唤醒ECU且唤醒网络

AUTOSAR架构下CanTrcv休眠唤醒问题再探

AUTOSAR 架构下EcuM唤醒源事件详解

DCM模块唤醒网络是主动唤醒还是被动唤醒(重新修改)

那么,我们的问题来了,CanNm处于Prepare Bus-Sleep Mode时收到诊断报文唤醒网络,DCM会响应吗DCM发出诊断Response报文,我们在CAN总线上能通过上位机收到)?

这个问题的答案很容易得到,我们在CanNm处于Prepare Bus-Sleep Mode时发送诊断报文唤醒网络,看有没有诊断响应报文发出来就能知道DCM会不会响应

这里直接给出答案,CanNm处于Prepare Bus-Sleep Mode时收到诊断报文后DCM不会响应。但是网络明明已经被诊断报文唤醒了,为什么DCM发不出诊断响应报文了?



注:本文章引用了一些第三方工具和文档,若有侵权,请联系作者删除!

正文

1.CanNmRSS状态切换到PBS状态行为分析

1.1.CanNm动作

 

CanNm状态从RSS状态跳转到PBS状态时会调用Nm_PrepareBusSleepMode()接口通知到NM模块,随后NM模块会调用ComM_Nm_PrepareBusSleepMode()接口通知到ComM模块。


1.2.ComM动作


ComM模块收到ComM_Nm_PrepareBusSleepMode()通知后会切换到COMM_SILENT_COMMUNICATION状态,然后DMC会调用Dcm_ComM_SilentComModeEntered()通知DCM模块。


1.3.DCM动作


DCM收到Dcm_ComM_SilentComModeEntered()通知后会Disable报文发送(诊断报文Response)。


1.4 小结

通过以上分析我们可以知道,CanNm进入到PBS状态后,DCM是无法相依诊断报文的。


2.CanNMPBS状态下收到一帧诊断报文行为分析

2.1.DCM动作1

CanNm处于PBS状态下时Can Stack是有收发报文的能力的,这个时候如果收到一帧诊断报文,通过Can StackCan Driver -> CanIf -> CanTp -> PduR -> Dcm调用Dcm_TpRxIndication上报给Dcm模块(如果是CAN收发是中断完成的,这个过程是中断调用栈中实现的),随后Dcm模块会调用ComM_DCM_ActiveDiagnostic模块通知到ComM模块。


2.2. ComM动作


ComM模块接收到Dcm模块的ComM_DCM_ActiveDiagnostic()通知后会从COMM_SILENT_COMMUNICATION状态切换到COMM_FULL_COMMUNICATION状态,然后回调用Dcm_ComM_FullComModeEntered()通知到Dcm模块。


2.3. DCM动作2


DCM模块收到ComM_DCM_ActiveDiagnostic()通知后Enable报文的发送(能够诊断Respons)。


2.3. CanNm动作

CanNm会由ComM调用CanNm_NetworkRequest()主动唤醒后切换到RMS状态(参考《DCM模块唤醒网络是主动唤醒还是被动唤醒(重新修改)》一文)。


2.4 问题

从以上分析可知在CanNm处于PBS状态下收到一帧诊断报文后会切换ComM状态到COMM_FULL_COMMUNICATION, 随后ComM会调用ComM_DCM_ActiveDiagnostic()解除Dcm发送报文的禁制,看上去Dcm应该能响应这一帧报文呀(发出诊断Respons报文)?但是为啥实际情况为啥没有诊断报文发出来了?


2.5 分析

通过实际调试和源码分析,得知Can Stack收到第一帧诊断报文通知给到DCM模块(中断RxIndication方式),随后DCM立马处理这一帧报文(这个时候DCM还是被ComMSilent状态禁止发送报文的),在尝试发送报文时检查到Transmit是被Disable的,最后就没有调用到PduR_DcmTransmit()外发出Respons报文。然后,就算DCM没有外发出Respons报文,DCM也认为这次的诊断响应已经处理完毕(认为在Silent状态下没有外发出报文是正常的)。随后,ComMFULL COM通知才到Dcm模块,这个时候DCM模块也不会再响应上一次的诊断请求了。


注意:也就是在以上分析中的2.1章节的DCM动作1中DCM就处理了这一帧诊断接收报文,由于DCM还处于Silent Disable Transmit状态,所以没有外发出诊断Respons报文。随后,ComM的Full Com通知才到DCM模块,之后DCM模块就能正常外发诊断Response报文了(也就是能响应第2帧诊断报文)。


3.总结

CanNmPBS状态下收到一帧诊断报文后会唤醒网络,但是诊断DCM模块不会响应这一帧报文,根本原因是DCM模块响应诊断报文的逻辑(外发Respons报文)比ComM模块解除DCM禁发报文的通知先完成。


End

「汽车电子嵌入式在CSDN上同步推出AUTOSAR精进之路专栏,本专栏每个模块完全按实际项目中开发及维护过程来详细介绍。模块核心概念介绍、实际需求描述、实际工程配置、特殊需求介绍及背后原理、实际工程使用经验总结。目的是让读者看完每一个章节后能理解原理后根据需求完成一个模块的配置或者解决一个问题。」


点击文章最后左下角的阅读原文可以获取更多信息


或者复制如下链接到浏览器获取更多信息

https://blog.csdn.net/qq_36056498/article/details/132125693


文末福利




1
.如需汽车电子嵌入式收集的学习文档,
后台回复“

资料

即可免费下载;

2.为便于技术交流,创建了汽车电子嵌入式技术交流群,可尽情探讨AP,CP,DDS,SOME/IP等前沿热点话题,后台回复“加群”即可加入;


注:本文引用了一些第三方工具和文档,若有侵权,请联系作者删除!


推荐阅读

汽车电子嵌入式精彩文章汇总第一期:20210530-20230703

汽车电子嵌入式精彩文章汇总第2期

汽车电子嵌入式精彩文章汇总第3期

【OS】AUTOSAR OS Event实现原理



End


欢迎点赞,关注,转发,在看,您的每一次鼓励,都是我最大的动力!

汽车电子嵌入式

微信扫描二维码,关注我的公众号

评论
  • 国产光耦合器正以其创新性和多样性引领行业发展。凭借强大的研发能力,国内制造商推出了适应汽车、电信等领域独特需求的专业化光耦合器,为各行业的技术进步提供了重要支持。本文将重点探讨国产光耦合器的技术创新与产品多样性,以及它们在推动产业升级中的重要作用。国产光耦合器创新的作用满足现代需求的创新模式新设计正在满足不断变化的市场需求。例如,高速光耦合器满足了电信和数据处理系统中快速信号传输的需求。同时,栅极驱动光耦合器支持电动汽车(EV)和工业电机驱动器等大功率应用中的精确高效控制。先进材料和设计将碳化硅
    克里雅半导体科技 2024-11-29 16:18 157浏览
  • 最近几年,新能源汽车愈发受到消费者的青睐,其销量也是一路走高。据中汽协公布的数据显示,2024年10月,新能源汽车产销分别完成146.3万辆和143万辆,同比分别增长48%和49.6%。而结合各家新能源车企所公布的销量数据来看,比亚迪再度夺得了销冠宝座,其10月新能源汽车销量达到了502657辆,同比增长66.53%。众所周知,比亚迪是新能源汽车领域的重要参与者,其一举一动向来为外界所关注。日前,比亚迪汽车旗下品牌方程豹汽车推出了新车方程豹豹8,该款车型一上市就迅速吸引了消费者的目光,成为SUV
    刘旷 2024-12-02 09:32 59浏览
  • 光耦合器作为关键技术组件,在确保安全性、可靠性和效率方面发挥着不可或缺的作用。无论是混合动力和电动汽车(HEV),还是军事和航空航天系统,它们都以卓越的性能支持高要求的应用环境,成为现代复杂系统中的隐形功臣。在迈向更环保技术和先进系统的过程中,光耦合器的重要性愈加凸显。1.混合动力和电动汽车中的光耦合器电池管理:保护动力源在电动汽车中,电池管理系统(BMS)是最佳充电、放电和性能监控背后的大脑。光耦合器在这里充当守门人,将高压电池组与敏感的低压电路隔离开来。这不仅可以防止潜在的损坏,还可以提高乘
    腾恩科技-彭工 2024-11-29 16:12 117浏览
  • 在电子技术快速发展的今天,KLV15002光耦固态继电器以高性能和强可靠性完美解决行业需求。该光继电器旨在提供无与伦比的电气隔离和无缝切换,是现代系统的终极选择。无论是在电信、工业自动化还是测试环境中,KLV15002光耦合器固态继电器都完美融合了效率和耐用性,可满足当今苛刻的应用需求。为什么选择KLV15002光耦合器固态继电器?不妥协的电压隔离从本质上讲,KLV15002优先考虑安全性。输入到输出隔离达到3750Vrms(后缀为V的型号为5000Vrms),确保即使在高压情况下,敏感的低功耗
    克里雅半导体科技 2024-11-29 16:15 119浏览
  • 戴上XR眼镜去“追龙”是种什么体验?2024年11月30日,由上海自然博物馆(上海科技馆分馆)与三湘印象联合出品、三湘印象旗下观印象艺术发展有限公司(下简称“观印象”)承制的《又见恐龙》XR嘉年华在上海自然博物馆重磅开幕。该体验项目将于12月1日正式对公众开放,持续至2025年3月30日。双向奔赴,恐龙IP撞上元宇宙不久前,上海市经济和信息化委员会等部门联合印发了《上海市超高清视听产业发展行动方案》,特别提到“支持博物馆、主题乐园等场所推动超高清视听技术应用,丰富线下文旅消费体验”。作为上海自然
    电子与消费 2024-11-30 22:03 70浏览
  • 《高速PCB设计经验规则应用实践》+PCB绘制学习与验证读书首先看目录,我感兴趣的是这一节;作者在书中列举了一条经典规则,然后进行详细分析,通过公式推导图表列举说明了传统的这一规则是受到电容加工特点影响的,在使用了MLCC陶瓷电容后这一条规则已经不再实用了。图书还列举了高速PCB设计需要的专业工具和仿真软件,当然由于篇幅所限,只是介绍了一点点设计步骤;我最感兴趣的部分还是元件布局的经验规则,在这里列举如下:在这里,演示一下,我根据书本知识进行电机驱动的布局:这也算知行合一吧。对于布局书中有一句:
    wuyu2009 2024-11-30 20:30 86浏览
  • 艾迈斯欧司朗全新“样片申请”小程序,逾160种LED、传感器、多芯片组合等产品样片一触即达。轻松3步完成申请,境内免费包邮到家!本期热荐性能显著提升的OSLON® Optimal,GF CSSRML.24ams OSRAM 基于最新芯片技术推出全新LED产品OSLON® Optimal系列,实现了显著的性能升级。该系列提供五种不同颜色的光源选项,包括Hyper Red(660 nm,PDN)、Red(640 nm)、Deep Blue(450 nm,PDN)、Far Red(730 nm)及Ho
    艾迈斯欧司朗 2024-11-29 16:55 155浏览
  • 学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习笔记&记录学习习笔记&记学习学习笔记&记录学习学习笔记&记录学习习笔记&记录学习学习笔记&记录学习学习笔记记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&
    youyeye 2024-11-30 14:30 62浏览
  • 光伏逆变器是一种高效的能量转换设备,它能够将光伏太阳能板(PV)产生的不稳定的直流电压转换成与市电频率同步的交流电。这种转换后的电能不仅可以回馈至商用输电网络,还能供独立电网系统使用。光伏逆变器在商业光伏储能电站和家庭独立储能系统等应用领域中得到了广泛的应用。光耦合器,以其高速信号传输、出色的共模抑制比以及单向信号传输和光电隔离的特性,在光伏逆变器中扮演着至关重要的角色。它确保了系统的安全隔离、干扰的有效隔离以及通信信号的精准传输。光耦合器的使用不仅提高了系统的稳定性和安全性,而且由于其低功耗的
    晶台光耦 2024-12-02 10:40 54浏览
  • RDDI-DAP错误通常与调试接口相关,特别是在使用CMSIS-DAP协议进行嵌入式系统开发时。以下是一些可能的原因和解决方法: 1. 硬件连接问题:     检查调试器(如ST-Link)与目标板之间的连接是否牢固。     确保所有必要的引脚都已正确连接,没有松动或短路。 2. 电源问题:     确保目标板和调试器都有足够的电源供应。     检查电源电压是否符合目标板的规格要求。 3. 固件问题: &n
    丙丁先生 2024-12-01 17:37 57浏览
我要评论
0
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦