嘴哥有料系列-can工具1:CAN诊断浅谈 + 如何用CAN工具进行诊断

原文章:https://mp.weixin.qq.com/s/bcuoUQfkfyx6rtbgw-Z_BQ


引言:

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

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

某条CAN总线故障:比如BCAN整条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

 

注: 以下都是16进制数字,本应该加上0x前缀.

 

一般诊断请求(发起, 就是我们常说的Request)的输入格式: 710 02 10 01

 

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

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 诊断会话服务发起后, 收到的肯定回应,

如下示例:

 

 

 

否定回应:

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

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

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

 

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

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

11 服务不支持 

12 子功能不支持

13 报文长度错误

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

     

 

 

     实例  

用PCAN-USB 读取诊断故障码(19服务)

     1. 发起诊断会话10服务01默认会话功能并成功收到肯定回应

          710 02 10 01  

     2. 发起诊断故障码查询服务19服务02按故障掩码查询方式功能0C已经确认的诊断故障代码

         710 03 19 02 0C

     3. PCAN-Explorer端的输入如下:

    

即每10ms一轮的故障码查询服务.

点击ok后, 就到以下页面,

诊断请求, 请看Transmit消息发送去的710帧, 

诊断回应结果, 请看Receive消息接收区的718帧.

具体数据比较长, PCAN-Explorer这里只显示了:

10 73 59 02 FF C1 40 87 这8个字节, 其实不止的, 

通过其他的CAN工具(支持超过8个的多字节显示)读取出:

10 73 59 02 FF C1 40 87 2F C1 64 87 2F D0 01 87 2F D1 40 87 2F C1 55 87 2F C1 98 87 2F C2 45 87 2F C1 51 87 2F D2 64 87 2F C1 21 87 2F C1 26 87 2F C1 28 87 2F C1 00 87 2F C1 01 87 2F C1 02 87 2F D0 08 87 2F C2 93 87 2F 91 65 17 2F 91 67 17 2F 40 42 54 2F 05 64 1C 2F 05 89 1C 2F 08 26 1C 2F D0 03 87 2F C2 36 87 2F D0 09 87 2F 91 6A 17 2F C1 27 87

 

10代表超长字节

73代表数据长度, 共73个字节

59代表发起的19服务+40的偏移量

FF代表之前故障(之前有问题, 但是现在故障已经不存在了)

2F是当前故障(现在还没好,故障还存在)

 

以上FF和2F共28次出现, 代表了28个故障信息,

比如FF C1 40 87就是一条"之前故障".

具体是什么故障, 要看C1 40 87的文档定义了,个人认为每个厂商的定义可能不一样.

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

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

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

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

 

学好了诊断, 您应该就可以进行tbox测试了, 及部分的网关测试, 也会模拟发送各种信号了. 诊断算是CAN教程里边最简单的课程了, 嘴哥不骗人, 因为嘴哥已经实现了诊断的自动化测试.

而且CAN诊断是统一标准, 各个公司都用UDS统一诊断服务, 大同小异的!

祝您成功!

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值