UDS诊断中的物理寻址和功能寻址

1:基本概念

诊断物理寻址:物理地址是针对网络中具体的ECU。

功能寻址:是针对网络中多个或所有ECU。(准确来说是功能请求报文的ID对应多个ECU)

      如一个车身域网络中,存在3个ECU,(车身域控制器,娱乐系统域控制器,远程网络系统域控制器),我们需要分别为这三个控制器分配三个物理诊断寻址。

1:如0x618(请求报文ID)=车身 ,0x658服务器应答报文ID

2:0x628 (请求报文ID)=娱乐,  0x668服务器应答报文ID

3:0x638(请求报文ID) = 远程网络,  0x678服务器应答报文ID

对这三个ECU,我们还能设定一个,针对所有三个ECU报文的请求报文,如

0x 668(功能寻址ID), 在网络中用0x 668报文发出请求报文,三个ECU都要接受,并处理这个请求信息。(对于是否应答?这么应答?则要根据具体情况来定)。

2:为什么要设计功能寻址

本人都是在零部件供应商打工的,一开始接触到功能寻址时,觉得非常难以理解,这不是脱裤子放屁,有了物理寻址还搞出一个功能寻址,不是多此一举吗?

直到我接触了,主机厂的整车联调,后我才明白功能寻址的意义,假设有如下场景。整车上,我们

**场景1)需要对某个ECU进行刷写(bootload操作)

因为刷写(bootload操作),需要两个前提:

1;关闭网络上的所有通讯

2:刷写(bootload操作)具体ECU的过程中,会对被刷写(bootload操作)产生干扰,导致误报DTC

对应的解决方法,调用uds中的0x28(通讯控制),和0x85(DTC控制)服务。

如果依然采用物理寻址,一个个去设置,显得麻烦,实际车上,一个网络上会挂载10个以上的ECU,如果采用物理寻址的方法,一个个设置,就非常麻烦和低效。

如果采用功能寻址,就很方便了。

**场景2)整车读取某些数据0x22服务

需要说明:uds设计过程中,没有要求DID或参数的唯一性要求,如;F1 98 在ECU1中可以用来读取,软件版本。在ECU2中同样也可以。

于是主机厂的工程师们,只要采用功能寻址,发送一条DID为 F1 98的报文,就可以读取网络中所有ECU的软件版本。

注意:客户端client 采用功能寻址 时,不同的ECU采用物理回复的ID,进行回复

如:诊断客户端   0x 668 03 22 F1 98

          ECU1应答:0x658 07 62 F1 98 90 90 90 90(90就是对应ascil码的软件版本)

          ECU2应答:0x668 07 62 F1 98 91 91 91 91(91就是对应ascil码的软件版本)

          ECU3应答:0x678 07 62 F1 98 92 92 92 92(92就是对应ascil码的软件版本)

需要注意的是:ECU回复依然是采用的是,物理地址回复。

### UDS诊断协议寻址配置方法及参数设置 #### 物理寻址功能寻址的区别 在UDS(统一诊断服务)协议中,存在两种主要的寻址方式:物理寻址功能寻址。对于拥有多个ECU(电子控制单元)的汽车网络而言,这两种寻址机制提供了不同的通信路径。 - **物理寻址**用于特定节点之间的直接一对一交互。这种方式下,每个消息都携带源地址目标地址的信息,使得发送方能够精确指定接收者[^3]。 - **功能寻址**则允许向具有相同功能的一组设备广播指令而不必关心具体哪个成员回应。这意味着可以简化某些类型的查询操作,尤其是在不知道确切响应来源的情况下特别有用。 #### 功能寻址的应用场景 当涉及到大量ECUs时,使用功能寻址能显著提高效率并减少复杂度。例如,在初始化阶段或执行全局性的状态检查时,可以通过一次调用来收集所有相关组件的数据而无需单独访问每一个实体。 #### 配置流程概述 为了实现有效的功能寻址,通常需要完成以下几个方面的设定: 1. 定义好各个子系统的唯一标识符服务ID (SID),这有助于区分不同种类的服务请求; 2. 设置适当的CAN-ID范围来支持多播或多路传输特性; 3. 确定哪些类型的事件应该触发自动回复以及如何处理这些反馈信息。 ```python # Python伪代码展示基本的功能寻址逻辑 def configure_functional_addressing(ecus_list, service_id): for ecu in ecus_list: # 假设ecu对象有一个方法set_service_handler()用于注册服务处理器 ecu.set_service_handler(service_id) configure_functional_addressing([ecu1, ecu2], 0x1A) # 示例:为两个ECU配置SID=0x1A的服务监听器 ``` 通过上述措施,可以在不影响现有架构的前提下引入更加灵活高效的通讯手段,从而更好地满足现代车辆日益增长的需求。
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值