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

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

3天内不再提示

提高软件质量,减少ADAS软件源代码验证时间

MATLAB 来源:MATLAB 2023-05-24 09:40 次阅读

随着高级驾驶辅助系统 (ADAS) 和自动驾驶 (AD) 系统日趋复杂,赋能这些系统的软件也变得愈加复杂。另一方面,汽车 OEM 要求供应商压缩 ADAS/AD 软件的交付周期,同时还提高了软件质量要求。因此,供应商可谓举步维艰。通常情况下,依靠手动过程,他们只能在开发生命周期的后期发现缺陷。更糟的是,如果系统已投入生产,则召回需要付出高昂的成本。

凭借 Polyspace 静态代码分析产品,HL Klemove 的工程团队在高级 ADAS/AD 软件开发过程的早期阶段即可发现运行时错误、安全漏洞和编码标准偏差。他们已将 Polyspace Bug Finder 和 Polyspace Access 集成到其自动化持续集成/持续交付 (CI/CD) 工作流中,从而减少了代码验证时间,提高了软件质量,并促进了团队间和团队内的协作。

HL Klemove 团队负责人 Minchae Lee 表示,“即使 ADAS/AD 软件项目的数量和复杂性有所增加,Polyspace Bug Finder 也能让我们在开发过程的早期阶段发现问题,从而交付质量更高的软件。它还使我们的团队能够满足 OEM 客户现行的安全编码标准要求,而 Polyspace Access 让我们可通过 Web 访问静态分析结果,从而改进协作。”

挑战

过去,HL Klemove 团队需要结合使用手动代码审查和独立工具,对 ADAS/AD 软件进行源代码分析。但是,视觉检查以及工具的配置和维护复杂且耗时。此外,将这些工具集成到 CI/CD 工作流也非易事。开发人员必须在他们的工作站上使用这些工具,但这既消耗资源,又使得他们很难执行其他开发任务。

因此,团队不得不将静态代码分析推迟到开发过程的后期进行,而这时用来发现并解决累积的各种问题的时间已经所剩无几。HL Klemove 需要一种新的工具来应对这些挑战,并使团队能够满足新的客户要求,即符合新 UNECE WP.29 法规所要求的 CERT C 编码标准。

解决方案

通过使用 Polyspace 产品,HL Klemove 可在整个开发过程中发现缺陷和编码违规行为,因而提高了 ADAS/AD 软件质量。

MathWorks 应用工程师的协助下,HL Klemove 的工程师将 Polyspace 工具集成到了他们的 CI 工具链,其中包括用于 CI/CD 的 Atlassian Bamboo,以及用于 Git 存储库管理的 Bitbucket。他们创建了 Bamboo 作业来触发 Polyspace Bug Finder Server 自动执行静态代码分析,并将分析结果发布到 Polyspace Access 以进行基于 Web 的协同审查。为了简化项目管理,他们还将 Polyspace Access 与 Atlassian JIRA 相集成,使得在 Polyspace Access 中创建与 Polyspace 结果相关的工单成为了可能。

“Polyspace 使我们能够自动执行 ADAS 软件的静态代码分析,并将其集成到我们的 CI/CD 工作流中。从开发的最早阶段直到生产的整个过程中,Polyspace 都可以帮助我们查明并消除潜在的高成本问题,而这些问题是开发人员仅凭自己难以发现的。”

—— Minchae Lee,HL Klemove

在典型项目开发期间,工程师将代码更改推送到 Bitbucket。更新后的代码随后由 Polyspace Bug Finder Server 进行分析,作为计划的或手动触发的 Bamboo 作业的一部分。一旦静态代码分析完成,用户就会收到通知电子邮件,其中包含指向 Polyspace Access 网页中相应结果的链接。通过 Polyspace Access Web 浏览器界面,经理和工程师们可以一边查看代码的静态分析结果一边展开协作,这些代码可能是他们处理过的代码、其他团队生成的代码,或使用 Embedded Coder 从 Simulink 模型自动生成的代码。Polyspace Bug Finder Server 的结果包括运行时错误、并发问题,以及 MISRA 和 CERT C 编码标准违规行为。软件工程师关注由 Polyspace Bug Finder Server 生成的来自功能分支的结果,而开发运营一体化工程师则关注来自发布分支的结果。

为了缩短开发人员的反馈回路,多个团队最近已经开始在编码的同时,使用 Polyspace as You Code IDE 插件来检查代码质量。这样,在向 Bitbucket 提交代码更改之前,他们便可解决其中 MISRA 或 CERT C 不合规的问题了。

目前,HL Klemove 正将 Polyspace 产品应用于所有的 ADAS/AD 开发计划,其中涉及数十个项目和数百种量产车型。

结果

减少源代码验证时间。

Lee 表示,“使用 Polyspace Bug Finder,我们将源代码验证时间减少了高达 80%。而且,通过自动生成报告,我们将为 OEM 客户创建综合报告所需的时间,从长达一小时缩短至 10 分钟甚至更短。”

在开发过程的早期阶段发现缺陷。

Lee 表示:“Polyspace 让我们在开发过程的早期阶段即可发现、诊断并解决问题。这对我们来说至关重要,因为即使只有一个缺陷未被发现,也可能会导致安全召回,潜在成本高达数百万美元。”

符合 OEM 的编码要求和标准。

Lee 说道,“我们最大的一个客户是一家 OEM,他们现在要求所有供应商都要遵循编码规范,包括 MISRA 和 CERT C。Polyspace 使我们的团队能够满足这一要求,并生成报告来展示我们的代码验证结果。我们已收到了客户的积极反馈,他们认为我们能够满足不断变化的软件质量相关要求。”

审核编辑 :李倩

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

    关注

    307

    文章

    2060

    浏览量

    207856
  • 自动驾驶
    +关注

    关注

    773

    文章

    13060

    浏览量

    163240
  • 安全漏洞
    +关注

    关注

    0

    文章

    148

    浏览量

    16544

原文标题:提高软件质量,减少 ADAS 软件源代码验证时间

文章出处:【微信号:MATLAB,微信公众号:MATLAB】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    源代码审计怎么做?有哪些常用工具

    地匹配、查找。 2、Checkmax:通过虚拟编译器自动对软件源代码分析,并建立了代码元素及代码元素之间关系的逻辑图。 然后对这个内部代码
    发表于 01-17 09:35

    为什么安秉信息的源代码防泄密软件这么稳定?

    现在很多研发性企业都会意识到企业的源代码文件需要防泄密保护,现在很多企业对于源代码只是用了git或svn版本管理服务器进行了简单的代码统一管控。虽然现在对于源代码防泄密,有专业的
    的头像 发表于 12-05 10:21 212次阅读
    为什么安秉信息的<b class='flag-5'>源代码</b>防泄密<b class='flag-5'>软件</b>这么稳定?

    如何通过HIL测试系统做ADAS验证

    本文分享的是一个案例,借助NI开放式、数据驱动型、软件互连的生态系统以及PXI功能,采埃孚能够开发可扩展的ADAS HIL系统,在满足未来需求的同时与测试项目的步伐保持一致。 目前,采埃孚的ADAS HIL测试系统原型已复制至H
    的头像 发表于 11-27 09:52 306次阅读
    如何通过HIL测试系统做<b class='flag-5'>ADAS</b><b class='flag-5'>验证</b>

    什么是软件成分分析(SCA)?

    大家或许都发现了,开发人员愈发依赖开源代码来快速为其专有软件添加功能。据估计,开源代码占专有应用程序代码库的60-80%。相伴而来的,除了更高的效率,还有更高的风险。因此,管理开
    的头像 发表于 11-25 08:04 416次阅读
    什么是<b class='flag-5'>软件</b>成分分析(SCA)?

    基于MSP430的可倾斜读数的LED电子手表(软件源代码)

    电子发烧友网站提供《基于MSP430的可倾斜读数的LED电子手表(软件源代码).rar》资料免费下载
    发表于 11-10 10:36 0次下载
    基于MSP430的可倾斜读数的LED电子手表(<b class='flag-5'>软件</b><b class='flag-5'>源代码</b>)

    如何提高嵌入式软件单元测试效率

    在本指南中,您将学习如何通过在更短的时间内运行更多的测试来增加您的单元测试吞吐量。 这种效率的提高来自于使用虚拟平台而不是物理硬件作为开发平台。 本指南对任何开发或运行嵌入式软件单元测试的人都很
    发表于 08-28 06:31

    企业内部源代码加密软件方案

    企业源代码加密有两种类型的产品,根据客户需要的不同可以划分为以下两类:  1,需求是 反编译的,对于c# php等代码在编译过程中通过特定的编译器,对源代码进行混淆编译,防止编译后的文件
    的头像 发表于 08-25 10:16 513次阅读

    Synergy 软件质量手册

    Synergy 软件质量手册
    发表于 07-06 18:39 0次下载
    Synergy <b class='flag-5'>软件</b><b class='flag-5'>质量</b>手册

    分享几个根据源代码自动画流程图的工具软件

    小伙伴们平时阅读别人的代码,或者编写技术文档时,经常需要画流程图,如果有工具软件能够根据源代码自动绘制流程图,那将极大提升我们的效率。接下来,就介绍几款软件,看看有没有可以派上用场的…
    的头像 发表于 06-15 14:12 1w次阅读
    分享几个根据<b class='flag-5'>源代码</b>自动画流程图的工具<b class='flag-5'>软件</b>

    软件仿真、硬件仿真、原型验证是如何工作的?

    面对复杂的设计代码,我们如何确保其准确性?功能验证就是这场战斗的关键过程。工程师们通常使用的验证方法包括软件仿真、硬件仿真和原型验证等。这些
    的头像 发表于 06-11 14:24 535次阅读
    <b class='flag-5'>软件</b>仿真、硬件仿真、原型<b class='flag-5'>验证</b>是如何工作的?

    STC12C5A60S2 PCA软件PWM1源代码

    STC12C5A60S2-PCA-软件PWM1源代码
    发表于 05-18 09:58 1次下载

    STC单片机软件定时器例程源代码

    STC单片机软件定时器例程源代码
    发表于 05-17 15:07 0次下载

    基于51单片机的钟表(可矫正时间)例程源代码

    基于51单片机的钟表(可矫正时间)例程源代码
    发表于 05-16 11:09 0次下载

    嵌入式软件开发基本要素之代码质量

    IAR 的嵌入式开发解决方案涵盖了所有的嵌入式软件开发基本要素,增加了提高生产力和效率的价值,保证了质量,并加快了上市时间。这一切可以通过投资回报率(ROI)和总拥有成本(TCO)的用
    发表于 05-15 16:36 417次阅读
    嵌入式<b class='flag-5'>软件</b>开发基本要素之<b class='flag-5'>代码</b><b class='flag-5'>质量</b>

    如何将Arduino IDE中的源代码与ESP8266中的源代码进行比较?

    ,我不知道我实际使用的是哪个软件版本(我有几次尝试名为 xxxx_v1.ino、xxx_v2.ino 等。它是可能是版本号最高但不确定的那个……) 那么我可以从现有的 ESP8266 下载代码或校验码并将其与 Arduino IDE 中的现有
    发表于 05-11 07:11