以太网诊断协议DoIP(Ethernet Diagnostic Protocol DoIP)

2023-10-18 10:13

本文主要是介绍以太网诊断协议DoIP(Ethernet Diagnostic Protocol DoIP),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

系列文章目录

C++技能系列
Linux通信架构系列
C++高性能优化编程系列
深入理解软件架构设计系列
高级C++并发线程编程
设计模式系列

期待你的关注哦!!!
在这里插入图片描述

现在的一切都是为将来的梦想编织翅膀,让梦想在现实中展翅高飞。
Now everything is for the future of dream weaving wings, let the dream fly in reality.

AutoSar CP学习概要

  • 系列文章目录
    • 1.1 诊断功能作用
    • 1.2 车辆诊断方法
    • 1.3 诊断功能发展历史
    • 1.4 车辆诊断功能协议
    • 1.5 诊断功能通信要素
    • 1.6 诊断功能通信流程
    • 1.7 DoIP协议
      • 1.7.1 DoIP应用场景:
      • 1.7.2 DoIP ISO:13400标准
      • 1.7.3 DoIP消息格式:
      • 1.7.4 DoIP通信流程
      • 1.7.5 DoIP网关功能

诊断无论是从主机厂还是供应商,无论是从上层设计还是从顶层设计来说,诊断都是必不可少的,比如CAN诊断、LIN诊断、以太网诊断。

无论研发还是售前、售后都是需要诊断的,比如ECU的升级和刷写、4S店的升级刷新、OTA升级等。

1.1 诊断功能作用

(1)识别、检查、确认车辆状态
(2)提供车辆维护、维修、更新数据

1.2 车辆诊断方法

(1)本地诊断(比如4S店人员用OBD读取ECU信息,升级刷写)
(2)远程诊断(比如通过云端远程诊断)
(3)仪表显示(比如车辆仪表盘指示灯的显示胎压不足)

1.3 诊断功能发展历史

时间协议描述
1996ISO9141-2CARB Requirements for Interchange of Infomation
1999ISO14230Keyword Protocol 2000
1999ISO/DIS15765Diagnostics on CAN - base on KWP2000
2001ISO15031Communication for emissions-related diagnostics
2001ISO15765Diagnostics on CAN - base on UDS
2006ISO14229Unified Diagnostics Services (UDS)
2013ISO14229Unified Diagnostics Services (UDS)

1.4 车辆诊断功能协议

UDS(Unified Diagnostic Services,统一的诊断服务)诊断协议是在汽车电子ECU环境下的一种诊断通讯协议。简单来说,可以理解为UDS诊断协议就是ISO 14229协议,在ISO 14229协议中定义了UDS服务用法、服务格式等信息。UDS诊断最主要目的是为了能够快速准确判断车辆或者某个控制器的故障以及故障原因,从而为维修提供可靠的依据。

UDS-ISO:14229标准

ISO14229Unified Diagnostics Services (UDS)
ISO14229_1Specification and requirements - 定义了诊断服务,只有应用层,不涉及网络及实现。
ISO14229_2Session layer services
ISO14229_3Unified Diagnostics Services on Can implementation(UDSSonCAN)- 定义了UDS在CAN总线上的实现
ISO14229_4Unified Diagnostics Services on FlexRay implementation(UDSSonFR)
ISO14229_5Unified Diagnostics Services on IP implementation(UDSonIP)
ISO14229_6UDS on K-Line implementation(UDSonk-Line)
ISO14229_7UDS on Local interconnect network(UDSonk-LIN)

诊断协议是用于汽车行业诊断通信的需求规范,由ISO-14229系列标准定义。应用于OSI七层模型的应用层(第7层),它只规定了与诊断相关的服务需求,并未涉及通信机制,所以,它可以在不同的汽车总线(例如CAN,LIN,FleXRAY,Ethernet和K-line)上实现。
在这里插入图片描述
在使用ISO-14229时,下面的通信机制可以改变,比如基于CAN,基于LAN,基于FlexRay等。诊断通信过程其实很简单,诊断仪发送诊断请求(request),ECU给出诊断响应(response),而UDS就是为不同诊断功能request和response定义统一的内容和格式。

1.5 诊断功能通信要素

  • 服务 Service
    UDS诊断包括6大类,26种服务,每种服务都有自己独立的ID,即SID(Service Identifier)
    在这里插入图片描述

  • 会话Session
    可以理解为某种诊断模式或权限,即在不同的模式下,对不同的诊断服务的使用做了限制。
    在这里插入图片描述

功能码说明
1Defaut Session
2Pograming
3Extended
  • 故障码DTC

1.6 诊断功能通信流程

其实诊断通信的机制很简单,事件驱动型,一问一答。

类比client-server通信方式,诊断仪即客户端,发送request,服务器即ECU,收到request之后进行处理,然后向诊断仪回复response。

  • 需要确认的服务
    在这里插入图片描述

  • 不需要确认的服务
    在这里插入图片描述

但是,诊断协议有自己的特色,它规定了request和response的格式,在收到request的时候要做格式检查。同时由于寻址方式的不同,有无sub-function的支持等,也会影响request和response的处理方式和结果。

1.7 DoIP协议

DoIP:Diagnositc communication over Internet Protocol

  • 一种用于UDS功能的以太网通信协议
  • ISO 13400

1.7.1 DoIP应用场景:

(1)本地一对一
(2)本地多对多
(3)远程一对多
(4)远程混合式

1.7.2 DoIP ISO:13400标准

标准:
ISO:13400_1:定义基本信息和用例
ISO:13400_2:网络层协议、传输层服务
ISO:13400_3:基于802.3,定义线序和接口
ISO:13400_4:定义诊断连接器
ISO:13400_5:一致性测试

1.7.3 DoIP消息格式:

DoIP报文由DoIP报头和Payload(有效载荷)组成,具体如下图所示。
在这里插入图片描述

  • (1)DoIP报头包含:DoIP协议版本号,目前为0x02(DoIP 2012)。
  • (2)协议版本号取反,目前为0xFD。注意:协议书上特别说明了Protocol version可以为0xFF,设这个值的作用是,当客户端和服务端的协议版本不匹配,可以设置此值绕过协议头版本不匹配而拒绝请求的case。
  • (3)Payload类型,分为3大类:
    ①节点管理类,包含DoIP报头否定应答、车辆声明及标识、路由激活、在线检查;
    ②车辆信息类,包含DoIP实体状态、诊断电源模式信息;
    ③诊断数据类,包含诊断报文。
    关于每个消息类型的含义如下表所示,具体含义参考标准即可。
    在这里插入图片描述

1.7.4 DoIP通信流程

在这里插入图片描述

DoIP通信的4个阶段
(1)物理连接:Tester使用有线或无线的方式与车辆建立连接
物理连接线图:
在这里插入图片描述

(2)IP地址分配:静态或动态的分配IP地址,使Tester和车辆可以进行网络通信

  • 静态分配:Tester与车辆连接前需配置完成(前期开发测试时可静态分配)
  • 动态分配:DHCP协议动态分配IP地址(推荐:外部设备作为服务器,车辆作为客户端发起请DHCP求)

(3)车辆发现:Tester识别并确认被诊断车辆

  • 查找识别车辆的过程
  • 标识符:车辆VIN、EID、GID等信息
    (4)诊断会话通信:Tester与车辆进行诊断功能通信
  • 建立TCP连接
  • 诊断功能通信
    在这里插入图片描述

1.7.5 DoIP网关功能

DoIP网关通信流程

这篇关于以太网诊断协议DoIP(Ethernet Diagnostic Protocol DoIP)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/231910

相关文章

Java如何接收并解析HL7协议数据

《Java如何接收并解析HL7协议数据》文章主要介绍了HL7协议及其在医疗行业中的应用,详细描述了如何配置环境、接收和解析数据,以及与前端进行交互的实现方法,文章还分享了使用7Edit工具进行调试的经... 目录一、前言二、正文1、环境配置2、数据接收:HL7Monitor3、数据解析:HL7Busines

【Linux】应用层http协议

一、HTTP协议 1.1 简要介绍一下HTTP        我们在网络的应用层中可以自己定义协议,但是,已经有大佬定义了一些现成的,非常好用的应用层协议,供我们直接使用,HTTP(超文本传输协议)就是其中之一。        在互联网世界中,HTTP(超文本传输协议)是一个至关重要的协议,他定义了客户端(如浏览器)与服务器之间如何进行通信,以交换或者传输超文本(比如HTML文档)。

配置InfiniBand (IB) 和 RDMA over Converged Ethernet (RoCE) 网络

配置InfiniBand (IB) 和 RDMA over Converged Ethernet (RoCE) 网络 服务器端配置 在服务器端,你需要确保安装了必要的驱动程序和软件包,并且正确配置了网络接口。 安装 OFED 首先,安装 Open Fabrics Enterprise Distribution (OFED),它包含了 InfiniBand 所需的驱动程序和库。 sudo

【Go】go连接clickhouse使用TCP协议

离开你是傻是对是错 是看破是软弱 这结果是爱是恨或者是什么 如果是种解脱 怎么会还有眷恋在我心窝 那么爱你为什么                      🎵 黄品源/莫文蔚《那么爱你为什么》 package mainimport ("context""fmt""log""time""github.com/ClickHouse/clickhouse-go/v2")func main(

JVM 常见异常及内存诊断

栈内存溢出 栈内存大小设置:-Xss size 默认除了window以外的所有操作系统默认情况大小为 1MB,window 的默认大小依赖于虚拟机内存。 栈帧过多导致栈内存溢出 下述示例代码,由于递归深度没有限制且没有设置出口,每次方法的调用都会产生一个栈帧导致了创建的栈帧过多,而导致内存溢出(StackOverflowError)。 示例代码: 运行结果: 栈帧过大导致栈内存

2024.9.8 TCP/IP协议学习笔记

1.所谓的层就是数据交换的深度,电脑点对点就是单层,物理层,加上集线器还是物理层,加上交换机就变成链路层了,有地址表,路由器就到了第三层网络层,每个端口都有一个mac地址 2.A 给 C 发数据包,怎么知道是否要通过路由器转发呢?答案:子网 3.将源 IP 与目的 IP 分别同这个子网掩码进行与运算****,相等则是在一个子网,不相等就是在不同子网 4.A 如何知道,哪个设备是路由器?答案:在 A

Modbus-RTU协议

一、协议概述 Modbus-RTU(Remote Terminal Unit)是一种基于主从架构的通信协议,采用二进制数据表示,消息中的每个8位字节含有两个4位十六进制字符。它主要通过RS-485、RS-232、RS-422等物理接口实现数据的传输,传输距离远、抗干扰能力强、通信效率高。 二、报文结构 一个标准的Modbus-RTU报文通常包含以下部分: 地址域:单个字节,表示从站设备

InfiniBand (IB) 和 RDMA over Converged Ethernet (RoCE)

在超算网络环境中,InfiniBand (IB) 和 RDMA over Converged Ethernet (RoCE) 是两种重要的网络技术,它们旨在提供高性能、低延迟的数据传输能力,适用于大规模并行计算任务。下面是对这两个技术的具体名词解释和应用场景的详细说明。 InfiniBand (IB) 名词解释 InfiniBand (IB):InfiniBand 是一种高性能计算和企业数据

网络原理之TCP协议(万字详解!!!)

目录 前言 TCP协议段格式 TCP协议相关特性 1.确认应答 2.超时重传 3.连接管理(三次握手、四次挥手) 三次握手(建立TCP连接) 四次挥手(断开连接)  4.滑动窗口 5.流量控制 6.拥塞控制 7.延迟应答 8.捎带应答  9.基于字节流 10.异常情况的处理 小结  前言 在前面,我们已经讲解了有关UDP协议的相关知识,但是在传输层,还有

DNS协议基础笔记

1.定义 DNS(Domain Name System,域名系统)是互联网的一项核心服务,它作为将域名和 IP 地址相互映射的一个分布式数据库,能够使人更方便地访问互联网。 2.域名解析过程 当用户在浏览器中输入一个域名,浏览器首先会检查自己的缓存中是否有该域名对应的 IP 地址。本地 DNS 服务器收到查询请求后,首先会检查自己的缓存中是否有该域名对应的 IP 地址。根域名服务器收到查询请