前言

由于工作中经常用到ISO-14229,因此决定对该协议做个总体介绍和总结,既是对自己学习的总结,也能够给初次涉及该协议的朋友一个参考。

首先简要介绍什么是ISO-14229,至于可以在网上找到的大篇理论介绍我就略过不讲了,有兴趣可以自行搜索。简单的说,它就是一个用于汽车行业诊断通信的需求规范,它只规定了与诊断相关的服务需求,并没有涉及通信机制,因此要实现一个完整的诊断通信还需要定义网络层协议(比如ISO-15765),还有底层硬件实现方式(比如CAN控制器)。由于不涉及网络通信机制,可以架设在各种网络之上,因此ISO-14229也称为UDS(Unified Diagnostic Services)。

1. 用途

ISO-14229的用途就是规定了诊断需求,因此想要了解ISO-14229的用途首先要知道诊断的用途。诊断最先用于汽车尾气排放的监测,后来发展为包括对汽车行驶故障的监测,想知道诊断的发展史,可以维基百科。至少现代的诊断可以粗略的分为排放相关和非排放相关,ISO-14229只定义非排放相关的诊断需求。非排放相关诊断可以做什么呢?其实用途很大,基本贯穿整个汽车ECU生命周期。首先,ECU开发时要用到它来构建bootloader,上传和下载数据;测试时要用它来读写RAM、ROM,控制外设;在产线上,要用它来校准机械件,刷新软件;在行驶过程中,要用它来监测各种故障,并记下故障码;在4S店,技师需要用它来读出故障码,判断故障发生点,还可以用来升级ECU程序。现在大热的车联网概念,其中一些就是通过OBD口联网,读取车内故障码,或者油量、速度等参数。

2. 诊断通信分层结构

虽然借鉴OSI的七层结构,但是诊断通信分层还是做了一些改变。可以参考如下列表:

OSI Layer

Enhanced Diagnostic Services

Application (layer 7)

ISO 14229

Presentation (layer 6)

-

Session (layer 5)

ISO 15765-3

Transport (layer 4)

ISO 15765-2

Network (layer 3)

ISO 15765-2

Data link (layer 2)

ISO 11898

Physical (layer 1)

ISO 11898

显然,从上表可以看出诊断通信分层模型和OSI的区别,同时也可以看到ISO-14229在该模型中的位置。其实,可以将该模型简化为:
- 统一诊断服务层 (layer 7)

- 网络服务层 (layers 1 to 6)

因此,在使用ISO-14229时,下面的通信机制可以改变,比如基于CAN,基于蓝牙,基于LAN,基于FlexRay等等。

3. 相关术语

3.1 协议相关术语

要了解协议,首先要知晓协议内定义的术语。我挑了一些使用频率比较高的在此解释。

1. Diagnostic Service (诊断服务)

诊断服务是介于诊断设备和被诊断ECU之间的一种信息交互方式。通常是由诊断设备发出请求,被诊断ECU做出回应。

2. Diagnostic Trouble Code (故障码)

故障码是用来标记ECU故障的代码,它遵循一定的规则(以后会介绍),驻留在ECU的非易失性存储器中。

3. Diagnostic Data (诊断数据)

诊断数据是可以被诊断设备请求的ECU内部数据,它包括:

-当前数据,即ECU正在使用的某个数据,比如车速、节气门角度等

-存储数据,即被ECU存储在存储器中某一时刻的数据,比如DTC

-静态数据,即恒定不变的ECU内部数据,比如VIN码。

4. Diagnostic Session (诊断会话)

可以理解为某种诊断模式或权限,即在不同的模式下,对不同的诊断服务的使用做了限制。

5. Diagnostic Routine (诊断例程)

驻留在被诊断ECU中的子程序,它可以被诊断设备启动和停止。比如格式化EEPROM的子程序。

6. Tester, 就理解为诊断设备或诊断仪吧。

3.2 诊断服务相关术语

再来说一些跟诊断服务相关的术语。

1 Addressing Type (寻址方式)

寻址方式指的是诊断消息的传递方式,有两种寻址方式:

-Physical ,物理寻址,即1对1通信,用于知道确切的被诊断ECU的地址

-Functional,功能寻址,即1对n通信,或者说广播发送,用于不知道确切的被诊断的ECU的地址,向一组或者全体ECU发送请求

2 Result

Result指的是tester请求诊断服务执行后,从ECU的返回结果。可以有两种结果:

-Positive Response,正响应,即诊断请求执行成功

-Negative Response,负响应,即诊断请求执行失败

3 Service Identifier

Service Identifier可以简称为SID,它是一个一字节的无符号整数,用以指代某个诊断服务。诊断协议为每一个诊断服务都分配了唯一一个SID,因此更方便协议的软件实现。同时,在日常工作中工程师们用SID来指代某个诊断服务比说出某个服务的名字更方便简洁。比如ReadDataByIdentifier这个服务是去按照ID去读某个诊断数据,直接说22服务会更加方便。

4 Data Identifier

简称DID,是2个字节无符号整数的ID,用来标识ECU中贮存的某个诊断数据单元。它的好处是当要读取某个单元的诊断数据时,只要读对应的DID就可以,不必知道数据的具体地址。即使当ECU中的数据地址发生变化时,只要DID和某个地址单元的映射地址改变即可,对于使用者来说DID屏蔽了具体实现细节,而将重点放在了数据本身。

5 Negative Response Code

可以简称为NRC,或者叫错误响应码,是一个字节的无符号整数。它是诊断协议为每一种执行失败的诊断服务分配的失败原因代号。

6 Sub-function

有些诊断服务可以支持不同的诊断子服务,sub-function就是用来定义这种子服务的,它将某一个服务细分为更为具体的服务,它是一个字节的无符号整数。比如ECUReset这个服务就有0x01,0x02,0x03等几种sub-function指代具体的reset方式。

UDS学习之:ISO-14229 简介相关推荐

  1. 【图解UDS】UDS汽车诊断标准协议(ISO 14229)带你入门到精通

                                      [图解UDS]UDS汽车诊断标准协议(ISO 14229)带你入门到精通 目录 为了便于学习ISO 14229 UDS诊断协议,提供 ...

  2. 怎样学习ISO 14229和ISO 15765?

    一.ISO 14229 UDS协议就是ISO14229,你需要做的就是了解并牢固掌握ISO14229中的内容,但是14229里的内容实在是太多了,还没开始看就头疼了.从作者的学习经历来看,如果从头开始 ...

  3. Docker学习一:Docker简介与安装

    前言 本次学习来自于datawhale组队学习: 教程地址为: https://github.com/datawhalechina/team-learning-program/tree/master/ ...

  4. ISO 14229、ISO 15765、ISO 11898的区别

    文章目录 前言 ISO 11898 ISO 14229 ISO 15765 ISO 26262 ISO 27145-4 前言 最近在做车载诊断相关的工作,对于ISO 14229一点都不熟悉,开发起来进 ...

  5. ASAM XCP及驱动代码、ISO 11898+CANFD,ISO 14229,ISO 15031,ISO 15765相关标准文档

    ASAM XCP及驱动代码.ISO 11898+CANFD.ISO 14229,ISO 15031,ISO 15765文档(选中对应名称,跳转至相应的文档): 一.ISO_11898 Part1_2_ ...

  6. 【小猫爪】AUTOSAR学习笔记02-Communication Stack简介

    [小猫爪]AUTOSAR学习笔记02-Communication Stack简介 前言 1 简介 2 CAN消息的传播路径 2.1 Com服务 2.2 Dcm服务 2.3 SM服务和NM服务 3 补充 ...

  7. 【小猫爪】AUTOSAR学习笔记01-AUTOSAR架构简介

    [小猫爪]AUTOSAR学习笔记01-AUTOSAR架构简介 前言 1 背景介绍 2 基本概念 3 方法论 4 分层软件架构 4.1 Application Layer(APP) 4.2 Basic ...

  8. StatQuest学习笔记23——RNA-seq简介

    StatQuest学习笔记23--RNA-seq简介 前言--主要内容 这篇笔记是StatQuest系列笔记的第58节,主要内容是讲RNA-seq的原理.StatQuest系列教程的58到62节是协录 ...

  9. UA MATH574M 统计学习V Variable Selection简介

    UA MATH574M 统计学习V Variable Selection简介 两个基础方法 Ranking Variables Best Subset Algorithm 对基础方法的改进 Gener ...

最新文章

  1. 黑马lavarel教程---11、响应处理
  2. Python 字典初始化dict()和{}
  3. python switch_从邮箱验证小项目说python字符串判断与if判断那些事儿
  4. 驳《IT开发工程师的悲哀》
  5. list去除重复值的方法(面试高频)
  6. zookeeper版本更新_很遗憾,没有一篇文章能讲清楚ZooKeeper
  7. 做一枚精致的程序猿,Fighting!
  8. 【渝粤教育】国家开放大学2018年秋季 0222-21T模拟电子电路 参考试题
  9. java 解析栅格数据_使用Rasterio读取栅格数据的实例讲解
  10. jQuery EasyUI简明教程
  11. 小鹏汽车面试经验分享
  12. javaweb学习路线
  13. 2020-08-18
  14. DICOMRT:XXX Target Volume,各种目标体积浅析
  15. dingo php,laravel 中安装 Dingo API 基本设置
  16. 蕉下招股书里提了26次的DTC,到底是啥?
  17. 将电脑多余空间分给其他盘
  18. MRS离线数据分析:通过Flink作业处理OBS数据
  19. ei eo 功能类型_[转载]CMMI之功能点估算法:EI、EQ和EO
  20. 概率统计:概率与统计的关系

热门文章

  1. ntp协议客户端服务器模式,思科配置NTP客户端服务器模式
  2. 合并两个有序表--顺序表
  3. 新员工第一阶段工作总结
  4. 一杯奶茶的数字化之路
  5. 2014,说说这个燥热的暑假
  6. 绕过WAF运行命令执行漏洞的方法大全
  7. 01 Android 植物人大战僵尸-画个方块
  8. C语言例程:投资问题 单利和复利
  9. 现场直击|ChinaJoy2018,最大惊喜竟然不是游戏
  10. python 读取配置文件,报错configparser.NoSectionError: No section 解决方案