详解汽车软件集成与分支管理

原创 水轻言 2024-09-25 07:00
本文摘编自《智能汽车电子与软件:开发方法、系统集成、流程体系与项目管理》,机械工业出版社出版,经出版方和作者授权发布,转载请标明文章来源。

首先,我们还是将汽车软件放在整车系统下来看。因此,我们会分离出3个层级的集成:

  • 软件组件集成。
  • 软件向硬件集成。
  • ECU向整车集成。



1

软件集成与分支划分


简单来说,软件集成就是创建一个边界明确、质量可靠的完整软件包。再扩充一些的话,就是基于源代码管理工具和分支管理策略,针对不同的单元(如.c或.h文件)逐级进行集成,并将相关的辅助文档、集成测试、配置文件等配置项进行配置管理。



1.1  “分支”的概念


由于汽车软件的平台化需求很高,所以,我们一般会进行“开发分支”和“交付分支”的区分。


  • 开发分支侧重于维护新特性的上线和通用性技术方案的导入

  • 交付分支则关心的是基于特定项目要求(如标定参数、项目配置参数、bug修复等)的释放。


二者的区分也可以让“开发的技术完善性”和“交付的时间及时性”不至于直接冲突和互相干扰


一般而言,软件集成的主要任务是识别、确认不同分支之间的公共组件,定义哪些组件应该从一条分支摘取到另一条分支上、哪些组件的变更需要单独释放以及哪个软件基线最终能够被用于哪个配置的交付上。



1.2 具体的集成


集成的策略取决于项目或平台释放的目的,而这又来源于项目的整体考量,所以,集成任务是需要项目经理类角色驱动的。简要集成流程如图1所示。


 

图1 软件集成简要流程


1.2.1 集成输入


尽管邮件也是一种输入,但对于繁杂的集成任务来说,通常最好使用ALM工作流类的工具来支撑,或是bug,或是变更,或是新特性需求,都可以通过相关工作项来驱动集成,比如,输入需求基线、变更范围、版本规则、工件、上一版本软件基线、交付日期等。


实际上,良好的集成更多来源于管理


1.2.2 编译、测试、打包


集成工程师在任务驱动下,去完成相应的源代码编译和相关错误清除,并完成必要的接口、资源消耗、冒烟等静动态集成测试。最后,根据预定规则,完成可执行文件、配置信息、测试报告、架构模型、设计文档、遗留问题、释放清单等的打包释放。此时,一个常规的集成任务就完成了。


1.2.3 软件配置管理


不管是集成组件选择,还是文件打包,其实都可以归属为配置管理这个大的概念,第3章我们从项目层面解释了配置管理,这里进入软件包里看,主要讲两部分。


(1) 软件版本号

软件的名字,也就是软件版本号,这是我们日常交流的主体对象,最基本的逻辑是一个版本号唯一对应一版代码


理论上,我们用V1、V2、V3也可以去描述软件,但为了增加软件的辨识度、可见性和交流的便利,我们会为软件版本号增加更多的信息,比如,项目名、车型名、客户名、硬件类别、芯片类别、架构类别、集成序列号、标定版本号、软件阶段(签名与否、适用工厂与否、ABCD级别等)等。


(2) 细化的分支概念

我们再细化讨论下分支的概念。注意,这是一个逻辑概念,并不真实存在。通俗理解,分支就是把组件的变更放在这个软件包里,而不是另一个,也就是不同的组件版本组合。


另外,前面我们说过可以把分支大体分为“开发分支”和“交付分支”。进一步地,二者都可以继续划分为更细化的分支概念,如图2所示。


 

图2 软件分支类型


1) 开发分支

“开发分支”可以细分为平台开发分支特性开发分支特定项目开发分支


  • 平台开发分支

平台开发分支是我们的平台化软件,是平台开发人员维护的、最具普适性的基础软件,是所有其他分支的源头,所有的变更、修改、提交应该严格审慎。如图3所示。


 

图3 平台开发分支示意图


  • 特性开发分支

特性开发分支一般是,经过普遍分析后,认为有必要导入到平台的特性开发或复杂bug修复,而且,这样的变更需要一定的周期和工作量。


为了避免影响到平台软件的日常维护,这时就有必要单独拉出来分支进行开发。在开发过程中,需要定期地将平台开发分支的变更进行同步,并在新特性释放后,合入平台开发分支,以保证平台开发分支的最新状态和完整性。如图4所示。


 

图4 特性开发分支示意图


  • 特定项目开发分支

对于特定项目开发分支来说,有些功能或特性的变更需求来源于特定项目,但需要动到平台开发分支,而由于其特殊性,又不需要永久合入平台开发分支的平台软件里,再加上二者团队的差异性,这时,就可以单独拉出来一个分支去完成这部分变更,但最终不会合入平台软件,而是合入到交付分支里。如图5所示。

 

图5 特定项目开发分支示意图


2) 交付分支

那么,“交付分支”也可以继续分为项目主干分支项目释放分支等。


接着看交付分支,交付分支的意义整体在于,既能基于平台化软件加速开发,又能保持一定的项目释放独特性与灵活性


  • 项目主干分支

对于项目主干分支来说,道理与平台开发分支类似,对于特定的车型类别或客户群项目,往往有更相近的需求,可以维护一条项目交付层级的“平台”软件


这条分支由项目团队精心维护,同时做好与平台的同步更新,保证其是一条构建和测试成功的“绿色“分支。如图6所示。


 

图6 项目主干分支示意图


  • 项目释放分支

而对于更多的项目变体,即项目释放分支,就能够以这条“绿色”的项目主干分支为交付基础,而高效地从中摘取软件基线,并完成自身的配置,比如,传感器、MCU、零件号等配置参数。如图7所示。


 

图7 项目释放分支示意图


值得说明的是,以上仅给出了一种分支拆分的思路,基本逻辑是平台化和定制化的权衡。实际上,有些产品与项目甚至不需要分支,只在一条分支上开发下去,具体项目需根据软件的成熟度和复杂性以及变体的多寡等来综合考虑合适的分支策略。




2

软件向硬件集成


在完整软件交付出来之后,我们要做的就是将软件刷写到ECU硬件中(具体刷写方式可能通过OBD口或USB或直接连接芯片针脚,或者通过远程OTA),这其实就是我们所要讲的系统(软硬件)集成


理论上讲,集成都是通过接口来完成的,系统集成也就是通过软硬件接口来进行,具体表现就是物理的芯片引脚和逻辑的传输数据的软件接口。如果开发流完整的话,这些接口应该在系统架构的部分进行过定义。


如果把系统集成再细分一些,我们再往上走,会有电路板与机械外壳、接插件、屏幕等的集成,只不过这步集成更多有着机械装配的意味,落在现实工作里就是打一批样件了。


当然,我们都知道一套完整的电控系统一般会包含传感器、ECU和执行器,处于中间的ECU是我们前述两步集成的结果。但传感器和执行器往往由外部其他组织提供,如果从系统的视角考虑,我们通过线束支撑的接口来完成这一级别的集成也是必要的。至少,内部开发中经常需要这样的环境来验证ECU的功能。




3

ECU向整车集成


整车集成基本是属于OEM的工作范围,也是它们的核心竞争力所在。


这一步的系统是从整车来看的,比如,驱动系统、刹车系统、转向系统、被动安全系统、照明系统、辅助驾驶系统等。


对于某一个电子控制器来说,在所有内部集成和验证完成后,必不可缺的一步是,在整车环境中完成布置确认、模态分析、传感信号校验、电子对手件联调、产线确认以及EMC、振动、冲击、水淋、盐雾、高低温等一系列的考验


对于软件来说,尤其要考虑对手件联调,越来越多的电子功能需要多模块协同,最常见的诊断、通信问题就是该环节频繁识别出来的。另外,很多在整车层面的属性性能也是需要在整车环境下进行软件标定匹配的。在汽车行业里做软件,要意识到,所有的代码其实都是最终服务于整车里的表现


但是,我们也要知道,我们并不期望在整车集成环节解决软件问题。毕竟,一台试验车动辄几十上百万,有些试验甚至是整车破坏性的,整车试验的成本通常都会比较高。当软件问题从开发团队一路逃逸到这个环节时,往往会带来比较大的成本。


关注公众号,点击公众号主页右上角“ ··· ”,设置星标,实时获取公众号“水轻言”最新文章。




延伸阅读:

以上是分享的节选内容,更多精彩内容,可以通过以下链接购买本书(全网正版最低价):

水轻言 致力于汽车软件研发管理。
评论
  • 自动化已成为现代制造业的基石,而驱动隔离器作为关键组件,在提升效率、精度和可靠性方面起到了不可或缺的作用。随着工业技术不断革新,驱动隔离器正助力自动化生产设备适应新兴趋势,并推动行业未来的发展。本文将探讨自动化的核心趋势及驱动隔离器在其中的重要角色。自动化领域的新兴趋势智能工厂的崛起智能工厂已成为自动化生产的新标杆。通过结合物联网(IoT)、人工智能(AI)和机器学习(ML),智能工厂实现了实时监控和动态决策。驱动隔离器在其中至关重要,它确保了传感器、执行器和控制单元之间的信号完整性,同时提供高
    腾恩科技-彭工 2025-01-03 16:28 123浏览
  • 从无到有:智能手机的早期探索无线电话装置的诞生:1902 年,美国人内森・斯塔布菲尔德在肯塔基州制成了第一个无线电话装置,这是人类对 “手机” 技术最早的探索。第一部移动手机问世:1938 年,美国贝尔实验室为美国军方制成了世界上第一部 “移动” 手机。民用手机的出现:1973 年 4 月 3 日,摩托罗拉工程师马丁・库珀在纽约曼哈顿街头手持世界上第一台民用手机摩托罗拉 DynaTAC 8000X 的原型机,给竞争对手 AT&T 公司的朋友打了一个电话。这款手机重 2 磅,通话时间仅能支持半小时
    Jeffreyzhang123 2025-01-02 16:41 156浏览
  • 车身域是指负责管理和控制汽车车身相关功能的一个功能域,在汽车域控系统中起着至关重要的作用。它涵盖了车门、车窗、车灯、雨刮器等各种与车身相关的功能模块。与汽车电子电气架构升级相一致,车身域发展亦可以划分为三个阶段,功能集成愈加丰富:第一阶段为分布式架构:对应BCM车身控制模块,包含灯光、雨刮、门窗等传统车身控制功能。第二阶段为域集中架构:对应BDC/CEM域控制器,在BCM基础上集成网关、PEPS等。第三阶段为SOA理念下的中央集中架构:VIU/ZCU区域控制器,在BDC/CEM基础上集成VCU、
    北汇信息 2025-01-03 16:01 134浏览
  • 【工程师故事】+半年的经历依然忧伤,带着焦虑和绝望  对于一个企业来说,赚钱才是第一位的,对于一个人来说,赚钱也是第一位的。因为企业要活下去,因为个人也要活下去。企业打不了倒闭。个人还是要吃饭的。企业倒闭了,打不了从头再来。个人失业了,面对的不仅是房贷车贷和教育,还有找工作的焦虑。企业说,一个公司倒闭了,说明不了什么,这是正常的一个现象。个人说,一个中年男人失业了,面对的压力太大了,焦虑会摧毁你的一切。企业说,是个公司倒闭了,也不是什么大的问题,只不过是这些公司经营有问题吧。
    curton 2025-01-02 23:08 225浏览
  • 影像质量应用于多个不同领域,无论是在娱乐、医疗或工业应用中,高质量的影像都是决策的关键基础。清晰的影像不仅能提升观看体验,还能保证关键细节的准确传达,例如:在医学影像中,它对诊断结果有着直接的影响!不仅如此,影像质量还影响了:▶ 压缩技术▶ 存储需求▶ 传输效率随着技术进步,影像质量的标准不断提高,对于研究与开发领域,理解并提升影像质量已成为不可忽视的重要课题。在图像处理的过程中,硬件与软件除了各自扮演着不可或缺的基础角色,有效地协作能够确保图像处理过程既高效又具有优异的质量。软硬件各扮演了什么
    百佳泰测试实验室 2025-01-03 10:39 83浏览
  • 物联网(IoT)的快速发展彻底改变了从智能家居到工业自动化等各个行业。由于物联网系统需要高效、可靠且紧凑的组件来处理众多传感器、执行器和通信设备,国产固态继电器(SSR)已成为满足中国这些需求的关键解决方案。本文探讨了国产SSR如何满足物联网应用的需求,重点介绍了它们的优势、技术能力以及在现实场景中的应用。了解物联网中的固态继电器固态继电器是一种电子开关设备,它使用半导体而不是机械触点来控制负载。与传统的机械继电器不同,固态继电器具有以下优势:快速切换:确保精确快速的响应,这对于实时物联网系统至
    克里雅半导体科技 2025-01-03 16:11 124浏览
  • 前言近年来,随着汽车工业的快速发展,尤其是新能源汽车与智能汽车领域的崛起,汽车安全标准和认证要求日益严格,应用范围愈加广泛。ISO 26262和ISO 21448作为两个重要的汽车安全标准,它们在“系统安全”中扮演的角色各自不同,但又有一定交集。在智能网联汽车的高级辅助驾驶系统(ADAS)应用中,理解这两个标准的区别及其相互关系,对于保障车辆的安全性至关重要。ISO 26262:汽车功能安全的基石如图2.1所示,ISO 26262对“功能安全”的定义解释为:不存在由于电子/电气系统失效引起的危害
    广电计量 2025-01-02 17:18 195浏览
  • 光耦合器,也称为光隔离器,是一种利用光在两个隔离电路之间传输电信号的组件。在医疗领域,确保患者安全和设备可靠性至关重要。在众多有助于医疗设备安全性和效率的组件中,光耦合器起着至关重要的作用。这些紧凑型设备经常被忽视,但对于隔离高压和防止敏感医疗设备中的电气危害却是必不可少的。本文深入探讨了光耦合器的功能、其在医疗应用中的重要性以及其实际使用示例。什么是光耦合器?它通常由以下部分组成:LED(发光二极管):将电信号转换为光。光电探测器(例如光电晶体管):检测光并将其转换回电信号。这种布置确保输入和
    腾恩科技-彭工 2025-01-03 16:27 114浏览
  • 在测试XTS时会遇到修改产品属性、SElinux权限、等一些内容,修改源码再编译很费时。今天为大家介绍一个便捷的方法,让OpenHarmony通过挂载镜像来修改镜像内容!触觉智能Purple Pi OH鸿蒙开发板演示。搭载了瑞芯微RK3566四核处理器,树莓派卡片电脑设计,支持开源鸿蒙OpenHarmony3.2-5.0系统,适合鸿蒙开发入门学习。挂载镜像首先,将要修改内容的镜像传入虚拟机当中,并创建一个要挂载镜像的文件夹,如下图:之后通过挂载命令将system.img镜像挂载到sys
    Industio_触觉智能 2025-01-03 11:39 84浏览
  • 本文继续介绍Linux系统查看硬件配置及常用调试命令,方便开发者快速了解开发板硬件信息及进行相关调试。触觉智能RK3562开发板演示,搭载4核A53处理器,主频高达2.0GHz;内置独立1Tops算力NPU,可应用于物联网网关、平板电脑、智能家居、教育电子、工业显示与控制等行业。查看系统版本信息查看操作系统版本信息root@ido:/# cat /etc/*releaseDISTRIB_ID=UbuntuDISTRIB_RELEASE=20.04DISTRIB_CODENAME=focalDIS
    Industio_触觉智能 2025-01-03 11:37 97浏览
  •  在这个日新月异的科技时代,智能家居正以前所未有的速度融入我们的日常生活,从智能灯光到温控系统,从安防监控到语音助手,每一处细节都透露着科技的温度与智慧。而在这场智能化浪潮中,一个看似不起眼却至关重要的组件——晶体管光耦,正扮演着连接物理世界与数字世界的隐形桥梁角色,默默推动着智能家居行业的发展与革新。 晶体管光耦——智能家居的“神经递质”晶体管光耦,作为一种能够将电信号转换为光信号,再通过光信号控制另一侧电路开关的电子元器件,其独特的工作原理使得它在隔离传输、抗干扰及保护电
    晶台光耦 2025-01-02 16:19 129浏览
  • 在快速发展的能源领域,发电厂是发电的支柱,效率和安全性至关重要。在这种背景下,国产数字隔离器已成为现代化和优化发电厂运营的重要组成部分。本文探讨了这些设备在提高性能方面的重要性,同时展示了中国在生产可靠且具有成本效益的数字隔离器方面的进步。什么是数字隔离器?数字隔离器充当屏障,在电气上将系统的不同部分隔离开来,同时允许无缝数据传输。在发电厂中,它们保护敏感的控制电路免受高压尖峰的影响,确保准确的信号处理,并在恶劣条件下保持系统完整性。中国国产数字隔离器经历了重大创新,在许多方面达到甚至超过了全球
    克里雅半导体科技 2025-01-03 16:10 80浏览
  • Matter加持:新世代串流装置如何改变智能家居体验?随着现在智能家庭快速成长,串流装置(Streaming Device,以下简称Streaming Device)除了提供更卓越的影音体验,越来越多厂商开始推出支持Matter标准的串流产品,使其能作为智能家庭中枢,连结多种智能家电。消费者可以透过Matter的功能执行多样化功能,例如:开关灯、控制窗帘、对讲机开门,以及操作所有支持Matter的智能家电。此外,再搭配语音遥控器与语音助理,打造出一个更加智能、便捷的居家生活。支持Matter协议
    百佳泰测试实验室 2025-01-03 10:29 102浏览
  • 在科技飞速发展的今天,机器人已经逐渐深入到我们生活和工作的各个领域。从工业生产线上不知疲倦的机械臂,到探索未知环境的智能探测机器人,再到贴心陪伴的家用服务机器人,它们的身影无处不在。而在这些机器人的背后,C 语言作为一种强大且高效的编程语言,发挥着至关重要的作用。C 语言为何适合机器人编程C 语言诞生于 20 世纪 70 年代,凭借其简洁高效、可移植性强以及对硬件的直接操控能力,成为机器人编程领域的宠儿。机器人的运行环境往往对资源有着严格的限制,需要程序占用较少的内存和运行空间。C 语言具有出色
    Jeffreyzhang123 2025-01-02 16:26 140浏览
  • 国际标准IPC 标准:IPC-A-600:规定了印刷电路板制造过程中的质量要求和验收标准,涵盖材料、外观、尺寸、焊接、表面处理等方面。IPC-2221/2222:IPC-2221 提供了用于设计印刷电路板的一般原则和要求,IPC-2222 则针对高可靠性电子产品的设计提供了进一步的指导。IPC-6012:详细定义了刚性基板和柔性基板的要求,包括材料、工艺、尺寸、层次结构、特征等。IPC-4101:定义了印刷电路板的基板材料的物理和电气特性。IPC-7351:提供了元件封装的设计规范,包括封装尺寸
    Jeffreyzhang123 2025-01-02 16:50 174浏览
我要评论
0
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦