0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

ECU电控软件开发及测试介绍

经纬恒润 2024-09-26 14:25 次阅读

伴随着电动化、智能化、网联化等技术发展的时代背景,各行各业电子电气架构都在发生深度变革。新型架构逐渐取代传统架构,比如汽车、工程机械、储能、船舶等领域,电子电气架构从传统分布式向域集中式,甚至向着中央集中式发展,控制器功能呈现集中化、复杂化的特点。为了提升开发效率、提高软件的稳定性以及便于平台移植,基于 AutoSar 架构开发复杂软件已成为行业共识。

另外,行业内竞争愈发激烈,开发周期大大压缩,加之软件复杂度的提升,在快速迭代的情况下确保软件质量是一个重要课题。加之 ASPICE、ISO26262 等过程体系和法规标准的要求,如何开发符合 AutoSar 架构的应用软件、评估软件质量和性能、优化软件结构、验证压力场景下的 ECU 稳定性成为各厂商面临的新挑战。

本文重点介绍符合 AutoSar 架构的应用软件开发、MBD 开发模式下的软件质量评估与优化方案、复杂场景下的 ECU 性能压力测试方案。

符合 AutoSar 架构的应用软件开发介绍

对于 AutoSar 软件架构,分为经典平台 AutoSar CP 和自适应平台 AutoSar AP,二者应用场景存在一定差别:AutoSar CP 具有高安全、高实时性,其通常部署在微控制器 MCU 类型芯片或多核异构芯片 M 核;AutoSar AP 具有动态性和可扩展性,适用于大数据并行处理和高性能计算等应用场景,通常部署在 MPU 或多核异构芯片 A 核。目前从行业内来看,无论是域控制器还是中央 + 区域控制器,通常都是多核的,甚至是多核异构的,不同核根据实际使用需求部署 AutoSar CP 或 AP,基础软件通常采用标准的 BSW 协议栈。下图所示是 AutoSar 软件架构示例:

wKgaomb0_OKAT9W7AADiOtArmc4665.pngAutoSar 软件架构

那对于应用层软件来说,如果要开发符合 AutoSar 架构的软件,需要考虑以下两个重要问题:

·采用何种开发工具链

·采用何种开发模式

对于应用软件开发工具链,通常涉及 SWC 软件架构设计工具和软件编程实现工具。SWC 软件架构设计工具主要对应用层软件架构进行实现,定义 SWC、配置 SWC 的交互接口、配置 Runnable、导出 ARXML 文件等,一般不同品牌的协议栈都有对应的 SWC 软件架构设计工具,经纬恒润自研 AutoSar 协议栈提供工具链方案为 EAS-SWCDesigner。

wKgZomb0_P2AW4LTAADQL54Fdc4688.pngEAS-SWCDesigner 界面

而软件编程实现可基于图形化编程自动生成代码或手写代码的方式,AutoSar CP 和 AP 架构应用层软件开发实现方法略有差别,CP 架构应用层更多采用基于模型设计方法开发,工具链通常采用 Matlab/Simulink,其对 CP 架构应用层开发的支持比较完善且成熟,但是由于其对 AP 架构应用软件开发支持还存在不完善的点,故 AP 架构应用层软件开发目前更多还是基于手写 C++ 代码的方式,工具链基于一些代码编辑工具比如 Vscode。

对于应用软件开发模式,分为自上而下开发、自下而上开发和双向开发模式。自上而下开发比较适用于正向开发流程,在有 EE 架构输入的情况下采用该模式,这种模式的好处是可以继承 EE 架构的工作产品,但是缺点是工作链路会比较长,应用层和底层软件开发都需要依耐 SWC 架构设计导出的 ARXML 文件作为输入,影响开发迭代效率;自下而上开发是直接在软件编程工具实现软件,然后配置 AutoSar 接口,再导出 ARXML,然后对 ARXML 文件进行合并,这种方式比较适用于没有 EE 架构输入的情况,应用软件开发工程师独立配置 AutoSar 接口,这种模式的好处是不依耐 AutoSar 工具链,比较灵活,但是缺点是对每个应用软件开发人员 AutoSar 知识要求高些;双向开发模式就是结合自上而下和自下而上开发模式的优点,针对第一版软件采用自上而下开发模式,后续版本软件更新迭代采用自下而上开发模式。

wKgaomb0_R6AbY3IAAC0HYJycpI476.png应用软件开发模式

MBD 开发模式下的软件质量评估与优化方案

MBD 全称是 Model Based Design(基于模型设计),是一种以可视化模型开发为主的开发方式,区别于传统的以文本编码为媒介的代码开发。采用模型化的方式来描述控制算法设计,无论是可读性、可维护性、可移植性、测试验证的便利性等方面,相比于从前手工 C 代码都有长足的进步。基于以上基于模型开发的特点基于 Simulink 的模型化 + 自动代码生成的开发方式在汽车电子行业正在逐渐演变成开发的标准配置。接踵而来如何保证 MBD 开发方式下软件质量问题也成为现阶段人们热议的话题

针对软件质量直接有效的手段便是开展完备的测试或在软件开发过程中优化软件结构减少问题的引入。

如何开展完备的模型测试?

模型验证方法可以分为静态验证和动态验证,模型静态验证,是一种通过 MAAB 和 dSPACE 等建模公司提供的建模规则指南来验证模型设计是否符合规则的测试方法。此外,还有一种模型度量元指标检查方法,可以分析模型的复杂程度,以此评判模型在可维护性、可移植性、可重用性等不同维度的质量特性。综上所述,在模型静态验证部分,可以看出有两种方法:建模规范规则检查和模型度量元指标检查。与模型静态验证不同,模型动态验证可以通过比较在执行实际模型时的输出值来进行验证。通过根据用户输入预期结果值对比实际模型结果值来动态验证模型。通过检查模型的覆盖率,可以提高测试用例针对需求的覆盖率以及测试用例的充分性。此外借助 ASPICE 过程管理的思维,在整个测试过程中加入过程管理思维,确保测试过程、测试环境、测试策略的可靠性以及测试用例的充分性、一致性、追溯性,以此确保模型质量。

如何优化软件结构?

现阶段我们模型生成的代码是否会存在以下问题:

·生成代码一个函数可能会上万行代码

·看不懂 matlab 生成代码后的变量的定义及过程转化

·要不要针对模型生成的代码做修改

优化软件的前提是已经开展静态测试优化完毕模型结构。确保模型结构的规范性。针对每一个软件设计单元生成独立函数、每一个软件组件生成与之相对应的 C 文件可以确保模型生成代码的结构清晰。同时不对模型生成的代码做任何的修改是 MBD 开发过程中的软件维护准则。

综上让我们一起来期待恒润针对 MBD 开发模式下的软件质量评估与优化的解决方案。

复杂场景下的 ECU 性能压力测试方案

随着控制器数量的激增和模块交互复杂度的提升,只针对软件基础功能验证的效果存在一定的缺陷,越来越多的项目实践表明,软件的偶发性故障需要从软件性能指标、压力场景来进行补充验证,以确保软件产品的质量。

性能测试针对 ECU 电控软件的内存(堆栈、RAM/ROM/FLASH)、CPU 负载进行最差工况的分析,保证资源占用的合理性;压力测试构建通信、IO 驱动、诊断、网络管理等模块的异常注入、总线故障、高频触发等场景,保证软件功能在压力场景下不存在致命风险。

基于 AbsInt 的静态性能分析

◾客户收益

·评估资源使用率,指导芯片选型和工程优化

·保证软件的任务、中断预留堆栈空间和分配周期合理性

·保证芯片内存占用率和 CPU 负载在阈值范围内

·开展符合功能安全和 ASPICE 流程要求的测试

◾测试内容

·内存:自动化分析最差工况的堆栈用量、RAM/ROM/Flash 占用率

·WCET:分析最差工况下的执行时间,测试周期稳定性和任务实时性

·调度仿真模拟任务调度,建模仿真 CPU 负载率和任务占比

◾方案特点

·借助 AbsInt 工具,针对工程二进制可执行文件进行自动化分析,无需依赖源码

·支持 PPC、V850、Tricore、ARM 等多种架构芯片的堆栈、时间分析

·分析遍历工况,结果涵盖程序的各个入口

·图形化展示最差工况下的执行路径和占比用量,指导性能优化

·不依赖测试用例,执行效率高,项目周期短

·AbsInt 工具满足 ASIL D 等级功能安全标准

wKgZomb0_UiAdZXzAAEGUCwJq4c966.png基于 AbsInt 的测试流程

wKgaomb0_WSAPXXeAABWxfaCoyI098.png函数调用关系及用量显示

wKgaomb0_XyAGUNyAACm1z3uUvE673.png数据化表格用量展示

基于 RVS 的动态性能测试

◾客户收益

·在 PIL、HIL、车载环境下进行时序分析,确保软件行为安全

·可视化监测任务调度和 CPU 负载,为系统升级提供优化参考

·保证多任务和多核运行的合理性,规避优先级反转、死锁等时序问题

·开展符合功能安全和 ASPICE 流程要求的测试

◾测试内容

·WCET:分析任务 / 中断的最差工况执行时间,测试周期稳定性和响应实时性

·任务调度:评估 WCRT,监测任务时序特征,图形化显示多核、多任务调度关系

·负载率:基于实际工况对 CPU 负载率进行实时统计和分析,评估极限负载下的 CPU 负载率占用情况

◾方案特点

·借助 RVS 分析套件进行实时数据采集和分析,还原实际环境下的执行工况

·支持全量数据采集和长时间监测运行,追踪定位软硬件交互情况

·自定义程度高,项目复用性强,可针对任意函数、模块或代码段进行时序分析

·支持集成多种处理器 + 编译器环境,实现 PIL/HIL/ 车载环境下分析

·RVS 工具可以支持产品功能安全认证等级 ASIL D

wKgZomb0_aCANDiNAAFFLNjctGI446.png基于 RVS 的测试流程

wKgZomb0_baAcl8UAAFU7IJBC1w814.png时序调度分析

基于自动化测试框架的压力测试

◾客户收益

·保证通信、诊断、操作系统、IO 驱动、网络管理等模块在压力场景下不存在致命风险

·作为功能验证的补充,发现软件质量潜在问题,确保软件鲁棒性、稳定性

·构建标准化的压力测试用例模板,有助于形成符合功能安全要求的测试流程

·测试用例搭载自动化测试框架进行测试执行、用例管理、问题追溯

◾测试内容

·针对 NVM、IO 驱动、CAN、LIN、ETH、COM 等模块进行压力场景构建

·分析系统不同组件间的时延特性,验证模块运行时间稳定性

·验证在异常注入、高频触发、总线故障等因素影响下的功能稳定性

·验证极限工况下的核心功能有效性及软件后续响应的合理性

◾方案特点

·借助自动化测试框架执行测试用例,测试周期短、测试效率高、测试复用性强

·支持软硬件交互,可监测底层函数、上层报文、外部信号

·支持在 PIL/HIL 环境下开展测试,可同步注入多种激励进行测试验证

wKgaomb0_daAYOzsAADSqLBjfwc262.png测试流程示意

wKgaomb0_e-AEeNlAAERdSqnC-o476.png测试框架示意

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 软件开发
    +关注

    关注

    0

    文章

    614

    浏览量

    27356
  • AUTOSAR
    +关注

    关注

    10

    文章

    362

    浏览量

    21573
  • ecu
    ecu
    +关注

    关注

    14

    文章

    886

    浏览量

    54497
收藏 人收藏

    评论

    相关推荐

    瑞萨电子推出完整的集成开发环境, 无需硬件即可实现ECU级车用软件开发

    全新集成软件开发环境支持多芯片ECU, 缩减开发时间和后期设计修改工作量   2022 年 9 月 28 日,中国北京讯 - 全球半导体解决方案供应商瑞萨电子(TSE:6723)今日宣布,推出全新
    发表于 10-08 10:21 843次阅读
    瑞萨电子推出完整的集成<b class='flag-5'>开发</b>环境, 无需硬件即可实现<b class='flag-5'>ECU</b>级车用<b class='flag-5'>软件开发</b>

    ECU/MCU软件开发

    汽车电子技术——ECU/MCU软件开发1. ECU/MCU软件开发知识储备1.1 ECU/MCU相关基础知识1.2 C语言编程知识1.3 外
    发表于 09-10 08:13

    基于OSEKturbo的电控柴油机ECU软件开发与实现

    采用基于OSEKturbo的模块化方法设计电控柴油机ECU软件开发框架。在此框架下进行了ECU软件开发,并分析目标代码的可调度性。实验证明采
    发表于 04-21 22:01 68次下载

    测试程序软件开发平台的实现

    测试程序软件开发平台的实现讨论了测试程序软件设计平台的基本功能、组成和软件结构,并介绍了与
    发表于 01-09 16:59 41次下载
    <b class='flag-5'>测试</b>程序<b class='flag-5'>软件开发</b>平台的实现

    ARM嵌入式软件开发

    ARM嵌入式软件开发ARM嵌入式软件开发ARM嵌入式软件开发
    发表于 01-15 17:29 65次下载

    TI的软件开发系统的使用应用和资料概述

    本文的主要内容介绍的是TI的软件开发系统介绍和使用应用和资料概述
    发表于 05-03 10:22 3次下载
    TI的<b class='flag-5'>软件开发</b>系统的使用应用和资料概述

    Linux软件开发环境

    Linux软件开发环境介绍
    发表于 03-25 15:46 7次下载
    Linux<b class='flag-5'>软件开发</b>环境

    汽车电子技术——ECU/MCU嵌入式软件开发

    汽车电子技术——ECU/MCU软件开发1. ECU/MCU软件开发知识储备1.1 ECU/MCU相关基础知识1.2 C语言编程知识1.3 外
    发表于 10-25 11:06 20次下载
    汽车电子技术——<b class='flag-5'>ECU</b>/MCU嵌入式<b class='flag-5'>软件开发</b>

    汽车软件开发流程介绍

    在汽车软件开发中,软件开发流程是软件工程的核心,因为它们为软件开发实践“提供了一个骨架并确保了它的严谨性”。软件开发的流程包含“阶段”“活动
    发表于 08-15 12:03 1.5w次阅读

    汽车电控底层及应用层软件开发介绍

    底层软件开发内容有:一方面是设备驱动的实现,基于主芯片有:底层驱动PORTS,ADC,PWM,SPI,CAN,SENT等,基于外围芯片的复杂驱动。
    发表于 10-10 09:13 3894次阅读

    软件开发的流程和方法有哪些?

    需求定义阶段要对项目可行性和用户需求进行分析,确定能否开发软件开发阶段包括概要设计、详细设计、编码过程、调试和测试过程;软件维护是周期最长的阶段,在这个过程中需
    的头像 发表于 12-27 10:56 2115次阅读
    <b class='flag-5'>软件开发</b>的流程和方法有哪些?

    ecu测试是什么 汽车ecu测试的共性有哪些

    ECU开发测试中,通常会把二者区分开来,我们从以下几个角度来看差异点: 测试对象:软件测试
    发表于 07-25 09:33 851次阅读
    <b class='flag-5'>ecu</b><b class='flag-5'>测试</b>是什么 汽车<b class='flag-5'>ecu</b><b class='flag-5'>测试</b>的共性有哪些

    AUTOSAR软件开发环境之EB tresos Studio简介

    EB tresos是一款经典的AUTOSAR软件开发环境,依赖于一致的单一工具环境来通过汽车开放系统架构 AUTOSAR 开发电子控制单元 (ECU);它能够实现配置、验证和生成 ECU
    的头像 发表于 09-19 10:06 9085次阅读
    AUTOSAR<b class='flag-5'>软件开发</b>环境之EB tresos Studio简介

    Vector DaVinci Team解决方案实现AUTOSAR Classic ECU软件开发

    随着软件技术的发展,车辆的开发过程从硬件主导转变为软件定义汽车(SDV),软件开发在汽车的开发过程中扮演着举足轻重的角色。车辆E/E架构由原
    的头像 发表于 09-13 11:23 1094次阅读
    Vector DaVinci Team解决方案实现AUTOSAR Classic <b class='flag-5'>ECU</b><b class='flag-5'>软件开发</b>

    9月12日云技术研讨会 | ECU电控软件开发测试全流程解决方案

    本次研讨会,经纬恒润将结合业务团队多年来在软件开发测试领域的工程实践经验,分享探讨基于AutoSar架构的应用软件开发、基于MBD开发软件
    的头像 发表于 09-26 14:18 1382次阅读
    9月12日云技术研讨会 | <b class='flag-5'>ECU</b><b class='flag-5'>电控</b><b class='flag-5'>软件开发</b>及<b class='flag-5'>测试</b>全流程解决方案