UDS诊断(ISO14229-1) 36服务

功能简介

36服务,即 TransferData(传输数据)服务,客户端利用 TransferData(传输数据)服务从客户端向服务器(下载)或从服务器向客户端(上传)传输数据。

数据传输方向取决于前述 RequestDownload(请求下载)或 RequestUpload(请求上传)服务。

TransferData(传输数据)服务请求包含 blockSequenceCounter(块序列计数器),以便在请求一序列 TransferData(传输数据)过程中 TransferData(传输数据)服务失败时提高错误处理。
收到RequestDownload(请求下载) (0x34)或 RequestUpload(请求上传)(0x35)消息时,服务器的blockSequenceCounter(块序列计数器)应初始化为 1。这表示 RequestDownload(请求下载(0x34)或 RequestUpload(请求上传)(0x35)消息之后的首个 TransferData(传输数据)(0x36)请求消息是从 blockSequenceCounter(块序列计数器) 1 开始。

应用场景

主要是用来给ECU下载数据的,最常见的应用就是在bootloader中,程序下载工具会发起下载请求,以完成ECU程序的升级

0x34服务一般和0x36服务(数据传输)是配套使用的。

请求和响应

1、请求

基本格式

归纳起来,诊断的request格式无非以下两种:

<SID> + <Sub-function> + <Parameter>

<SID> + <Parameter>

即有无sub-function的区别。Parameter可以是DID,可以是输入参数,可以是自定义的值,字节数视具体要求而定。

在这里插入图片描述
在这里插入图片描述

2、子功能

子功能参数定义(1字节数据):

  • Bit7:抑制肯定响应消息指示位suppressPosRspMsgIndicationBit
    • 0=False:需要肯定响应
    • 1=True:禁止肯定响应
  • Bit6-0:子功能参数值(0x00~0x7F)

无。

3、肯定响应

基本格式:

<SID + 0x40> + <Sub-function> + <Parameter>

<SID + 0x40> + <Parameter>

要注意,第一个字节是由SID和0x40的和构成。这里的Parameter项是optional的,具体要看协议规定。

在这里插入图片描述
在这里插入图片描述

4、否定响应

基本格式:

<0x7F> + <SID> + <NRC>

看起来比较简单,格式比较固定,只要是Negative Response,第一字节就是0x7F,第二字节照抄原来的SID,第三个字节是错误响应码,指示具体错误响应的原因

在这里插入图片描述

NRC 判断优先级顺序

在这里插入图片描述

报文示例

1、下载数据到服务器

  • 假设

第 1 步,客户端和服务器执行 RequestDownload(请求下载)服务。
在这里插入图片描述
在这里插入图片描述

第 2 步,客户端从 memoryaddress(内存地址) 0x602000 开始向服务器的快闪内存器传输 65535 字节
数据。

第 3 步,客户端执行 requestTransferExit(请求传输终止)服务终止向服务器传输数据。

测试条件: ignition = on, engine = off, vehicle speed = 0 [kph](点火开关打开,发动机熄火,车辆速度为 0 [kph])

假设在此例中服务器支持三字节 memoryAddress(内存地址)和三字节 MemorySize(内存大小)。如果 MemorySize(内存大小)包含未压缩大小,则无法计算 127 数据字节的 TransferData(传输数据)服务的大小,因为压缩方法和压缩比不规范。如果 MemorySize(内存大小)包含压缩大小,则127 数据字节的 TransferData(传输数据)服务大小应为 516,其后为三字节的单个 TransferData(传输数据)请求。因此,假设最后一个 TransferData(传输数据)请求消息包含大小相当于 0x05 的blockSequenceCounter(块序列计数器)。

  • 步骤 1:下载请求
    在这里插入图片描述
    在这里插入图片描述

  • 步骤 2:传输数据
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

  • 步骤 3:请求传输终止
    在这里插入图片描述
    在这里插入图片描述

UDS中常用 NRC

在这里插入图片描述

### 关于UDS 36服务的介绍 UDS (Unified Diagnostic Services) 是一种基于ISO 14229标准的汽车诊断协议,广泛应用于车辆电子系统的测试和维护。其中,UDS $36服务被称为“Transfer Exit”,主要用于结束刷写过程中的数据传输阶段[^2]。 #### 请求结构 在UDS $36服务中,`blockSequenceCounter`是一个重要的参数,其作用是在请求和响应之间保持一致性。具体来说,在发送$36服务请求时,客户端需要提供一个与之前传输过程中使用的序列号相同的值,以此来确认当前的数据块已经成功接收并处理完毕。 #### 参数说明 - **blockSequenceCounter**: 这一字段用于验证最后一步操作的状态是否匹配预期值。它确保ECU能够识别到这是最后一个数据包,并完成整个下载流程。 需要注意的是,不同于其他一些关联的服务(比如$35),这里并没有涉及所谓的 `transferRequestParameterRecord` 参数,因为该参数仅适用于上传场景下的初始化阶段[$^2$]。 另外值得注意的一点是,$34(Transfer Data)$ 和 $35(Request Upload/Download)$ 实际上构成了相反的操作逻辑,而作为它们后续收尾工作的组成部分之一,$36自然也遵循类似的反向关系原则[$^2$]. 以下是简单的Python伪代码展示如何构建这样的请求: ```python def uds_transfer_exit(block_sequence_counter): """ 构造UDS Transfer Exit ($36) 的请求消息 :param block_sequence_counter: 序列计数器数值(int) :return: 字节列表表示形式的消息(list of int) """ request = [0x36] request.append(block_sequence_counter & 0xFF) # 添加低字节部分 return request ``` 此函数接受一个整型输入代表最终校验所需的序号位信息,然后将其转换成适合CAN总线通信的标准帧格式. ### 结论 综上所述,通过正确设置必要的参数如block sequence counter可以有效地利用UDS 36服务终止先前建立起来的数据流连接状态从而保障整体程序执行连贯性和稳定性.[^2]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值