聊一聊汽车控制器的启动——BOOT

汽车ECU开发 2023-02-02 08:48



一、BOOT来源


你有没有遇到过电脑新安装了软件,然后提示你Reboot的场景?这里的Reboot,大家都知道是重启,而Boot就是启动的意思。但你有没有想过为什么电脑启动会叫做Boot? Boot不是靴子吗?

Boot作为启动术语的来源确实与靴子有关。因为计算机的启动都是从硬件上电开始的,此时软件还没工作,需要一个引导程序把它拉起来。而拉起软件的动作又需要软件自身的启动和运行,这个过程就很像一句英文谚语:


Pull oneself up by one's bootstraps.


意思是通过鞋带把自己提起来,寓意自食其力,靠自己振作起来。由于两者思想如出一辙,计算机发展初期就把启动的引导程序称作BootStrap Loader,或BootloaderBoot

 

1:用鞋带把自己拉起来的示意图



二、Bootloader简介


Bootloader,又称为引导程序,对操作系统非常重要,是计算机和汽车控制器的一个关键组成部分。然而,因为它往往在后台发挥作用,它经常被忽视。那么Bootloader的具体工作原理是怎样的呢?我们以下图中的PIC16单片机作为例子来具体看看。

按单片机设计,芯片通电后就会从Flash0x000地址开始执行指令,也就是说芯片上电后,第一行代码就从0X000开始执行。如左所示,用户可以通过UART串口将整个用户程序烧录到Flash上,这样整个存储区都可以用于用户程序。但是每次烧写都很麻烦。如右所示,如果在0X000开始布置三行指令,用于跳转到Bootloader区(即下图右方的跳转1),然后在0XF00区域开始执行Bootloader引导程序,正常启动时,Bootloader执行完会再跳转到用户程序(即下图右方的跳转2)。在Bootloader程序中,可以进行特殊的开发例程或者刷写新的用户程序,这样对开发和刷写都更加友好。

 2Bootloader示意图


不同处理器的具体Bootloader细节略有差异,但是整体逻辑和思路都是相同的。例如对于电脑上的CPUBootloader还会初始化硬件,将操作系统内核从硬盘加载到内存,再将操作系统从加载到内存,然后操作系统会进一步将需要运行的应用程序从硬盘加载到内存中执行。总的来说,就是处理器硬件启动后自动执行的第一行代码会跳转到Bootloader,然后再由Bootloader引导执行用户代码。


三、Flash Bootloader


如上文所述,Bootloader的优势主要是为用户软件的刷写提供便利性。而汽车上传统的控制器都是高度嵌入式系统,而且各个控制器从开发到量产到售后都有软件更新的需求,Bootloader刚好就能用来完成刷写控制器软件的任务。这个以刷写更新软件为目的的Bootloader在汽车行业就被广泛称之为Flash BootloaderFBL)。它主要用于MCU等传统嵌入式系统的软件刷写。


实际上,Flash Bootloader应该算是Bootloader引导后的第二道程序。第一道被引导起来的Bootloader会判断ECU状态,再根据这个状态来拉起应用程序或者进入Flash Bootloader。由于简略表达或者概念模糊,在实际工作场合中很多时候都会听到有人把BootloaderFlash Bootloader混为一谈。我们可以根据场合保持沟通的连贯性,但心里应该清晰区分两者的区别。


在汽车行业的实际应用中,Bootloader还常细分为Primary BootloaderPBL)和Secondary BootloaderSBL)。其中SBL更加接近于Flash Bootloader。下图是一种常见的PBLSBLMCU存储器的关系示意图。

3Flash Bootloader与内存关系示意框图


PBL的作用是在应用软件有效时引导它。PBL存储在MCU芯片的Flash,它一般是产品出厂时一次性刷好的,芯片上电或重启后,第一批执行的代码就是PBL。需要刷写软件时,PBL可以通过统一诊断服务(UDS),基于CAN或以太网等底层总线协议与外界诊断仪通信。在校核完诊断仪的权限后,PBL会将诊断仪上的SBL下载到MCU的内存RAM上,然后由SBL进行刷写。SBL包含PBL提供的所有服务以及闪存驱动器(Flash Driver和一些额外的UDS服务。通过UDS触发,SBL会利用Flash Driver擦除旧软件,并把新软件写到对应的存储区。具体流程如下图4所示:


4MCU刷写流程示意图


为了避免应用软件被意外误刷写或者删除,PBL中一般不包含Flash Driver,不能直接操作闪存。每次刷写时,包含Flash DriverSBL都会从诊断仪中重新加载到内存。这种PBLSBL的分工方案,有这些好处:


1.平时防止应用软件被误刷写。


2.提高网络安全性。每次从诊断仪下载SBL时,都可以通过安全鉴权机制,确保合法的诊断仪才能触发刷写。

3.通过SBL还能反向刷写更新PBL,提高了Bootloader的整体灵活度。



四、SoC的启动和刷写


上面说的Flash Bootloader是针对传统高度嵌入式系统的。但相信各位汽车同仁也感受到,越来越多的高性能计算芯片正在汽车上普及,汽车中央电脑等方案也是不绝于耳。对于这些高性能计算芯片,行业内常以SoCSystem on Chip)相称。SoC的启动和刷写方案和MCU如出一辙,但由于其内部存储管理系统和内部总线更加复杂,启动的具体实现与MCU略有差异,其细节更接近于我们熟悉的个人电脑。总体的启动流程如下图所示。


5BIOSUEFI启动流程示意图


传统计算机的启动一般采用上图上部分的BIOS启动。BISOBasic Input Output System的缩写,是计算机硬件与软件第一次相遇的地方。BIOS的代码通常被嵌入到电脑的主板的EEPROM中。BIOS可以完成计算机上电后的基本自检,并指示计算机如何执行基本功能,如启动和键盘控制。在BIOS也可以选择配置启动参数。对,这就是我们以前重装电脑系统时,在BIOS可以选择从光盘还是硬盘启动等操作的原因。然后BIOS会调用硬盘起始位置的MBRMaster Boot Record,然后按照其中的分区表拉起Bootloader,然后是操作系统内核,再到操作系统和应用。


当然BIOS的设计已经有年头了。现在生产的电脑基本都是使用UEFIUnified Extensible Firmware Interface,汽车上的高性能计算单元也一样。从实现功能上来看,UEFI可以认为是升级版的BIOS


UEFI是一个微型操作系统,它在内存中加载Bootloader,再执行额外的操作程序。作为微型操作系统,UEFI运行在固件之上,可以支持的功能比BIOS多得多,包括系统验证等安全功能。其中最核心的区别是,UEFI支持更大的寻址空间,并且可以在32位或64位模式下运行(BIOS只支持16位),也就是UEFI可以支持更大的硬盘或者网络共享,并且启动速度更快。


由于SoC一般采用基于文件系统的操作系统,可以通过文件系统升级软件,再加上UEFI具有更灵活的启动分区引导,所以车上的高性能计算平台一般还支持A/B分区升级。也就是在A系统运行时,悄悄升级冗余的B系统,完成安装升级后再重启SoC,然后再切换到B系统。其总体过程如下图所示。

6A/B分区升级示意图



五、车载控制器启动的挑战


新年伊始,万象更新。每年的开始阶段对这一整年的影响都举足轻重。对车载控制器的启动来说也是类似,好的开始是成功的一半。正是由于启动的重要性,也有不少挑战要通过启动过程来解决。其中最突出的就是关于信息安全和启动时间的挑战。


启动的信息安全挑战


一年之计在于春。试想如果有人把你给孩子春节期间立下的flag偷偷换掉,然后你孩子还按照这个假的flag执行,如果flag是恶意的,那问题是不是大了?对车载控制器来说也是类似,启动过程中加载的Bootloader或者操作系统如果是被恶意替换了,不就破防了?

为了迎接这个挑战,在启动过程中,会引入安全启动(secure boot机制。其目的是在系统启动之前先验证系统签名的合法性,从而判断将要启动的系统的合法性。如果系统合法,则继续加载拉起系统,如果非法则报错或自动回滚到上一个合法系统。由于传统嵌入式MCU和高性能计算芯片SoC的架构区别,二者在实施安全启动时也略有差别。如下图所示,MCU一般会使用内嵌的HSMHardware Security Module,硬件安全模块来存储密钥和验证签名。而SoC一般会使用TEETrusted Execution Environment,可信执行环境)架构来获取密钥和验证签名。两者在安全层面根据芯片架构采用不同策略,但是其目的和效果都是一样的。

 7:一种MCUSoC安全启动方案的示意图


启动时长的挑战


随着车载计算平台的发展,其所需要管理的硬件资源越来越丰富,也越来越复杂。这让控制器启动时需要加载的数据越来越大,需要初始化的设备也越来越多,导致其启动时长也越来越长。这就像20年前的诺基亚手机开机可能只需要几秒钟,现在智能手机开机则要几十秒甚至一分钟以上。据行业观察,当下流行的几款SoC正常启动时长很少少于10秒钟,如果加上安全启动等过程,则启动时长更长。有些控制器甚至从上电到上层功能业务应用开始工作,需要差不多1分钟。

车载业务对于启动时间又非常敏感。例如当下大家都习惯的倒车影像,我们通常坐上车、系好安全带、发动车辆挂倒挡,就希望影像能够出现在中控屏。试想如果整个启动时长需要1分钟,那我们就需要在车上等待几十秒,或者脱离辅助功能“盲开”出去了,这样的用户体验会很差。


为了迎接这个挑战,车载域控制器或计算平台经常会引入休眠模式。这也类似我们电脑的休眠模式,就是让原本掉电丢失的内存上的内容先存储到硬盘里,下次启动时再将所有内容重新加载到内存上,而不是采用重新从UEFI加载Bootloader到内核再初始化的那一套流程。这样控制器技能长时间保持低功耗,又能在需要唤醒时能够快速启动工作。当然,这需要耗费硬盘上的额外空间来存储休眠时的内存数据。以下图Windows 8的示意图为例,传统冷启动需要耗费大量的时间来初始化系统,但是从休眠模式中启动时,只需把硬盘中的休眠数据(Hiberfile加载到内存,就可以开始用户登录了。


8Windows 8冷启动和从休眠中的启动时长对比示意图


而除了休眠模式,控制器还可以通过优化安全启动策略缩短启动时长。有些情况下,可以允许控制器先拉起Bootloader,操作系统和应用,并记录其启动的签名、指纹等关键数据。待系统工作后,TEE会在后台再次校验已经启动的系统是否合法,如果非法则进入相应的安全模式。这种做法比先验证再启动的方案会损失安全性,但是能缩短启动时长。基于整车网络安全架构的分析,可以让部分较为安全的控制器(例如不与外网直接通讯的本地控制器)采用这种策略。


当然,产品的发展都是多维度而不是单一维度的。车载控制器的启动过程也应该按照多维度标准去取舍和开发。这就像当年传统非智能手机的启动时间是很快,也很安全,没有那么多病毒。但还是被现在启动时间更长、安全风险更大的智能手机所取代了。春节期间大家在家看的智能电视也是一个道理。在汽车智能化的大趋势下,启动过程相信也会不断平衡,做得更加智能、高效、安全。 



参考来源:

1.https://buildstorm.com/blog/automotive-bootloader-fbl/

2.https://www.embitel.com/blog/embedded-blog/what-is-flash-bootloader-and-nuances-of-an-automotive-ecu-re-programming

3.https://baike.baidu.com/item/Bootloader/8733520

4.http://www.oz1bxm.dk/PIC/bootloader.htm

5.https://www.timesys.com/security/secure-boot-snapdragon-410/

推荐阅读

车身控制器功能规范

小鹏P7的热管理系统详解

大众ID4.X内部ECU技术细节整理

比亚迪海豹整车技术整理

揭秘理想的整车电子电气架构

国内主机整车EEA架构汇总

谈谈Bootloader自更新

谈谈对两家AUTOSAR工具看法

奥迪首款800V车型技术总览

汽车软件需求是如何变成用户功能?

汽车E/E架构的网络安全分析

电子电气架构设计需要考虑哪些方面?

深度解读汽车域控制器
自动驾驶域控制器信息梳理
谈谈对汽车OTA的理解
小鹏P7内部ECU技术信息梳理


分享不易,恳请点个【👍】和【在看】

汽车ECU开发 专注于汽车电子ECU软件开发,技术分享。
评论 (0)
  • 现阶段,Zigbee、Z-Wave、Thread、Wi-Fi与蓝牙等多种通信协议在智能家居行业中已得到广泛应用,但协议间互不兼容的通信问题仍在凸显。由于各协议自成体系、彼此割据,智能家居市场被迫催生出大量桥接器、集线器及兼容性软件以在不同生态的设备间构建通信桥梁,而这种现象不仅增加了智能家居厂商的研发成本与时间投入,还严重削减了终端用户的使用体验。为应对智能家居的生态割裂现象,家居厂商需为不同通信协议重复开发适配方案,而消费者则需面对设备入网流程繁琐、跨品牌功能阉割及兼容隐患等现实困境。在此背景
    华普微HOPERF 2025-04-17 17:53 50浏览
  • 置信区间反映的是“样本均值”这个统计量的不确定性,因此使用的是标准误(standard error),而不是直接用样本标准差(standard deviation)。标准误体现的是均值的波动程度,而样本标准差体现的是个体数据的波动程度,两者并非一回事,就如下图所显示的一样。下面优思学院会一步一步解释清楚:一、标准差和标准误,究竟差在哪?很多同学对“标准差”和“标准误”这两个概念傻傻分不清楚,但其实差别明显:标准差(Standard Deviation,σ或s):是衡量单个数据点相对于平均值波动的
    优思学院 2025-04-17 13:59 24浏览
  • 一、行业背景与需求智能门锁作为智能家居的核心入口,正从单一安防工具向多场景交互终端演进。随着消费者对便捷性、安全性需求的提升,行业竞争已从基础功能转向成本优化与智能化整合。传统门锁后板方案依赖多颗独立芯片(如MCU、电机驱动、通信模块、语音模块等),导致硬件复杂、功耗高、开发周期长,且成本压力显著。如何通过高集成度方案降低成本、提升功能扩展性,成为厂商破局关键。WTVXXX-32N语音芯片通过“单芯片多任务”设计,将语音播报、电机驱动、通信协议解析、传感器检测等功能整合于一体,为智能门锁后板提供
    广州唯创电子 2025-04-18 09:04 122浏览
  • 一、行业背景与需求随着智能化技术的快速发展和用户对便捷性需求的提升,电动车行业正经历从传统机械控制向智能交互的转型。传统电动车依赖物理钥匙、遥控器和独立防盗装置,存在操作繁琐、功能单一、交互性差等问题。用户期待通过手机等智能终端实现远程控制、实时数据监控及个性化交互体验。为此,将蓝牙语音芯片集成至电动车中控系统,成为推动智能化升级的关键技术路径。二、方案概述本方案通过在电动车中控系统中集成WT2605C蓝牙语音芯片,构建一套低成本、高兼容性的智能交互平台,实现以下核心功能:手机互联控制:支持蓝牙
    广州唯创电子 2025-04-18 08:33 111浏览
  •   无人机蜂群电磁作战仿真系统全解析   一、系统概述   无人机蜂群电磁作战仿真系统是专业的仿真平台,用于模拟无人机蜂群在复杂电磁环境中的作战行为与性能。它构建虚拟电磁环境,模拟无人机蜂群执行任务时可能遇到的电磁干扰与攻击,评估作战效能和抗干扰能力,为其设计、优化及实战应用提供科学依据。   应用案例   目前,已有多个无人机蜂群电磁作战仿真系统在实际应用中取得了显著成效。例如,北京华盛恒辉和北京五木恒润无人机蜂群电磁作战仿真系统。这些成功案例为无人机蜂群电磁作战仿真系统的推广和应用提
    华盛恒辉l58ll334744 2025-04-17 16:29 71浏览
  • 近日,全球6G技术与产业生态大会(简称“全球6G技术大会”)在南京召开。紫光展锐应邀出席“空天地一体化与数字低空”平行论坛,并从6G通信、感知、定位等多方面分享了紫光展锐在6G前沿科技领域的创新理念及在空天地一体化技术方面的研发探索情况。全球6G技术大会是6G领域覆盖广泛、内容全面的国际会议。今年大会以“共筑创新 同享未来”为主题,聚焦6G愿景与关键技术、安全可信、绿色可持续发展等前沿主题,汇聚国内外24家企业、百余名国际知名高校与科研代表共同商讨如何推动全行业6G标准共识形成。6G迈入关键期,
    紫光展锐 2025-04-17 18:55 131浏览
  • 【摘要/前言】4月春日花正好,Electronica就在浪漫春日里,盛大启幕。2025年4月15-17日,慕尼黑上海电子展于上海新国际博览中心成功举办。伴随着AI、新能源汽车、半导体的热潮,今年的Electronica盛况空前。请跟随Samtec的视角,感受精彩时刻!【 Samtec展台:老虎的朋友圈技术派对】借天时、占地利、聚人和,Samtec 展台人气爆棚!每年展会与大家相聚,总能收获温暖与动力~Samtec展台位于W3展馆716展位,新老朋友相聚于此,俨然一场线下技术派对!前沿D
    电子资讯报 2025-04-17 11:38 40浏览
  • 1. 在Ubuntu官网下载Ubuntu server  20.04版本https://releases.ubuntu.com/20.04.6/2. 在vmware下安装Ubuntu3. 改Ubuntu静态IP$ sudo vi /etc/netplan/00-installer-config.yaml# This is the network config written by 'subiquity'network:  renderer: networkd&nbs
    二月半 2025-04-17 16:27 67浏览
  •   无人机蜂群电磁作战仿真系统软件,是专门用于模拟、验证无人机蜂群在电磁作战环境中协同、干扰、通信以及对抗等能力的工具。下面从功能需求、技术架构、典型功能模块、发展趋势及应用场景等方面展开介绍:   应用案例   目前,已有多个无人机蜂群电磁作战仿真系统在实际应用中取得了显著成效。例如,北京华盛恒辉和北京五木恒润无人机蜂群电磁作战仿真系统。这些成功案例为无人机蜂群电磁作战仿真系统的推广和应用提供了有力支持。   功能需求   电磁环境建模:模拟构建复杂多样的电磁环境,涵盖各类电磁干扰源与
    华盛恒辉l58ll334744 2025-04-17 16:49 64浏览
  •   无人机电磁环境效应仿真系统:深度剖析   一、系统概述   无人机电磁环境效应仿真系统,专为无人机在复杂电磁环境下的性能评估及抗干扰能力训练打造。借助高精度仿真技术,它模拟无人机在各类电磁干扰场景中的运行状态,为研发、测试与训练工作提供有力支撑。   应用案例   目前,已有多个无人机电磁环境效应仿真系统在实际应用中取得了显著成效。例如,北京华盛恒辉和北京五木恒润无人机电磁环境效应仿真系统。这些成功案例为无人机电磁环境效应仿真系统的推广和应用提供了有力支持。   二、系统功能  
    华盛恒辉l58ll334744 2025-04-17 15:51 66浏览
  •   北京华盛恒辉无人机电磁兼容模拟训练系统软件是专门用于模拟与分析无人机在复杂电磁环境中电磁兼容性(EMC)表现的软件工具。借助仿真技术,它能帮助用户评估无人机在电磁干扰下的性能,优化电磁兼容设计,保障无人机在复杂电磁环境中稳定运行。   应用案例   目前,已有多个无人机电磁兼容模拟训练系统在实际应用中取得了显著成效。例如,北京华盛恒辉和北京五木恒润无人机电磁兼容模拟训练系统。这些成功案例为无人机电磁兼容模拟训练系统的推广和应用提供了有力支持。   系统功能   电磁环境建模:支持三维
    华盛恒辉l58ll334744 2025-04-17 15:10 52浏览
  •   无人机电磁兼容模拟训练系统软件:全方位剖析   一、系统概述   北京华盛恒辉无人机电磁兼容模拟训练系统软件,专为满足无人机于复杂电磁环境下的运行需求而打造,是一款专业训练工具。其核心功能是模拟无人机在电磁干扰(EMI)与电磁敏感度(EMS)环境里的运行状况,助力用户评估无人机电磁兼容性能,增强其在复杂电磁场景中的适应水平。   应用案例   目前,已有多个无人机电磁兼容模拟训练系统在实际应用中取得了显著成效。例如,北京华盛恒辉和北京五木恒润无人机电磁兼容模拟训练系统。这些成功案例为
    华盛恒辉l58ll334744 2025-04-17 14:52 33浏览
我要评论
0
6
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦