小公司如何使用”AUTOSAR”?

原创 汽车电子与软件 2024-04-26 07:46

作者 | 贲月亭
出品 | 汽车电子与软件



#01  

中小企业为什么对AUTOSAR望而却步?



天下苦于AUTOSAR久矣,苦于Vector久矣!


AUTOSAR从成立至今已20多年,如今AUTOSAR已在汽车开发领域渗透率极高,很多汽车电子企业也都“无脑”运用AUTOSAR,以在产品宣传时能够体现自己的“高大上”,行业内从业者若没接触过AUTOSAR似乎都觉得自己落伍快被行业淘汰一样。然而当今市面AUTOSAR服务商总是给人“价格高、技术门槛高”等诸多印象,主流服务商Vector价格也确实高达几百万、上千万,即使国内AUTOSAR服务商东软睿驰、普华、恒润等价格也得数百万。现实的价格及人力资源投入等因素,使得很多中小企业对于AUTOSAR只能望而却步。


AUTOSAR作为全球标准的软件架构技术,它的作用不仅仅是定义了汽车电子产品中各个模块及接口的设计规范,更多地传递了软件架构设计的思想和理念。本文将利用AUTOSAR软件架构思想,提供小公司简化可实施“AUTOSAR”解决方案。本文呼吁各企业和从业的软件工程师们从软件本质出发、从思想出发,去建立和完善公司的软件产品。


本人接触AUTOSAR时间并不长,将学习AUTOSAR过程中一点心得用于分享,由于本人水平有限,本文仅为个人一己之见,不足之处还望大家批评指正,共同学习,一起成长;



#02 

什么是AUTOSAR?



如何使用AUTOSAR,首先需要搞明白AUTOSAR的基本内容,其次设计符合自己公司的软件架构。



2.1 背景


在汽车领域,人们对电子化的要求逐渐变高,汽车电子成本占据整车费用的份额越来越高。随着EE架构逐渐趋于集中化,汽车软件系统出现了多种操作系统并存的局面,导致系统复杂性、开发成本的剧增。为了提高软件的管理性、移植性、裁剪性及质量,需要定义一套架构、方法和应用接口以实现标准的接口、高质量的无缝集成、高效的开发以及通过新的模型来管理复杂的系统。

AUTOSAR(Automotive Open System Architecture)联盟最初是在由9家汽车行业的巨头(宝马、博世、大陆、戴姆勒、福特、通用、PSA、丰田、大众)成立,截至目前行业内已高达300多家企业或组织加入AUTOSAR,共同参与制定了汽车电子系统的合作开发架构,该架构旨在改善汽车电子系统软件的更新与交换,同时更方便有效地管理日趋复杂的汽车电子软件系统。AUTOSAR规范的运用使得不同结构的电子控制单元的接口特征标准化,应用软件具备更好的可扩展性以及可移植性,能够实现对现有软件的重用,大大降低了重复性工作,缩短开发周期。自成立以来,AUTOSAR一直致力于为汽车行业开发和引入开放且标准化的软件架构,尤其在汽车智能化领域,发挥着越来越重要的作用,是目前世界上最具影响力的汽车电子软件全球合作联盟。


2.2 Classic Platform AUTOSAR


AUTOSAR分为Classic Platform AUTOSAR(CP)和Adaptive Platform AUTOSAR(AP)两个平台。经典平台CP是用于众多汽车电子控制单元(ECU)的AUTOSAR架构,目前已广泛应用于传统嵌入式ECU中,如发动机控制器、电机控制器、整车控制器、BMS控制器等等。其次,自适应平台AP是随着近年来汽车信息娱乐系统的发展而兴起的一种AUTOSAR架构。这种架构主要应用在带有高级操作系统(如Linux或QNX)的车载系统级芯片(SoC)上,未来会更多地应用于如ADAS、自动驾驶等需求高计算能力、高带宽通信、分布式部署的下一代汽车应用领域中。这两种分类代表了AUTOSAR软件在汽车工业中的不同应用场景和需求。


本文中主要研究AUTOSAR CP。


AUTOSAR CP架构定义设计了三个软件层:以运行时环境层RTE(Runtime Environment)为界,隔离上层的应用层ASW(Application Layer)与下层的基础软件BSW(Basic Software)。其中BSW进一步定义成为服务层(Service Layer)、ECU抽象层(ECU Abstraction Layer)、微控制器抽象层(MicroController Abstraction Layer,即MCAL)和复杂驱动层(Complex Drivers Layer,即CCD)。


图1 AUTOSAR分层架构


每个软件层可以进一步按照功能分成模块块组,每个模块组都包含相应的模块。如服务层(Service Layer)包含通讯服务组(Communication Services),该组中包含Com、Dcm、PduR等模块。

图2 AUTOSAR模块

2.3 开发方法论


AUTOSAR的出现革新了汽车软件的开发流程,形成了囊括OEM主机厂、Tier1、中间件厂商等在内的开发流程。


图3  图片来源:华泰研究


OEM进行逻辑系统和物理系统的设计(定义EE架构网络结构、总线配置、传输的信息单元,将整车设计的不同功能分配到 ECU上)并生成配置文件ARXML,提供SWC系统模型和通信矩阵,交付给Tier1。


图4  零部件软件开发


Tier1则基于OEM需求进行ECU的设计开发。Tier1可以通过直接购买AUTOSAR方案,只需要通过配置工具按照需求和硬件方案进行相应的配置,包括根据配置开发软件SWC的接口设计,对不同ECU的数据映射,生成RTE、BSW、SWC Template代码,可以极大的缩减软件开发时间,并保障基础软件的质量。Tier1则在生成代码框架基础上将精力花在产品功能开发,调试等。



#03

如何设计小公司的“AUTOSAR”?



天下苦于AUTOSAR久矣,苦于Vector久矣

,揭开AUTOSAR的面纱,小企业也能轻松使用“AUTOSAR”

AUTOSAR的本质目的即为软件的通用性。


小公司往往涉及产品比较杂,面对的客户较多,各种五花八门的需求都需要应和,且小公司往往容易追求短期利益,在不断降本道路上老是喜欢主芯片切来切去,一发现某家公司推出新的性价比的芯片,就迫不及待的进行切换,此外,芯片国产化也催生了各种各样的芯片在小公司的运用变得非常普遍。那小公司到底应该是什么样的AUTOSAR?


小公司依然需要以软件通用性为设计原则,只要坚持软件通用性为原则的软件,我们即可称为“AUTOSAR”

,当然各自公司可以重新自己拟个名称就行了,并非非得都叫“AUTOSAR”,

该软件可以无论什么产品、无论客户什么需求、无论芯片怎么换,在本公司内都能够轻松应对,同时兼备很好的便捷性、维护性、迭代性,那一定是非常优秀的软件。



3.1 分层架构设计



图5 分层架构设计


本着简单实用的原则,共设计4层架构:


·APPL:软件功能层面的相关模块处理,与产品功能息息相关,包含信号指令处理、功能逻辑判断等;类似AUTOSAR中的ASW层软件内容。


·MIDL:包含操作系统、诊断、故障等通用功能的处理,与产品功能没有直接关系;类似AUTOSAR中的Services层软件内容。


·LOWL:将底层模块抽象化,与MCU没有直接关系;类似AUTOSAR中的ECU Abstraction Layer层软件内容。


·MCAL:与芯片直接相关的驱动软件部分,该软件往往直接由芯片厂提供。这里指的MCAL并不要求芯片厂商提供的底层代码按照相应的标准软件规范执行,当然对于企业来讲,如果芯片厂商提供的Demo软件无法看,更好的软件质量管控最好底层代码最好还是自己来写。


与AUTOSAR相比,本架构设计从顶层设计上去除了CDD复杂驱动和RTE,因为对于个体公司而言,整个APPL,MIDL,LOWL都为自主研发设计,并无必要严格的区分复杂驱动部分。关于RTE的解释请看下个小节说明。


对公司而言,需要确保APPL、MIDL、LOWL在切换产品、切换芯片、切换需求等等变化中,都能保障软件结构的稳定,软件接口的稳定,那这样的软件即为公司自己的“AUTOSAR”。



3.2 模块设计


小公司在设计软件时,需要更多地考虑

轻便和易用

,需要结合公司自身实际情况进行模块设计。如下图仅是列出了部分常用的设计模块。


图6  “AUTOSAR”模块


图中APPL模块“XXX”代表公司与产品相关的功能模块,各公司可以自行定义。



3.2.1 通讯功能


这边的通讯模块设计与AUTOSAR中很大的区别是去除了PduR模块,PduR的功能则由Com承担;当然我们很多产品并不需要复杂的消息路由功能,Com收到消息时,仅需判断Id信息,即可再分发给AppCom,Uds或者Nm等;



图7  通讯功能


·CanIf与LinIf:底层的抽象,设计通用的Can与Lin接口


·Com:消息分发,通讯控制,信号解析提供信号接口等


·AppCom:读写消息接口



3.2.2 诊断功能

 

图8  诊断功能


·CanIf与LinIf:底层的抽象,设计通用的Can与Lin接口


·Com:识别诊断消息,分发给Tp模块


·Tp:诊断消息的拆包与封装处理


·Uds:UDS协议(类似AUTOSAR中Dcm模块)


·Fault:故障处理(类似AUTOSAR中Det模块)


·AppDiag:读写诊断指令接口



3.2.3 模块关系


清晰的架构需要遵守相应的调用关系,然而实际中,我们经常容易看到混乱一大堆的去随意引用头文件,虽然编译器会帮忙处理背后的关系,但是实际是软件架构的紊乱。


本软件设计中,并未像AUTOSAR一样,设计隔离Asw与Bsw的RTE, RTE的思想渗透到每个模块,每个模块都带有Rte.h,文件,无论是应用层软件还是底层软件。


图9  模块与模块之间的调用关系

实际运用时,可以只需要在该Module的Rte头文件中包含必要的.h文件,及使用extern关键词引用相应的接口函数或者配置即可。这样可以极大避免模块之间的紊乱的调用关系。


此外本架构中,仅设计了一个Cfg.h和Cfg.c文件,没有像AUTOSAR中区分了Pre-compile、Link和Post-build三种类型的配置形式,这样也极大简化了模块设计复杂度。


图11  子模块之间的调用关系


后言:


·我倾向于从物理框架来研究事物。我们运用第一性原理,而不是类比思维去思考问题,是非常重要的

——埃隆·马斯克


·道生一,一生二,二生三,三生万物

——老子《道德经》

    

在软件学习过程中,非常喜欢的两句话分享给大家,期望大家设计软件架构时,从需求出发、从模块属性出发,多动脑筋,多思考,一定能设计出优秀的模块。


最后,非常感谢大家的阅读,本文中在介绍AUTOSAR部分大量采用的网上现有的资料,有些并无标注出处,若有侵权还望及时提醒删除。


作者:

贲月亭,汽车行业软件开发



参考资料:

[1] AUTOSAR R22-11. AUTOSAR_EXP_LayeredSoftwareArchitecture. 


汽车电子与软件 主要介绍汽车电子软件设计相关内容,每天分享一篇技术文章!
评论
  • 应用趋势与客户需求,AI PC的未来展望随着人工智能(AI)技术的日益成熟,AI PC(人工智能个人电脑)逐渐成为消费者和企业工作中的重要工具。这类产品集成了最新的AI处理器,如NPU、CPU和GPU,并具备许多智能化功能,为用户带来更高效且直观的操作体验。AI PC的目标是提升工作和日常生活的效率,通过深度学习与自然语言处理等技术,实现更流畅的多任务处理、实时翻译、语音助手、图像生成等功能,满足现代用户对生产力和娱乐的双重需求。随着各行各业对数字转型需求的增长,AI PC也开始在各个领域中显示
    百佳泰测试实验室 2025-02-27 14:08 255浏览
  • 美国加州CEC能效跟DOE能效有什么区别?CEC/DOE是什么关系?美国加州CEC能效跟DOE能效有什么区别?CEC/DOE是什么关系?‌美国加州CEC能效认证与美国DOE能效认证在多个方面存在显著差异‌。认证范围和适用地区‌CEC能效认证‌:仅适用于在加利福尼亚州销售的电器产品。CEC认证的范围包括制冷设备、房间空调、中央空调、便携式空调、加热器、热水器、游泳池加热器、卫浴配件、光源、应急灯具、交通信号模块、灯具、洗碗机、洗衣机、干衣机、烹饪器具、电机和压缩机、变压器、外置电源、消费类电子设备
    张工nx808593 2025-02-27 18:04 120浏览
  • 更多生命体征指标风靡的背后都只有一个原因:更多人将健康排在人生第一顺位!“AGEs,也就是晚期糖基化终末产物,英文名Advanced Glycation End-products,是存在于我们体内的一种代谢产物” 艾迈斯欧司朗亚太区健康监测高级市场经理王亚琴说道,“相信业内的朋友都会有关注,最近该指标的热度很高,它可以用来评估人的生活方式是否健康。”据悉,AGEs是可穿戴健康监测领域的一个“萌新”指标,近来备受关注。如果站在学术角度来理解它,那么AGEs是在非酶促条件下,蛋白质、氨基酸
    艾迈斯欧司朗 2025-02-27 14:50 400浏览
  • 一、VSM的基本原理震动样品磁强计(Vibrating Sample Magnetometer,简称VSM)是一种灵敏且高效的磁性测量仪器。其基本工作原理是利用震动样品在探测线圈中引起的变化磁场来产生感应电压,这个感应电压与样品的磁矩成正比。因此,通过测量这个感应电压,我们就能够精确地确定样品的磁矩。在VSM中,被测量的样品通常被固定在一个震动头上,并以一定的频率和振幅震动。这种震动在探测线圈中引起了变化的磁通量,从而产生了一个交流电信号。这个信号的幅度和样品的磁矩有着直接的关系。因此,通过仔细
    锦正茂科技 2025-02-28 13:30 100浏览
  • RGB灯光无法同步?细致的动态光效设定反而成为产品客诉来源!随着科技的进步和消费者需求变化,电脑接口设备单一功能性已无法满足市场需求,因此在产品上增加「动态光效」的形式便应运而生,藉此吸引消费者目光。这种RGB灯光效果,不仅能增强电脑周边产品的视觉吸引力,还能为用户提供个性化的体验,展现独特自我风格。如今,笔记本电脑、键盘、鼠标、鼠标垫、耳机、显示器等多种电脑接口设备多数已配备动态光效。这些设备的灯光效果会随着音乐节奏、游戏情节或使用者的设置而变化。想象一个画面,当一名游戏玩家,按下电源开关,整
    百佳泰测试实验室 2025-02-27 14:15 137浏览
  • 在物联网领域中,无线射频技术作为设备间通信的核心手段,已深度渗透工业自动化、智慧城市及智能家居等多元场景。然而,随着物联网设备接入规模的不断扩大,如何降低运维成本,提升通信数据的传输速度和响应时间,实现更广泛、更稳定的覆盖已成为当前亟待解决的系统性难题。SoC无线收发模块-RFM25A12在此背景下,华普微创新推出了一款高性能、远距离与高性价比的Sub-GHz无线SoC收发模块RFM25A12,旨在提升射频性能以满足行业中日益增长与复杂的设备互联需求。值得一提的是,RFM25A12还支持Wi-S
    华普微HOPERF 2025-02-28 09:06 143浏览
  •         近日,广电计量在聚焦离子束(FIB)领域编写的专业著作《聚焦离子束:失效分析》正式出版,填补了国内聚焦离子束领域实践性专业书籍的空白,为该领域的技术发展与知识传播提供了重要助力。         随着芯片技术不断发展,芯片的集成度越来越高,结构也日益复杂。这使得传统的失效分析方法面临巨大挑战。FIB技术的出现,为芯片失效分析带来了新的解决方案。它能够在纳米尺度上对芯片进行精确加工和分析。当芯
    广电计量 2025-02-28 09:15 116浏览
  • Matter 协议,原名 CHIP(Connected Home over IP),是由苹果、谷歌、亚马逊和三星等科技巨头联合ZigBee联盟(现连接标准联盟CSA)共同推出的一套基于IP协议的智能家居连接标准,旨在打破智能家居设备之间的 “语言障碍”,实现真正的互联互通。然而,目标与现实之间总有落差,前期阶段的Matter 协议由于设备支持类型有限、设备生态协同滞后以及设备通信协议割裂等原因,并未能彻底消除智能家居中的“设备孤岛”现象,但随着2025年的到来,这些现象都将得到完美的解决。近期,
    华普微HOPERF 2025-02-27 10:32 214浏览
  •           近日受某专业机构邀请,参加了官方举办的《广东省科技创新条例》宣讲会。在与会之前,作为一名技术工作者一直认为技术的法例都是保密和侵权方面的,而潜意识中感觉法律有束缚创新工作的进行可能。通过一个上午学习新法,对广东省的科技创新有了新的认识。广东是改革的前沿阵地,是科技创新的沃土,企业是创新的主要个体。《广东省科技创新条例》是广东省为促进科技创新、推动高质量发展而制定的地方性法规,主要内容包括: 总则:明确立法目
    广州铁金刚 2025-02-28 10:14 103浏览
  • 振动样品磁强计是一种用于测量材料磁性的精密仪器,广泛应用于科研、工业检测等领域。然而,其测量准确度会受到多种因素的影响,下面我们将逐一分析这些因素。一、温度因素温度是影响振动样品磁强计测量准确度的重要因素之一。随着温度的变化,材料的磁性也会发生变化,从而影响测量结果的准确性。因此,在进行磁性测量时,应确保恒温环境,以减少温度波动对测量结果的影响。二、样品制备样品的制备过程同样会影响振动样品磁强计的测量准确度。样品的形状、尺寸和表面处理等因素都会对测量结果产生影响。为了确保测量准确度,应严格按照规
    锦正茂科技 2025-02-28 14:05 134浏览
  • 在2024年的科技征程中,具身智能的发展已成为全球关注的焦点。从实验室到现实应用,这一领域正以前所未有的速度推进,改写着人类与机器的互动边界。这一年,我们见证了具身智能技术的突破与变革,它不仅落地各行各业,带来新的机遇,更在深刻影响着我们的生活方式和思维方式。随着相关技术的飞速发展,具身智能不再仅仅是一个技术概念,更像是一把神奇的钥匙。身后的众多行业,无论愿意与否,都像是被卷入一场伟大变革浪潮中的船只,注定要被这股汹涌的力量重塑航向。01为什么是具身智能?为什么在中国?最近,中国具身智能行业的进
    艾迈斯欧司朗 2025-02-28 15:45 221浏览
  • 1,微软下载免费Visual Studio Code2,安装C/C++插件,如果无法直接点击下载, 可以选择手动install from VSIX:ms-vscode.cpptools-1.23.6@win32-x64.vsix3,安装C/C++编译器MniGW (MinGW在 Windows 环境下提供类似于 Unix/Linux 环境下的开发工具,使开发者能够轻松地在 Windows 上编写和编译 C、C++ 等程序.)4,C/C++插件扩展设置中添加Include Path 5,
    黎查 2025-02-28 14:39 140浏览
我要评论
0
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦