0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

基于ODX诊断测试开发(1):ODX数据库剖析

北汇信息POLELINK 2022-07-27 15:28 次阅读

1.ODX简介

由ASAM组织提出的诊断数据交互格式,全称为Open Diagnostic Data Exchange,包含ODX2.0.1和ODX2.2.0规范,两个版本之间不兼容。ISO收录了其中ASAM ODX2.2.0规范,即ODX规范ISO-22901,主要用于描述整车以及ECU的诊断数据,方便供应商与OEM、产品开发与售后间的数据交互。ODX使用统一建模语言(UML)图描述,数据交互格式使用可扩展标记语言(XML)存储记录数据。便于承载从设计、开发、测试、生产及售后维护的全流程工作。

2.ODX文件类型

ODX2.2.0(ISO-22901)将ODX文件分为如下类型:

  • odx-c/-cs:通讯参数,如会话层、传输层时间参数以及逻辑地址等通讯相关信息
  • odx-d:ECU诊断层规范(包含ECU所有诊断服务以及诊断使用的数据)
  • odx-v:车辆信息(-v文件可以包含整车所有控制器拓扑结构,诊断仪可以通过logic link选择需要诊断的ECU)
  • odx-e:ECU配置(产线ECU配置信息)
  • odx-f:ECU编程数据(ECU刷写相关数据,如checksum和签名信息等)
  • odx-fd:功能字典(车辆功能信息库,如中控锁功能包含四个车门功能信息)
  • odx-m:多ECU功能规范(定义了同时和多个ECU进行通讯的方法)

2.1.PDX文件

PDX文件可作为各类型ODX文件的容器,将相关ODX文件打包为PDX文件(.pdx),并且作为输入物导入诊断工具。

2.2.ODX包目录文件index.xml

ODX包目录由一个CATALOG实例表示,它提供了存储在相应PDX包中的所有文件的列表。

元素“FILE”的内容代表PDX中包含的文件,

元素“CATEGORY”内容如下:

  • ODX-DATA:适用于所有ODX文件
  • ODX-JOB:适用于java-files,class-files,jar-files,dll-files
  • LIB:所有被JOB使用或导入的文件
  • PROGRAMMING-DATA:用于控制器编程的bin/hex文件

pYYBAGLg3QuAGr8GAAJT-uLYGpM105.png

2.3.车辆信息odx-v

odx-v文件主要作为诊断仪访问ECU的入口,包含两个重要元素:

  • Info-Component(该元素包含OEM、Vehicle-Model、Model-year、Vehicle-Type等)。
  • Vehicle-Information(该元素包含Vehicle-Connector、Physical-Vehicle-Link、Logical-Link等),诊断仪可以使用Logic-Link信息在PDX包中寻找包含目标ECU的Base-Variant文件,然后诊断仪就可以与ECU通讯了,当然也要确认ECU的变体信息ECU-Variant。

pYYBAGLg3SCAYV_3AAFx_hhldvE532.png

pYYBAGLg3S2AIlxnAADauKlPwaI199.png

2.4.通信参数odx-c/odx-cs

odx-c描述应用层、传输层、物理层适用的是哪版规范(如CAN总线对应的规范分别是14229、15765、11898),其中应用层(如P2、P2*等)、传输层(As、Bs、Br、Cs、Cr、STMin等)、物理层(ID等)分别对应一个odx-cs文件。

poYBAGLg3T-AQ16DAABoyxIl2CE514.png

2.4.1.通信参数规范引用

poYBAGLg3WSAH0OEAAEswHM2mu0401.png

2.4.2.通信参数规范定义应用层、传输层、物理层适用的规范

pYYBAGLg3XSALxHHAAFF7Ci_Too795.png

2.4.3.传输层参数定义

pYYBAGLg3YKAcgPUAAF2uueeUK0261.png

为了减少数据冗余,odx-c/cs参数为默认值,对于ECU差异性数据可以用元素SIMPLE-VALUE对应用的通信参数重新赋值。

poYBAGLg3Y-AEtUbAAEbYlPtbbc417.png

2.5.诊断层odx-d

odx-d文件包含控制器的所有诊断数据,如服务、DTC、DID、RID、数据类型等信息,odx-d元素分类如下:

poYBAGLg3Z-ADjclAACI7Sh7CGc970.png

  • PROTOCOL:定义了某种诊断层协议(如UDS/OBD)
  • FUNCTIONAL_GROUP:定义了多个ECU共同支持的服务或数据
  • BASE-VARIANT:代表一个具体ECU,每个ECU只有一个BASE-VARIANT,它继承PROTOCOL和FUNCTIONAL-GROUP,可以对上面两层的诊断服务与数据进行引用,也可以对继承的服务和数据进行修改
  • ECU_VARIANT:各个ECU的具体实现,如BCM有多种配置,不同配置的BCM数据也存在差异
  • ECU-SHARED-DATA:是一个数据库,由上述4层对其进行引用

2.5.1.层级继承关系

odx支持值继承,相较于其他数据库ODX文件更加灵活,各层级间继承关系如下:

pYYBAGLg3bKASz9AAAC4jnrxLfU620.png

  • ECU-SHARED-DATA可被其它层继承,但不能继承其它层;
  • PROTOCOL可继承ECU-SHARED-DATA;
  • FUNCTIONAL-GROUP可继承PROTOCOL和ECU-SHARED-DATA;
  • BASE-VARIANT可继承 FUNCTIONAL-GROUP、ECU-SHARED-DATA、PROTOCOL;
  • ECU-VARIANT可继承ECU-SHARED-DATA、BASE-VARIANT。

2.5.2.层级继承关系示例

pYYBAGLg3c6AGgFmAAEZ6MH_Q0w400.png

pYYBAGLg3diAX4TkAAEzhcY-fOI384.png

2.5.3.UDS请求报文示例

pYYBAGLg3emAH3UpAAETT22CixU363.png

引用“DLC.UDS.ESD.Generic_UDS_Services.RQ.Req_Tester_Present”。

pYYBAGLg3fmAKPHGAAE50DC99P4997.png

2.5.4.UDS肯定应答报文示例

pYYBAGLg3haAXwzfAAEGjVqtSSs330.png

引用“DLC.UDS.ESD.Generic_UDS_Services.PR.Pos_Resp_Tester_Present”。

pYYBAGLg3puAaEI6AAFIUuZbfVg073.png

2.5.5.UDS否定应答示例

poYBAGLg3q6AY5L9AAErcp5JRhs189.png

引用“DLC.UDS.ESD.Generic_UDS_Services.DOP.ISO_NRC_definition”。

poYBAGLg3ryAQExVAAEqDzwMDGk540.png

引用“DLC.UDS.ESD.Generic_UDS_Services.DOP.NRC_10”。

poYBAGLg3seAMvUwAADDK-FNApw023.png

3.总结

ISO-22901是标准的ODX规范,各个OEM会按照自己的需求编写企业级的AGL(Authoring Guide Line)文件,用于定义ODX文件结构,便于诊断数据工程师开发、维护ODX文件,所以AGL文件对ODX数据解析起着指导性作用。

北汇信息专注于汽车电子测试、与众多OEM合作,在总线网络诊断测试开发相关领域积累了丰富的经验。本篇文章简单介绍了ODX数据结构,ODX协议规则还有很多,限于篇幅,不做一一介绍了,下篇系列文章将分享为了实现诊断相关的测试,ODX数据解析的过程和方法,敬请持续关注。

参考文献

[1]ISO 22901-1

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
收藏 人收藏

    评论

    相关推荐

    数据库数据恢复—Mysql数据库表记录丢失的数据恢复流程

    Mysql数据库故障: Mysql数据库表记录丢失。 Mysql数据库故障表现: 1、Mysql数据库表中无任何
    的头像 发表于 12-16 11:05 146次阅读
    <b class='flag-5'>数据库</b><b class='flag-5'>数据</b>恢复—Mysql<b class='flag-5'>数据库</b>表记录丢失的<b class='flag-5'>数据</b>恢复流程

    数据库数据恢复—MYSQL数据库ibdata1文件损坏的数据恢复案例

    mysql数据库故障: mysql数据库文件ibdata1、MYI、MYD损坏。 故障表现:1数据库无法进行查询等操作;2、使用my
    的头像 发表于 12-09 11:05 152次阅读

    数据库数据恢复—通过拼接数据库碎片恢复SQLserver数据库

    一个运行在存储上的SQLServer数据库,有1000多个文件,大小几十TB。数据库每10天生成一个NDF文件,每个NDF几百GB大小。数据库包含两个LDF文件。 存储损坏,数据库
    的头像 发表于 10-31 13:21 216次阅读
    <b class='flag-5'>数据库</b><b class='flag-5'>数据</b>恢复—通过拼接<b class='flag-5'>数据库</b>碎片恢复SQLserver<b class='flag-5'>数据库</b>

    在嵌入式开发领域,有哪些好用的国产工具?

    商:经纬恒润 功能:将Excel格式的诊断调查问卷转换为标准ODX格式文件,生成的ODX文件兼容市面上主流的诊断测试开发商的软件产品。 特
    的头像 发表于 10-23 09:21 210次阅读

    Oracle数据恢复—异常断电后Oracle数据库报错的数据恢复案例

    Oracle数据库故障: 机房异常断电后,Oracle数据库报错:“system01.dbf需要更多的恢复来保持一致性,数据库无法打开”。数据
    的头像 发表于 09-30 13:31 304次阅读
    Oracle<b class='flag-5'>数据</b>恢复—异常断电后Oracle<b class='flag-5'>数据库</b>启<b class='flag-5'>库</b>报错的<b class='flag-5'>数据</b>恢复案例

    数据库数据恢复—SQL Server数据库出现823错误的数据恢复案例

    SQL Server数据库故障: SQL Server附加数据库出现错误823,附加数据库失败。数据库没有备份,无法通过备份恢复数据库
    的头像 发表于 09-20 11:46 349次阅读
    <b class='flag-5'>数据库</b><b class='flag-5'>数据</b>恢复—SQL Server<b class='flag-5'>数据库</b>出现823错误的<b class='flag-5'>数据</b>恢复案例

    恒讯科技分析:sql数据库怎么用?

    SQL数据库的使用通常包括以下几个基本步骤: 1、选择数据库系统: 选择适合您需求的SQL数据库系统,如MySQL、PostgreSQL、Microsoft SQL Server、SQ
    的头像 发表于 07-15 14:40 358次阅读

    ODX Factory System,汽车诊断工程师的利器! #汽车电子测试 #ODX #PDX

    汽车电子
    jf_93524069
    发布于 :2024年07月01日 19:44:41

    数据库数据恢复—数据库所在分区空间不足导致sqlserver故障的数据恢复案例

    数据库数据恢复环境: 某品牌r520服务器,服务器中有7块SAS硬盘,这7块硬盘组建了一组2盘raid1阵列和一组5盘raid5阵列,raid1阵列存储空间安装操作系统,raid5阵
    的头像 发表于 05-22 13:16 460次阅读
    <b class='flag-5'>数据库</b><b class='flag-5'>数据</b>恢复—<b class='flag-5'>数据库</b>所在分区空间不足导致sqlserver故障的<b class='flag-5'>数据</b>恢复案例

    HarmonyOS开发案例:【搭建关系型数据库】(4)

    本节将介绍如何调用关系型数据库接口在本地搭建数据库,并读写相应的用户数据
    的头像 发表于 05-11 10:27 902次阅读
    HarmonyOS<b class='flag-5'>开发</b>案例:【搭建关系型<b class='flag-5'>数据库</b>】(4)

    数据库数据恢复—raid5阵列上层Sql Server数据库数据恢复案例

    数据库数据恢复环境: 5块硬盘组建一组RAID5阵列,划分LUN供windows系统服务器使用。windows系统服务器内运行了Sql Server数据库,存储空间在操作系统层面划分了三个逻辑分区
    的头像 发表于 05-08 11:43 511次阅读
    <b class='flag-5'>数据库</b><b class='flag-5'>数据</b>恢复—raid5阵列上层Sql Server<b class='flag-5'>数据库</b><b class='flag-5'>数据</b>恢复案例

    如何从0到1设计诊断系统

    诊断系统设计主要涵盖了诊断方案设计、诊断需求定义和诊断数据库开发。本文会逐一介绍这些环节,以便更
    的头像 发表于 04-26 17:59 1162次阅读
    如何从0到<b class='flag-5'>1</b>设计<b class='flag-5'>诊断</b>系统

    通过Modbus读写数据库中的数据

    用Modbus poll测试了,以下是智能网关的网络参数和测试截图: 通过智能网关的串口同样可以读写数据库。IGT-SER系列智能网关也支持作为Mobus主站,读取Modbus从站/服务端的
    发表于 03-14 13:44

    数据库数据恢复】Oracle数据库ASM实例无法挂载的数据恢复案例

    oracle数据库ASM磁盘组掉线,ASM实例不能挂载。数据库管理员尝试修复数据库,但是没有成功。
    的头像 发表于 02-01 17:39 524次阅读
    【<b class='flag-5'>数据库</b><b class='flag-5'>数据</b>恢复】Oracle<b class='flag-5'>数据库</b>ASM实例无法挂载的<b class='flag-5'>数据</b>恢复案例

    IZYTRONIQ测试软件介绍——管理测试设备数据库

    一款完整的用于管理和记录测试过程的数据库软件IZYTRONIQ
    的头像 发表于 01-11 11:11 412次阅读
    IZYTRONIQ<b class='flag-5'>测试</b>软件介绍——管理<b class='flag-5'>测试</b>设备<b class='flag-5'>数据库</b>