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,第三个字节是错误响应码,指示具体错误响应的原因

在这里插入图片描述

5、NRC优先级

在ISO14229-1中未明确定义NRC优先级,可以参考下方优先级顺序:
0x11 > 0x7F > 0x13 > 0x12 > 0x7E > 0x33 > 0x24 > 0x31 > 0x22 > 0x78

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服务中的NRC11错误分析 在执行UDS(统一诊断服务)协议下的请求时,如果收到NRC11响应,则表明存在子功能未支持的情况。这意味着发送给电子控制单元(ECU)服务请求中所指定的操作,在当前状态下无法被识别或处理[^1]。 对于特定于Flash编程会话内的操作而言,当尝试通过SID(服务ID)=0x36启动例行程序来更新应用程序代码或者Bootloader部分时,可能会遇到这种情况。具体来说: - 如果目标ECU确实实现了所需的功能但是返回了此否定应答码(NACK),那么可能是由于配置文件设置不当或者是固件版本太旧而不兼容最新的命令集。 - 另一方面,也可能是因为实际硬件并不具备实现某些高级特性的能力,比如双区闪存管理等功能,这将导致即使是最新的软件也无法克服物理层面的局限性。 针对上述情况提出的建议措施如下所示: #### 解决方案一:验证并升级工具链环境 确保使用的刷写工具及其配套库处于最新状态,并仔细核对官方文档确认所有必要的依赖项都已正确安装。此外,还需检查连接线缆的质量以及接口适配器是否匹配车辆端口规格。 #### 解决方案二:查阅技术手册获取更多信息 参阅制造商提供的详细说明资料,了解有关如何正确调用相应API的具体指导方针;同时注意排查是否有其他前置条件尚未满足,例如进入安全模式前需完成的身份认证流程等。 ```python def check_toolchain_version(): """检查工具链版本""" pass def update_firmware_if_needed(ecu_model): """根据ECU型号决定是否需要更新固件""" pass ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值