技术丨 浅谈以太网系统级刷写测试

2023-12-22 18:20

本文主要是介绍技术丨 浅谈以太网系统级刷写测试,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在研发阶段,我们一般将ECU直连至刷写上位机进行软件更新,但在整车环境中,各ECU之间通过线束连接在一起,如果此时想对某个单独的样件进行软件更新,把零件拆下来再接到上位机上进行软件更新是不现实的。

作为测试工程师,除了保证ECU直连上位机的时候可以正常进行软件升级之外,也要保证在整车环境下可以对车辆软件进行更新。搭建一个系统级的台架测试环境,将车内的ECU节点按照整车网络拓扑连接好之后,模拟上位机对ECU进行刷写测试,可以验证在整车环境下,各ECU之间是否能配合完成车辆软件的更新。

01 系统级刷写实现方式

在整车上实现软件升级一般有两种方式,最常见的是通过车辆的OBD接口,用诊断仪进行升级,还有一种是通过远程诊断(如TBOX)的方式来实现升级功能。下图描述了整车网络拓扑的简图。

图片

上位机(诊断仪/TBOX)通过以太网TX/T1接口连接网关节点,将UDS诊断请求发送给网关,网关要实现诊断路由功能,解析DoIP报文中的TA(Target Logical Address),识别上位机是给哪个网段的哪个ECU发送的诊断请求,并将该诊断请求路由到对应ECU所在的网段上。同理,网关将ECU回复的诊断响应路由给上位机,在执行了完整刷写流程的诊断交互之后即实现了对ECU的软件升级。

完成系统级刷写除了需要ECU本身实现刷写功能,还需要网关实现诊断路由功能,下面简要介绍各参与模块的工作原理。

ECU刷写

车载ECU的刷写流程主要包括3个阶段(预编程,编程,后编程),通过UDS协议来实现,下图是基于UDS刷写的流程示例。

图片

网关诊断路由

DoIP->DoCAN

当上位机刷写的ECU为车内CAN节点时,网关根据诊断报文中的Target ECU Logical Address识别目标CAN节点,将上位机发送的以太网诊断请求转换为CAN诊断请求给ECU,之后将ECU回复的CAN诊断响应转换为以太网诊断响应给上位机,实现DoIP->DoCAN的路由。诊断请求报文格式转换示例如下。

图片

DoIP路由DoCAN诊断请求格式示例

图片

图片

车内CAN节点诊断交互过程示例

DoIP->DoIP

当上位机刷写的ECU为车内DoIP节点时,网关根据诊断报文中的Target ECU Logical Address识别目标DoIP节点,并主动与ECU完成路由激活,之后转发上位机发送的以太网诊断请求给ECU,以及ECU回复的诊断响应给上位机,实现DoIP->DoIP的诊断路由。诊断请求报文格式转换示例如下。

图片

DoIP路由DoIP诊断请求格式示例

图片

图片

车内DoIP节点诊断交互过程示例

上位机

上位机发送UDS诊断请求,网关在上位机和ECU之间实现诊断路由,从而实现上位机对ECU的诊断,上位机按照刷写流程一步一步的将刷写文件写入ECU中,实现ECU的软件更新。

02 系统级刷写测试

测试环境

实现系统级刷写测试需考虑系统供电、通讯控制、故障注入三个方面。

系统供电:需要选用可编程控制的电源,方便自动化调节系统的供电电压。

通讯控制:Tester需要模拟上位机实现跟网关的通信,同时也要监听网关和ECU之间的通信,这就要求测试使用的网络接口卡可以同时监听多个网段(Tester<-->网关,网关<-->车内ECU),当刷写流程出现问题时(如,上位机没有接收到诊断响应),可以通过不同网段的log分析是ECU没有回复诊断响应,还是网关没有正确转发ECU的诊断响应。采用TAP模式监听网关和车内以太网节点之间的以太网数据。

图片

故障注入:测试过程中需要模拟网络通讯故障和ECU掉电故障,如CAN通讯断路,以太网P/N短路等。可以选用ETS6204模拟以太网通讯故障,ETS6210模拟CAN网络通讯故障,同时也都能实现对ECU的电源控制。

测试点

系统级刷写测试的执行一般是在完成单节点刷写测试和网关诊断路由测试之后,在此之前应已单独验证了ECU可以实现刷写功能,以及网关可以实现诊断路由功能。

单节点的刷写测试,侧重点在于验证刷写流程,以及刷写流程错误时ECU的响应。而系统级刷写测试,则着重关注测试环境变化对刷写的影响,如电压不稳定、以太网接线不稳定等,确保当一次刷写出现问题时不影响后续重新对其进行刷写。可设计的测试点参考如下。

图片

软件实现

Tester可以使用CANoe或SolarTest软件实现自动化测试,如之前描述,在系统级刷写测试之前已经进行了单节点的刷写测试,那么系统级的刷写测试,就可以基于单节点的刷写测试脚本进行更新。


以上就是我们给大家分享的以太网系统级刷写测试的相关内容了,任何疑问或是自动化测试需求,都可以随时联系我们噢,感谢大家的阅读~

这篇关于技术丨 浅谈以太网系统级刷写测试的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

SpringBoot3实现Gzip压缩优化的技术指南

《SpringBoot3实现Gzip压缩优化的技术指南》随着Web应用的用户量和数据量增加,网络带宽和页面加载速度逐渐成为瓶颈,为了减少数据传输量,提高用户体验,我们可以使用Gzip压缩HTTP响应,... 目录1、简述2、配置2.1 添加依赖2.2 配置 Gzip 压缩3、服务端应用4、前端应用4.1 N

Python FastAPI+Celery+RabbitMQ实现分布式图片水印处理系统

《PythonFastAPI+Celery+RabbitMQ实现分布式图片水印处理系统》这篇文章主要为大家详细介绍了PythonFastAPI如何结合Celery以及RabbitMQ实现简单的分布式... 实现思路FastAPI 服务器Celery 任务队列RabbitMQ 作为消息代理定时任务处理完整

Linux系统中卸载与安装JDK的详细教程

《Linux系统中卸载与安装JDK的详细教程》本文详细介绍了如何在Linux系统中通过Xshell和Xftp工具连接与传输文件,然后进行JDK的安装与卸载,安装步骤包括连接Linux、传输JDK安装包... 目录1、卸载1.1 linux删除自带的JDK1.2 Linux上卸载自己安装的JDK2、安装2.1

Java利用JSONPath操作JSON数据的技术指南

《Java利用JSONPath操作JSON数据的技术指南》JSONPath是一种强大的工具,用于查询和操作JSON数据,类似于SQL的语法,它为处理复杂的JSON数据结构提供了简单且高效... 目录1、简述2、什么是 jsONPath?3、Java 示例3.1 基本查询3.2 过滤查询3.3 递归搜索3.4

Python中随机休眠技术原理与应用详解

《Python中随机休眠技术原理与应用详解》在编程中,让程序暂停执行特定时间是常见需求,当需要引入不确定性时,随机休眠就成为关键技巧,下面我们就来看看Python中随机休眠技术的具体实现与应用吧... 目录引言一、实现原理与基础方法1.1 核心函数解析1.2 基础实现模板1.3 整数版实现二、典型应用场景2

浅谈mysql的sql_mode可能会限制你的查询

《浅谈mysql的sql_mode可能会限制你的查询》本文主要介绍了浅谈mysql的sql_mode可能会限制你的查询,这个问题主要说明的是,我们写的sql查询语句违背了聚合函数groupby的规则... 目录场景:问题描述原因分析:解决方案:第一种:修改后,只有当前生效,若是mysql服务重启,就会失效;

Linux系统之主机网络配置方式

《Linux系统之主机网络配置方式》:本文主要介绍Linux系统之主机网络配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、查看主机的网络参数1、查看主机名2、查看IP地址3、查看网关4、查看DNS二、配置网卡1、修改网卡配置文件2、nmcli工具【通用

Linux系统之dns域名解析全过程

《Linux系统之dns域名解析全过程》:本文主要介绍Linux系统之dns域名解析全过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、dns域名解析介绍1、DNS核心概念1.1 区域 zone1.2 记录 record二、DNS服务的配置1、正向解析的配置

Linux系统中配置静态IP地址的详细步骤

《Linux系统中配置静态IP地址的详细步骤》本文详细介绍了在Linux系统中配置静态IP地址的五个步骤,包括打开终端、编辑网络配置文件、配置IP地址、保存并重启网络服务,这对于系统管理员和新手都极具... 目录步骤一:打开终端步骤二:编辑网络配置文件步骤三:配置静态IP地址步骤四:保存并关闭文件步骤五:重

Windows系统下如何查找JDK的安装路径

《Windows系统下如何查找JDK的安装路径》:本文主要介绍Windows系统下如何查找JDK的安装路径,文中介绍了三种方法,分别是通过命令行检查、使用verbose选项查找jre目录、以及查看... 目录一、确认是否安装了JDK二、查找路径三、另外一种方式如果很久之前安装了JDK,或者在别人的电脑上,想