CAN诊断浅谈

出自微信公众号--嘴哥有料,本人做学习记录用,侵删。

引言:

   从之前的课程我们了解到, 车上的智能硬件设备太多, 即ECU节点太多, 这些节点通过CAN总线外加汽车网关, 组成了整车CAN网络. 当车辆某个节点, 或者某条CAN总线出故障甚至网关出故障了, 会有什么现象呢?

某ECU节点故障:   也就是你的车上的某个智能硬件不work或者不好用, 比如空调这个设备无法调节温度了.

某条CAN总线故障:  比如Body CAN整条CAN总线都不work了, 那整条CAN总线上的智能硬件(ECU节点)会功能不好用, 比如语音控制打开天窗, 没效果了, 必须要手动用硬件打开天窗.

CAN网关出故障了:   嘴哥还没碰见过...., 但肯定是更加严重的, 比如到处都发出报警提示音, 因为很多ECU节点都丢失了.

但以上一般是不会有生命危险的,动力系统一般还可用, 车窗啥的单独的硬件按钮调节.

这时候你把车开去4s店维修:

  如果是4s店的维修工人, 一般是会帮您读取下诊断故障码,然后发现某项ECU的参数不对, 然后跟您说重新刷了下软件或更换了整个智能硬件. 这就是CAN诊断最通俗的解释。

 什么是ECU自检与诊断故障码

ECU自检:每个ECU都有自己故障检测功能, 基本上每个ECU都有一块EEPROM(可读性可编程存储器),可存储自身故障信息,但是以上故障信息一般会上传至网关的EEPROM,并以诊断故障码(DTC:Diagnose Trouble Code)的形式存储.

什么是CAN诊断

CAN诊断, 即对CAN网络各节点, 各CAN总线, 网关的故障查验与修复. 

查验包括: 诊断故障码查询

修复包括: 重新对ECU写入新的配置值

CAN诊断的发起条件

需要通过Diag CAN才能进行诊断.

一般是将直接将CAN硬件工具(诊断仪, PCAN-USB, Vehicle SPY3, CANoe...)的CAN-High, CAN-Low直接接到Diag 诊断CAN上, 然后通过诊断仪, PCAN-Explorer, Vehicle SPY3, CANoe等软件发送CAN诊断输入!

也有通过Tbox进行本地诊断或远程诊断的, 因为Tbox是诊断CAN总线上的唯一节点.

一般 什么人会用到诊断

① 4s店的维修人员, 他们一般只需要做读取故障码(19服务), ECU参数写入服务(2E服务), ECU参数读取服务(22服务)

② Tbox开发测试, 网关开发测试人员, 由于Tbox可发起本地诊断与远程诊断, 网关负责诊断信号转发, 所以都需要测试诊断.

③ 车厂的电子电气研发部门研发人员.....

CAN诊断标准介绍

统一诊断服务(UDS:Unified Diagnostic Services), 即IOS-14229标准, 绝大大部分汽车厂商用的诊断服务,诊断命令都大同小异, 唯一可能不同的是各厂商某些数据标识符(DID)及程序标识符不一致.

统一诊断服务(UDS)规定了以下诊断发起的服务, 诊断回应规范等:

诊断请求(发起)服务_Request

常用的诊断请求(发起)服务列表:

10: 诊断会话请求服务

  必须先发起诊断会话, 不然无法进行其他诊断服务发起服务.

  也就是说只要诊断, 必须先用10服务, 发起诊断会话session,

  类似于先建立握手,

      常用如:710 02 10 01 (10代表诊断会话发起服务, 01代表默认会话功能)

2E: 写入配置请求服务

       简单点说: 对某个ECU写入配置项数据, 就是常听说的重新标定.

       常用如:710 07 2E C0 01 01 03 22 FF (C0 01是一个DID数据标识符, 代表某ECU节点的多个参数, 01 03 22 FF代表ECU里的以上多个参数应该设定的值), 

11: 网关复位刷新请求服务

      一般如果用2E写入ECU配置值值后, 必须对网关刷新复位, 不然这个值可能不会立马生效.

       常用如: 710 02 11 01 (代表向所有的ECU发起硬复位请求)

27: 安全访问认证请求服务

      一般如果需要涉及2E写入ECU配置项等服务时, 必须通过网关的安全认证, 不然无权限修改, 你可以理解成, 没成功申请到27安全访问的话, 你的CAN网络权限是只读的, 不可写.

        常用如:710 02 27 03 (代表向网关发起安全认证的请求)

22: 读取配置请求服务

        简单点说: 读取某个ECU配置项信息

        常用如:710 03 22 C0 01 (代表读取C0 01 这个数据标识符里的多项参数值)

19: 读取故障码请求服务

       读取正常CAN网络的故障信息, 一般有ECU节点丢失(比如ECU节点松动脱落或者烧坏了等), 电压过高过低, CAN总线异常(即Bus Off)等...这些故障会记录在一串超长故障码(DTC)列表里.

        常用如:710 03 19 02 0C (代表读取整个CAN网络的当前已生效的故障码)

14: 清除故障码请求服务

       清除所有ECU的诊断故障码, 包括故障码相关的快照等,

       如果CAN网络有故障, 其会源源不断的反馈以上故障, 

       即使清除后也会立马再发出. 

      常用如:710 04 14 FF FF FF (代表清除所有ECU上的诊断故障码(包括故障码相关的快照等.))

 诊断回应_Responding

任何一轮诊断输入后, 都会有诊断回应帧, 一般是帧ID是:718

但是分为肯定回应及否定回应.

肯定回应:

即您刚才输入的诊断命令,目标对方(网关或某节点)已经收到并做了处理返回.

比如以下是: 10 诊断会话服务发起后, 收到的肯定回应,

如下示例:

CAN诊断浅谈

否定回应:

即您刚刚输入的诊断命令, 目标对方(网关或某节点)因为某些原因,未成功收到或者未做处理就被打回了, 可以理解成吃了闭门羹.

看到7f否定回应码就知道吃闭门羹了, 所有吃闭门羹的都是7f否定回应码.

比如以下是: 10 诊断会话服务发起后, 收到的否定回应:

CAN诊断浅谈

以上的吃闭门羹的原因是: 22条件不符合.

其实还有很多其他的原因会导致吃闭门羹, 常用的有:

11 服务不支持 

12 子功能不支持

13 报文长度错误

31 请求超出范围.....

以上只是嘴哥的浅谈CAN诊断.

有需要详细了解CAN诊断的朋友可以看看下面这批文章, 这偏文章写的超级赞, 算是CAN诊断里写的最通俗易懂的一篇文章了.

https://wenku.baidu.com/view/f2c2cc6afd0a79563c1e72d7.html?from=search

这是网友分享的众泰公司的诊断需求说明书.