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

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

相关文章

Mac系统下卸载JAVA和JDK的步骤

《Mac系统下卸载JAVA和JDK的步骤》JDK是Java语言的软件开发工具包,它提供了开发和运行Java应用程序所需的工具、库和资源,:本文主要介绍Mac系统下卸载JAVA和JDK的相关资料,需... 目录1. 卸载系统自带的 Java 版本检查当前 Java 版本通过命令卸载系统 Java2. 卸载自定

基于Python实现一个简单的题库与在线考试系统

《基于Python实现一个简单的题库与在线考试系统》在当今信息化教育时代,在线学习与考试系统已成为教育技术领域的重要组成部分,本文就来介绍一下如何使用Python和PyQt5框架开发一个名为白泽题库系... 目录概述功能特点界面展示系统架构设计类结构图Excel题库填写格式模板题库题目填写格式表核心数据结构

Linux系统中的firewall-offline-cmd详解(收藏版)

《Linux系统中的firewall-offline-cmd详解(收藏版)》firewall-offline-cmd是firewalld的一个命令行工具,专门设计用于在没有运行firewalld服务的... 目录主要用途基本语法选项1. 状态管理2. 区域管理3. 服务管理4. 端口管理5. ICMP 阻断

Java中的登录技术保姆级详细教程

《Java中的登录技术保姆级详细教程》:本文主要介绍Java中登录技术保姆级详细教程的相关资料,在Java中我们可以使用各种技术和框架来实现这些功能,文中通过代码介绍的非常详细,需要的朋友可以参考... 目录1.登录思路2.登录标记1.会话技术2.会话跟踪1.Cookie技术2.Session技术3.令牌技

Windows 系统下 Nginx 的配置步骤详解

《Windows系统下Nginx的配置步骤详解》Nginx是一款功能强大的软件,在互联网领域有广泛应用,简单来说,它就像一个聪明的交通指挥员,能让网站运行得更高效、更稳定,:本文主要介绍W... 目录一、为什么要用 Nginx二、Windows 系统下 Nginx 的配置步骤1. 下载 Nginx2. 解压

如何确定哪些软件是Mac系统自带的? Mac系统内置应用查看技巧

《如何确定哪些软件是Mac系统自带的?Mac系统内置应用查看技巧》如何确定哪些软件是Mac系统自带的?mac系统中有很多自带的应用,想要看看哪些是系统自带,该怎么查看呢?下面我们就来看看Mac系统内... 在MAC电脑上,可以使用以下方法来确定哪些软件是系统自带的:1.应用程序文件夹打开应用程序文件夹

windows系统上如何进行maven安装和配置方式

《windows系统上如何进行maven安装和配置方式》:本文主要介绍windows系统上如何进行maven安装和配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不... 目录1. Maven 简介2. maven的下载与安装2.1 下载 Maven2.2 Maven安装2.

使用Python实现Windows系统垃圾清理

《使用Python实现Windows系统垃圾清理》Windows自带的磁盘清理工具功能有限,无法深度清理各类垃圾文件,所以本文为大家介绍了如何使用Python+PyQt5开发一个Windows系统垃圾... 目录一、开发背景与工具概述1.1 为什么需要专业清理工具1.2 工具设计理念二、工具核心功能解析2.

Linux系统之stress-ng测压工具的使用

《Linux系统之stress-ng测压工具的使用》:本文主要介绍Linux系统之stress-ng测压工具的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、理论1.stress工具简介与安装2.语法及参数3.具体安装二、实验1.运行8 cpu, 4 fo

python多线程并发测试过程

《python多线程并发测试过程》:本文主要介绍python多线程并发测试过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、并发与并行?二、同步与异步的概念?三、线程与进程的区别?需求1:多线程执行不同任务需求2:多线程执行相同任务总结一、并发与并行?1、