• 统一诊断服务 (Unified diagnostic services , UDS) (五)


    转载来自  :https://zhuanlan.zhihu.com/p/34425737  知乎张丁

    这篇文章介绍Stored Data Transmission (存储数据传输,用于操作DTC)这一类诊断服务,涉及到两条诊断命令,分别是:

    0x14:ClearDiagnosticInformation

    0x19:ReadDTCInformation

    这两条服务用于操作存储在ECU中的DTC,使用频率很高,而且它们比较好地体现了“诊断”两个字的含义。

    0x14:ClearDiagnosticInformation

    这条诊断命令的格式比较简单,用法也很好理解,即删除存储在ECU中的DTC。

                   0x14诊断命令请求的格式

    第一个字节就是SID了,后边的三个字节用于标识将要被删除的DTC种类,UDS规定用FF FF FF表示所有种类的DTC,由厂家自定义代表Powertrain、Chassis、、Body、Network Communication等种类DTC的值。

    比如,14 FF FF FF这条指令表示的就是删除掉ECU中的所有DTC。ECU只需要返回一个0x54表示成功执行即可。

    其他的 00 00 00 FF FF FE 表示的是针对哪个


    0x19:ReadDTCInformation

    这条指令用于读取存储在ECU中的DTC,它的格式如下

                                  0x19诊断命令请求的格式0x14诊断命令请求的格式

    0x19服务的sub-function代表了各式各样读取DTC的方法,UDS给19服务的sub-function从0x00到0x19进行了明确定义,我只使用过其中4种,下面对我用过的这些进行介绍,如果大家对其他的感兴趣,可以查阅ISO 14229的定义。

    sub-function = 0x01 (reportNumberOfDTCByStatusMask)

    sub-function = 0x01用于读取符合特定条件的DTC数量,此时parameter为一个byte的Mask,用于与DTC的Status进行“与”运算,

    而ECU返回的则是"与"运算之后结果不为0的DTC的数量。DTC的Status用一个byte表示,其中的8个bit分别代表DTC的不同状态,

    比如,bit 0 表示这个DTC是active的还是passive的,bit 4表示这个DTC是否已经被confirm了,如果DTC的状态是confirm,则说明该DTC已经被ECU存储下来了。

    比如:19 01 08这个命令的用途,就是读取所有状态为confirm的DTC的数量。

    sub-function = 0x02 (reportDTCByStatusMask)

    sub-function = 0x02用于读取符合特定条件的DTC列表,此时parameter仍然为一个byte的Mask,用于与DTC的Status进行“与”运算,而ECU返回的则是"与"运算之后结果不为0的DTC列表。

    比如19 02 01这个命令的用途,就是读取所有状态为active的DTC的数量。此时ECU返回的格式应该是59 02 01 XX XX XX 01 YY YY YY 09......。返回的DTC列表中的每个条目为4个字节,前三个字节用于标识DTC,比如 XX XX XX,最后一个字节用于标识DTC状态,比如01,表示DTC是active的,09表示DTC是active且confirm的。

    sub-function = 0x06 (reportDTCExtDataRecordByDTCNumber)

    sub-function = 0x06用于读取某个DTC及其相关的环境数据,此时parameter为4个byte,前三个byte用于标识我们要读取的DTC,第四个byte用于标识要读取的环境数据的范围,UDS规定使用FF来表示读取所有的环境数据,各厂家可以要根据自己的需求定义其他的值来代表要读取的环境数据的范围。环境数据包括DTC状态,优先级,发生次数,老化计数器,时间戳,里程等,厂家还可以根据自己的需求定义一些此DTC产生时的测量数据。

    比如 19 06 XX XX XX FF就表示读取 XX XX XX这个DTC的所有环境数据,ECU的返回值应该是59 06 XX XX XX AA BB CC DD.....,其中AA BB CC DD...代表的就是XX XX XX这个DTC产生时所一起存储的环境数据。

    sub-function = 0x0E(reportMostRecentConfirmedDTC)

    sub-function = 0x0E时,不需要parameter。0x0E表示,要求ECU上报最近的一条被置为confirm的DTC。我在《统一诊断服务 (Unified diagnostic services , UDS) (三)》一文中介绍过0x86服务,sub-function = 0x0E的19服务通常被作为参数传递给86指令,要求ECU在发生DTC存储的时候进行自动上报,即19 0E这两个字节的指令被嵌入到86服务的命令中。这条命令在开发阶段会用到,比如验证某个故障路径是否生效。

     //19这边不那么 详细   可以查看 https://blog.csdn.net/weixin_44536482/article/details/93090417

    Sub-function Description
    01 reportNumberOfDTCByStatusMask/通过状态掩码报告DTC数量
    02 reportDTCByStatusMask/通过状态掩码报告DTC信息
    04 reportDTCSnapshotRecordByDTCNumber/获取指定DTC的快照记录
    06 reportDTCExtendedDataRecordByDTCNumber/获取指定DTC的扩展数据记录
    0A reportSupportedDTC/获取ECU支持的所有DTC

  • 相关阅读:
    C#.NET 以上超大文件上传和断点续传服务器的实现
    ASP.NET 以上超大文件上传和断点续传服务器的实现
    JSP 以上超大文件上传和断点续传服务器的实现
    Java 以上超大文件上传和断点续传服务器的实现
    4GB以上超大文件上传和断点续传服务器的源码
    4GB以上超大文件上传和断点续传服务器的代码
    4GB以上超大文件上传和断点续传服务器的实现
    hdu 1013 Digital Roots
    hdu 1012 u Calculate e
    hdu 1011 树形dp
  • 原文地址:https://www.cnblogs.com/Galesaur-wcy/p/13225152.html
Copyright © 2020-2023  润新知