【ISO14229_UDS_0x37服务详解】

1、0x37服务(RequestTransferExit,请求传输退出服务)

  Service description:
  0x37服务(RequestTransferExit,请求传输退出服务)被客户端用于终止在客户端和服务端间的数据传输。

2、请求报文格式

2.1 请求报文定义

  下表定义了请求报文的格式:

字节序号参数值约定字节值
#1RequestTransferExit Request SIDM0x37

#2
.
.
#n
transferRequestParameterRecord[] = [
               transferRequestParameter#1
               .
               .
               transferRequestParameter#m ]

U
.
.
U

0x00 - 0xFF
.
.
0x00 - 0xFF

2.2 请求报文中子函数参数定义

  该服务未使用子函数参数。

2.3 请求报文中数据参数定义

  该服务在请求报文中的数据参数定义如下表所示:

定义
transferRequestParameterRecord
此参数记录包含了服务端所需要的,用来支持数据传输的参数。这个参数的格式和长度都是汽车制造厂商指定的。

3、肯定应答报文

3.1 肯定应答报文格式定义

字节序号参数值约定字节值
#1RequestTransferExit Response SIDM0x77

#2
.
.
#n
transferResponseParameterRecord[] = [
        transferResponseParameter#1
        .
        .
        transferResponseParameter#m ]

U
.
.
U

0x00 - 0xFF
.
.
0x00 - 0xFF

3.2 肯定应答报文数据参数定义

  该服务肯定应答报文中使用到的数据参数的定义见下表:

定义
transferResponseParameterRecord
此参数记录包含了服务端所需要的,用来支持数据传输的参数。这个参数的格式和长度都是汽车制造厂商指定的。

4、支持的否定应答码(NRC_)

  本服务实施了如下否定响应代码,下表记录了每个否定应答码发生的情况,如果服务端在错误场景使用了该服务,则应使用如下列出的否定响应码。

NRC描述
0x13incorrectMessageLengthOrInvalidFormat
请求报文长度不正确时,会发送该NRC。
0x24requestSequenceError
以下情况发生会则会使用该否定应答码:
— 该服务的请求接收时,刷新程序没有完成;
— RequestDownload和RequestUpload服务没有被激活。
0x31requestOutOfRange
transferRequestParameterRecord参数中包含了无效的数据,会发送该NRC。
0x72generalProgrammingFailure
当结束客户端与服务端的数据传输时(比如,完整性校验),如果服务端检测到错误发生,会发送该NRC。

  0x37服务(RequestTransferExit,请求传输退出服务)的否定应答码(NRC)具体处理过程如下。
在这里插入图片描述

5、0x37服务(RequestTransferExit,请求传输退出服务)案例说明

5.1 下载数据到服务端,Download data to a server

  Assumptions:
  以下案例为客户端到服务端的数据传输,即下载。该案例包含了3步。
  第一步客户端和服务端执行RequestDownload服务,接着在客户端和服务端中的请求和肯定应答报文中有如下信息作为参数被交换。
  下表定义了 transferRequestParameter 的值。

Data Parameter NameData Parameter ValuesData Parameter Description
MemorySize (3 bytes)0x602000下载数据的起始内存地址(memoryAddress)
dataFormatIdentifier0x11dataFormatIdentifier:
— compressionMethod = 0x1X
— compressionMethod = 0xX1
MemorySize (3 bytes)0x00FFFFMemorySize = (65 535 bytes)
在requestTransferExit服务执行过程中,该参数值被服务端用于比较传输数据的实际字节数。

  下表定义了 transferResponseParameter 的值。

Data Parameter NameData Parameter ValuesData Parameter Description
maximumNumberOfBlockLength0x0081maximumNumberOfBlockLength:
(serviceId + BlockSequenceCounter (1 byte) + 127 server data bytes = 129 data bytes)

  第二步客户端传输65535字节的数据到闪存中,从服务端内存地址为0x602000起始处开始。
  第三步客户端使用 requestTransferExit 服务终止传输数据到服务端中。
  Test conditions:ignition = on,engine = off,vehicle speed = 0 [kph]。
  该案例中,有这样的假设:服务端支持3个字节的memoryAddress 和 3个字节的MemorySize。如果MemorySize包含的是未被压缩的数据的大小,带有127个字节的数据的 TransferData 服务的数量无法被计算,因为压缩方法和压缩比是不标准的。如果MemorySize包含的是被压缩数据的大小,在单个TransferData请求之后,带有127个字节的数据的 TransferData 服务的总数将会是516个。因此,最后一个TransferData 请求报文包含的 blockSequenceCounter 的值等于0x05。
  Step1:Request for download
下表定义了 RequestDownload 服务请求报文的案例,报文从客户端到服务端:

字节序号描述字节的值
#1RequestDownload Request SID0x34
#2dataFormatIdentifier0x11
#3addressAndLengthFormatIdentifier0x33
#4
#5
#6
memoryAddress [ byte#1 ] (MSB)
memoryAddress [ byte#2 ]
memoryAddress [ byte#3 ] (LSB)
0x60
0x20
0x00
#7
#8
#9
MemorySize [ byte#1 ] (MSB)
MemorySize [ byte#2 ]
MemorySize [ byte#3 ] (LSB)
0x00
0xFF
0xFF

下表定义了 RequestDownload 肯定应答报文的案例,报文从服务端到客户端:

字节序号描述字节的值
#1RequestDownload Response SID0x74
#2LengthFormatIdentifier0x20
#3
#4
maxNumberOfBlockLength [ byte#1 ] (MSB)
maxNumberOfBlockLength [ byte#2 ] (LSB)
0x00
0x81

  Step2:Transfer data
下表定义了 TransferData 服务请求报文的案例,报文从客户端到服务端:

字节序号描述字节的值
#1TransferData Request SID0x36
#2blockSequenceCounter0x01
#3
.
.
#129
transferRequestParameterRecord [ transferRequestParameter#1 ] = dataByte#3
.
.
transferRequestParameterRecord [ transferRequestParameter#127 ] = dataByte#129
0xXX
.
.
0xXX

下表定义了 TransferData 肯定应答报文的案例,报文从服务端到客户端:

字节序号描述字节的值
#1TransferData Response SID0x76
#2blockSequenceCounter0x01

在这里插入图片描述

字节序号描述字节的值
#1TransferData Request SID0x36
#2blockSequenceCounter0x05
#3
.
.
#n+2
transferRequestParameterRecord [ transferRequestParameter#1 ] = dataByte#3
.
.
transferRequestParameterRecord [ transferRequestParameter#n-2 ] = dataByte#n
0xXX
.
.
0xXX

下表定义了 TransferData 肯定应答报文的案例,报文从服务端到客户端:

字节序号描述字节的值
#1TransferData Response SID0x76
#2blockSequenceCounter0x05

  Step3:Request Transfer exit
下表定义了 RequestTransferExit 服务请求报文的案例,报文从客户端到服务端:

字节序号描述字节的值
#1RequestTransferExit Request SID0x37

下表定义了 RequestTransferExit 服务肯定应答报文的案例,报文从服务端到客户端:

字节序号描述字节的值
#1RequestTransferExit Response SID0x77

5.2 从服务端上传数据,Upload data from a server

  以下案例为服务端到客户端的数据传输,即上传。该案例包含了3步。
  第一步客户端和服务端执行 requestUpload 服务,接着在客户端和服务端中的请求和肯定应答报文中有如下信息作为参数被交换。
  下表定义了 transferRequestParameter 的值。

Data Parameter NameData Parameter ValuesData Parameter Description
MemorySize (3 bytes)0x201000上传数据的起始内存地址(memoryAddress)
dataFormatIdentifier0x11dataFormatIdentifier:
— compressionMethod = 0x1X
— compressionMethod = 0xX1
MemorySize (3 bytes)0x0001FFMemorySize = (511 bytes)
在执行requestTransferExit服务过程中,该参数显示了有多少数据字节会被传输,会被服务端用于比较传输数据的实际字节数。

  下表定义了 transferResponseParameter 的值。

Data Parameter NameData Parameter ValuesData Parameter Description
maximumNumberOfBlockLength0x0081maximumNumberOfBlockLength:
(serviceId + BlockSequenceCounter (1 byte) + 127 server data bytes = 129 data bytes)

  第二步服务端将会从外部RAM中内存地址为0x201000的位置处,传输 511 字节的数据,其中包含4个带有129个字节数据的transferData服务(1个字节的服务ID + 1个字节的 blockSequenceCounter + 127个字节的服务端数据) 和 1个带有5个字节数据的transferData服务(1个字节的服务ID + 1个字节的 blockSequenceCounter + 3个字节的服务端数据)。
  第三步客户端使用 requestTransferExit 服务终止传输数据到服务端中。
  Test conditions:ignition = on,engine = off,vehicle speed = 0 [kph]。
  该案例中,有这样的假设:服务端支持3个字节的memoryAddress 和 3个字节的MemorySize。而且假设服务端支持在0x36服务TransferData的blockSequenceCounter。
  Step1:Request for upload
下表定义了 RequestUpload 服务的请求报文案例,报文从客户端到服务端:

字节序号描述字节的值
#1RequestUpload Request SID0x35
#2dataFormatIdentifier0x11
#3addressAndLengthFormatIdentifier0x33
#4
#5
#6
memoryAddress [ byte#1 ] (MSB)
memoryAddress [ byte#2 ]
memoryAddress [ byte#3 ] (LSB)
0x20
0x10
0x00
#7
#8
#9
MemorySize [ byte#1 ] (MSB)
MemorySize [ byte#2 ]
MemorySize [ byte#3 ] (LSB)
0x00
0x01
0xFF

下表定义了 RequestUpload 肯定应答报文的案例,报文从服务端到客户端:

字节序号描述字节的值
#1RequestUpload Response SID0x75
#2LengthFormatIdentifier0x20
#3
#4
maxNumberOfBlockLength [ byte#1 ] (MSB)
maxNumberOfBlockLength [ byte#2 ] (LSB)
0x00
0x81

  Step2:Transfer data
下表定义了 TransferData 服务请求报文的案例,报文从客户端到服务端:

字节序号描述字节的值
#1TransferData Request SID0x36
#2blockSequenceCounter0x01

下表定义了 TransferData 肯定应答报文的案例,报文从服务端到客户端:

字节序号描述字节的值
#1TransferData Response SID0x76
#2blockSequenceCounter0x01
#3
.
.
#129
transferResponseParameterRecord [ transferResponseParameter#1 ] = dataByte#3
.
.
transferResponseParameterRecord [ transferResponseParameter#127 ] = dataByte#129
0xXX
.
.
0xXX

在这里插入图片描述

字节序号描述字节的值
#1TransferData Request SID0x36
#2blockSequenceCounter0x05

下表定义了 TransferData 肯定应答报文的案例,报文从服务端到客户端:

字节序号描述字节的值
#1TransferData Response SID0x76
#2blockSequenceCounter0x05
#3
.
.
#5
transferResponseParameterRecord [ transferResponseParameter#1 ] = dataByte#3
.
.
transferResponseParameterRecord [ transferResponseParameter#3 ] = dataByte#5
0xXX
.
.
0xXX

  Step3:Request Transfer exit
下表定义了 RequestTransferExit 服务请求报文的案例,报文从客户端到服务端:

字节序号描述字节的值
#1RequestTransferExit Request SID0x37

下表定义了 RequestTransferExit 服务肯定应答报文的案例,报文从服务端到客户端:

字节序号描述字节的值
#1RequestTransferExit Response SID0x77

返回UDS诊断服务功能单元介绍目录

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: iso-14229是一项用于汽车电子系统通信的协议,其全称为ISO14229 Unified Diagnostic Services(UDS)on Controller Area Network(CAN)。该协议旨在为车辆的诊断、维护和修复提供标准化的方法。ISO 14229定义了诊断服务和通信的标准化消息格式,包括诊断数据、错误码、故障清除等,以使不同车辆的系统实现得到统一和互操作性。 ISO14229 UDS协议栈是用于实现ISO 14229诊断协议的软件组件。该协议栈的实现可分为物理层和软件层两个部分,其中物理层是指使用CAN总线对车辆的执行单元进行通信,而软件层则是指实现ISO 14229标准的协议堆栈。该协议栈具有标准化、可重用和可配置的特点,可在不同的客户平台上使用。 ISO 14229的文档是对该协议的规范和说明,包括协议的基本架构、消息格式、错误码表、会话层和传输层的细节等。该文档是实现ISO 14229协议的必要依据,可用于开发UDS协议栈的开发人员和车辆诊断工程师。 源码.zip则是UDS协议栈的实现源代码,包括物理层和软件层代码。开发人员可根据该源码了解UDS协议栈的实现细节和技术实现,并根据需求进行二次开发。 综上所述,ISO-14229_14229_UDS协议栈_UDS-ISO-14229_ISO14229文档_ISO 14229_源码.zip等组件,是用于实现汽车电子系统诊断的标准化协议,可为车辆的维护和修复提供规范的方法。开发人员和车辆诊断工程师可根据这些组件进行UDS协议栈的开发和实现。 ### 回答2: ISO-14229是用于诊断汽车电子控制单元(ECU)的标准协议。该协议旨在提供一种标准化的方法,让技术人员可以使用相同的工具和流程诊断不同制造商的汽车。 14229 UDS是该标准的通信协议栈。UDS指协议栈中定义的通用诊断服务,该服务可用于访问ECU的内部数据和状态。ISO14229文档提供了UDS协议栈的详细规范,以及相关的数据格式和命令集合。 此外,文档和源代码可以帮助工程师实现符合ISO-14229标准的诊断工具或ECU,提高汽车诊断系统的质量和效率。源码.zip则是UDS协议栈的代码包。 总之,ISO-14229标准和UDS协议栈提供了一种标准化的、可靠的汽车诊断协议。它们有助于提高汽车技术人员的工作效率,同时减少汽车诊断工具和软件的开发成本。 ### 回答3: ISO-14229是一种用于汽车电子系统的通讯协议。它定义了诊断通信的规范和协议,允许车辆厂商和供应商使用这些规范和协议来开发和测试车载电子控制单元。其中,UDS协议栈是实现ISO-14229的关键技术之一,能够为客户端提供远程访问ECEs的可能性。 ISO-14229规定了接口:UDS(Unified Diagnostic Service),用于与电子控制单元(ECU)之间进行通讯。 UDS协议栈则实现了UDS协议的接口,可以自动进行诊断和测试,发生故障时还能产生错误报告。 相应地, ISO14229文档描述了在ISO14229-1文档中定义的UDS协议的特定应用,与ISO15765-2的特定要求相结合。 它还包括了EVITA Light文档中的安全方面。 源码.zip文件则包含了UDS协议栈的源代码,可以在开发与应用中使用,实现对汽车电子控制单元的简便对话操作。 总之,ISO-14229及其UDS协议栈实现了车载控制电子单元的标准化通讯,可简化车辆诊断和维护过程,提高效率和可靠性。同时,相应的规范、文档和源代码也为相关人员提供了方便和支持。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值