CN116610340A - 车辆软件的更新方法、装置、车辆及存储介质 - Google Patents

车辆软件的更新方法、装置、车辆及存储介质 Download PDF

Info

Publication number
CN116610340A
CN116610340A CN202310505102.8A CN202310505102A CN116610340A CN 116610340 A CN116610340 A CN 116610340A CN 202310505102 A CN202310505102 A CN 202310505102A CN 116610340 A CN116610340 A CN 116610340A
Authority
CN
China
Prior art keywords
vehicle
program
updated
memory
software program
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Pending
Application number
CN202310505102.8A
Other languages
English (en)
Inventor
杨斌
范永钊
谢天礼
李晓波
邓云飞
刘学武
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Guangzhou Automobile Group Co Ltd
Original Assignee
Guangzhou Automobile Group Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Guangzhou Automobile Group Co Ltd filed Critical Guangzhou Automobile Group Co Ltd
Priority to CN202310505102.8A priority Critical patent/CN116610340A/zh
Publication of CN116610340A publication Critical patent/CN116610340A/zh
Pending legal-status Critical Current

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/60Software deployment
    • G06F8/65Updates
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/60Software deployment
    • G06F8/61Installation
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y02TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
    • Y02DCLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
    • Y02D10/00Energy efficient computing, e.g. low power processors, power management or thermal management

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • General Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Computer Security & Cryptography (AREA)
  • Stored Programmes (AREA)

Abstract

本申请提供了一种车辆软件的更新方法、装置、车辆及存储介质。车辆软件的更新方法包括:在车辆运行过程中,从所述车辆的多个程序存储器中,确定当前运行程序的运行存储器以及当前未运行程序的备份存储器;获取车辆中待更新系统的更新软件程序,将所述更新软件程序安装至所述备份存储器;在所述车辆重启后,切换至所述备份存储器运行所述更新软件程序,以通过所述更新软件程序控制所述待更新系统运行,并停止通过所述运行存储器运行程序。本申请能够使得车辆可以在行车过程中进行车辆软件更新,避免更新时间过长造成驾驶体验差,从而提升车辆的使用体验。

Description

车辆软件的更新方法、装置、车辆及存储介质
技术领域
本申请涉及车辆技术领域,具体涉及一种车辆软件的更新方法、装置、车辆及存储介质。
背景技术
在对车辆的软件进行更新时,出于安全性考虑,必须要停车之后进行软件更新,在行车过程中无法对车辆进行软件更新,导致驾驶员需要在停车之后等待更新过程的进行。更新过程浪费驾驶员较长时间,影响驾驶员正常驾驶车辆,从而降低车辆使用体验。
发明内容
本申请的一个目的在于提出一种车辆软件的更新方法、装置、车辆及存储介质,旨在使得车辆可以在行车过程中进行车辆软件更新,避免更新时间过长造成驾驶体验差,从而提升车辆的使用体验。
根据本申请实施例的一方面,提供了一种车辆软件的更新方法,所述方法包括:
在车辆运行过程中,从所述车辆的多个程序存储器中,确定当前运行程序的运行存储器以及当前未运行程序的备份存储器;
获取车辆中待更新系统的更新软件程序,将所述更新软件程序安装至所述备份存储器;
在所述车辆重启后,切换至所述备份存储器运行所述更新软件程序,以通过所述更新软件程序控制所述待更新系统运行,并停止通过所述运行存储器运行程序。
根据本申请实施例的一方面,提供了一种车辆软件的更新装置,所述装置包括:
确定模块,用于在车辆运行过程中,从所述车辆的多个程序存储器中,确定当前运行程序的运行存储器以及当前未运行程序的备份存储器;
安装模块,用于获取车辆中待更新系统的更新软件程序,将所述更新软件程序安装至所述备份存储器;
切换模块,用于在所述车辆重启后,切换至所述备份存储器运行所述更新软件程序,以通过所述更新软件程序控制所述待更新系统运行,并停止通过所述运行存储器运行程序。
在本申请的一些实施例中,基于以上技术方案,所述装置配置为:
获取动力系统的运行状态;所述待更新系统包括动力系统;
若所述运行状态匹配参考状态,则输出更新提示信息;所述参考状态是所述动力系统停机时运行状态所在区间;
响应于对所述更新提示信息的确定指令,重启所述车辆;
若所述运行状态不匹配所述参考状态,则输出停机更新提示信息;
响应于对所述停机更新提示信息的确定指令,控制所述动力系统停机,并重启所述车辆。
在本申请的一些实施例中,基于以上技术方案,所述装置配置为:
输出针对所述车辆中待更新系统的数据下载提示信息;
响应于对所述数据下载提示信息的确定指令,从云端服务器下载所述待更新系统的更新软件程序以及数字签名;
若校验所述数字签名通过,则保存所述更新软件程序。
在本申请的一些实施例中,基于以上技术方案,所述装置配置为:
获取所述车辆中预设系统的版本信息;
若根据所述版本信息,检测到所述预设系统存在新版本,则获取所述新版本的更新描述信息;
生成包括所述更新描述信息的所述下载提示信息。
在本申请的一些实施例中,基于以上技术方案,所述装置配置为:
输出针对所述更新软件程序的安装提示信息;
响应于对所述安装提示信息的确定指令,将下载的所述更新软件程序写入至所述备份存储器,并覆盖所述备份存储器中的已有软件程序;
获取安装所述更新软件程序的进度信息,并展示所述进度信息。
在本申请的一些实施例中,基于以上技术方案,所述装置配置为:
若检测到安装至所述备份存储器成功,则重启所述车辆;
若检测到安装至所述备份存储器失败,则从所述运行存储器中读取当前版本的软件数据,并将所述当前版本的软件数据写入至所述备份存储器。
在本申请的一些实施例中,基于以上技术方案,所述装置配置为:
重新检测当前运行程序的运行存储器,并根据重新检测的运行存储器的存储数据获取版本信息;
将重新检测到的运行存储器的标识以及重新获取的所述版本信息发送至云端服务器;
若检测到所述云端服务器反馈的更新指令,则重新下载所述更新指令对应的更新软件程序,并将所述更新指令对应的更新软件程序更新至所述车辆当前未运行的备份存储器中。
根据本申请实施例的一方面,提供了一种车辆,包括:一个或多个处理器;存储装置,用于存储一个或多个程序,当所述一个或多个程序被所述一个或多个处理器执行时,使得所述车辆实现上述各种可选实现方式中提供的方法。
根据本申请实施例的一方面,提供了一种计算机程序介质,其上存储有计算机可读指令,当所述计算机可读指令被计算机的处理器执行时,使计算机执行上述各种可选实现方式中提供的方法。
根据本申请实施例的一个方面,提供了一种计算机程序产品或计算机程序,该计算机程序产品或计算机程序包括计算机指令,该计算机指令存储在计算机可读存储介质中。计算机设备的处理器从计算机可读存储介质读取该计算机指令,处理器执行该计算机指令,使得该计算机设备执行上述各种可选实现方式中提供的方法。
在本申请实施例提供的技术方案中,通过在车辆运行过程中,车辆的多个程序存储器中,确定当前运行程序的运行存储器以及当前未运行程序的备份存储器,获取车辆中待更新系统的更新软件程序,将更新软件程序安装至备份存储器,在车辆重启后,切换至备份存储器运行更新软件程序,以通过更新软件程序控制待更新系统运行,并停止通过运行存储器运行程序。在车辆运行过程中,多个程序存储器中包括当前正在运行程序的程序存储器以及当前未运行程序的程序存储器,更新软件的过程中,运行存储器可以继续正常运行程序,以使得车辆正常行车,同时可以将更新软件程序安装至备份存储器,以对待更新系统的软件进行更新;由于更新软件程序安装在独立于运行存储器的备份存储器中,在车辆重启之后,可以直接切换至备份存储器运行更新软件程序,使得通过更新软件程序控制待更新系统运行而完成车辆软件的更新,并且可以停止通过此前的运行存储器来运行程序。在车辆软件的更新过程中,车辆无需停车即可将更新软件程序更新至未运行程序的备份存储器,而重启之后即可快速切换至备份存储器来运行更新的软件程序,减少了停车等待更新的时间,极大程度降低了对正常驾驶的干扰,从而提高了车辆的使用体验。
本申请的其他特性和优点将通过下面的详细描述变得显然,或部分地通过本申请的实践而习得。
应当理解的是,以上的一般描述和后文的细节描述仅是示例性的,并不能限制本申请。
附图说明
通过参考附图详细描述其示例实施例,本申请的上述和其它目标、特征及优点将变得更加显而易见。
图1示出了根据本申请一个实施例的车辆软件的更新方法的流程示意图。
图2示出了根据本申请一个实施例的车辆软件的更新方法的流程示意图。
图3示出了根据本申请一个实施例的车辆软件的更新方法的流程示意图。
图4示出了根据本申请一个具体实现方式中的车辆软件的更新流程示意图。
图5示出了云端服务器、车载客户端以及ECU之间通信交互的示意图。
图6示出了MCU与两个FLASH的通信交互示意图。
图7示出了根据本申请一实施例的车辆软件的更新装置的结构示意图。
图8示出了根据本申请一个实施例的车辆的结构示意图。
具体实施方式
现在将参考附图更全面地描述示例实施方式。然而,示例实施方式能够以多种形式实施,且不应被理解为限于在此阐述的范例;相反,提供这些示例实施方式使得本申请的描述将更加全面和完整,并将示例实施方式的构思全面地传达给本领域的技术人员。附图仅为本申请的示意性图解,并非一定是按比例绘制。图中相同的附图标记表示相同或类似的部分,因而将省略对它们的重复描述。
此外,所描述的特征、结构或特性可以以任何合适的方式结合在一个或更多示例实施方式中。在下面的描述中,提供许多具体细节从而给出对本申请的示例实施方式的充分理解。然而,本领域技术人员将意识到,可以实践本申请的技术方案而省略特定细节中的一个或更多,或者可以采用其它的方法、组元、步骤等。在其它情况下,不详细示出或描述公知结构、方法、实现或者操作以避免喧宾夺主而使得本申请的各方面变得模糊。
附图中所示的一些方框图是功能实体,不一定必须与物理或逻辑上独立的实体相对应。可以采用软件形式来实现这些功能实体,或在一个或多个硬件模块或集成电路中实现这些功能实体,或在不同网络和/或处理器装置和/或微控制器装置中实现这些功能实体。
车辆的软件更新可以通过空中下载(Over-the-Air,OTA)实现,由于车辆需要兼顾安全性,因此在更新软件过程中,需要停车进行更新。具体而言,车辆的程序存储器包括两个分区,一个分区用于运行程序,另一个程序用于备份程序,目前在进行OTA更新过程中,需要将软件下载至运行程序的分区,由于该分区正在运行程序,无法直接写入更新软件,只能将车辆停下来,通过OTA下载更新程序写入至运行程序的分区,备份分区的作用在于,如果更新失败,可以将备份分区中此前保存的软件重新写入至运行程序的分区,避免更新失败造成的运行程序的分区的程序损坏。可以看出,上述方式只能在车辆停止运行时,才能进行软件更新,此过程需要驾驶员停车,然后进行更新操作,之后等待车辆进行软件下载和更新,直至所有更新完成后,才能继续驾驶车辆,造成时间浪费,干扰正常用车,从而降低了车辆使用体验。为解决上述问题,提出以下各个实施例阐述本申请的技术方案。
图1示出了根据本申请一个实施例的车辆软件的更新方法的流程示意图,该方法包括:
步骤S101:在车辆运行过程中,从车辆的多个程序存储器中,确定当前运行程序的运行存储器以及当前未运行程序的备份存储器。
在本实施例中,执行主体为车辆。程序存储器是存储车辆运行所需程序的存储器。程序存储器是一种非易失性存储器,比如Flash。程序存储器的数量可以为两个或者两个以上。程序存储器基于其当前是否运行程序可以被划分为运行存储器和备份存储器。如果当前正在运行程序,则该程序存储器被识别为运行存储器,如果当前未运行程序,则该程序存储器被识别为备份存储器。如此可以使得车辆中既有维持正常运行程序的存储器,也有用于进行软件更新的备份存储器。
在一实施例中,程序存储器包括第一程序存储器以及第二程序存储器,通过在第一程序存储器和第二程序存储器中识别运行程序的存储器和未运行程序的存储器,分别得到运行存储器和备份存储器。
步骤S102:获取车辆中待更新系统的更新软件程序,将更新软件程序安装至备份存储器。
待更新系统是需要进行更新的系统,待更新系统可以是动力系统,也可以是非动力系统。此外,可以通过OTA技术来下载更新软件程序,并且将更新软件程序写入备份存储器,并覆盖备份存储器原有的软件程序。
在一实施例中,获取车辆中待更新系统的更新软件程序,包括:输出针对车辆中待更新系统的数据下载提示信息;响应于对数据下载提示信息的确定指令,从云端服务器下载待更新系统的更新软件程序以及数字签名;若校验数字签名通过,则保存更新软件程序。
数据下载提示信息是用于提示使用者是否需要下载更新程序的信息。输出该数据下载提示信息的方式比如在车辆的多媒体设备上进行展示或者播放,或者将该下载提示信息发送至关联的电子设备等。确定指令是确定需要下载更新软件程序的指令,该指令可以是触控交互指令、语音指令等形式。云端服务器存储有最新版本的更新软件程序,并存储有该更新软件程序的数字签名。
在一实施例中,车辆获取到更新软件程序之后,通过预先存储的公钥对数字签名进行验证,该预先存储的公钥可以是车辆制造商的公钥,也可以是其他可信的公钥,如果数字签名验证通过,则表明更新软件程序是数字签名的私钥拥有者进行签名的,且更新软件程序没有被篡改过,否则,车辆将拒绝该更新软件程序,并可以停止更新过程。此外,如果数字签名验证通过,车辆还可以继续验证更新软件程序的完整性和真实性,比如对更新软件程序的哈希值进行计算,并与预先存储的哈希值进行比对,如果更新软件程序的哈希值与预先存储的哈希值相符,则表明更新软件程序是完整的且没有篡改过。此后车辆可以保存该更新软件程序,并继续更新过程。
在一实施例中,若校验数字签名不通过,则丢弃更新软件程序,并重新请求更新软件程序。
采用上述方式,可以提高更新过程的安全性,同时还匹配了使用者的数据下载需求,在使用者确认的情况下进行数据下载,提高使用者的使用体验。
在一实施例中,输出针对车辆中待更新系统的数据下载提示信息之前,该方法还包括:获取车辆中预设系统的版本信息;若根据版本信息,检测到预设系统存在新版本,则获取新版本的更新描述信息;生成包括更新描述信息的下载提示信息。
预设系统是车辆中存在的系统,比如动力系统和非动力系统。版本信息包括预设系统当前使用的软件的版本号,此外该版本信息中也可以包括与版本号对应的预设系统中各零部件的标识。更新描述信息是描述该新版本的更新内容的信息,比如哪些零部件的相应固件、哪些功能得到了更新的相关介绍。下载提示信息包括该更新描述信息,从而可以使得使用者结合更新描述判断是否需要更新。
在一实施例中,可以通过如下方式检测预设系统是否存在新版本:将版本信息发送至云端服务器,检测云端服务器根据版本信息反馈的更新指示,如果检测到云端服务器发送的更新指示,则表明预设系统存在新版本,如果未检测到云端服务器返回该更新指示,则表明预设系统暂时不存在新版本。
采用上述方式,能够检测车辆中系统的新版本,以及新版本系统更新的内容,便于使用者了解更新的内容。
在一实施例中,将更新软件程序安装至备份存储器,包括:输出针对更新软件程序的安装提示信息;响应于对安装提示信息的确定指令,将下载的更新软件程序写入至备份存储器,并覆盖备份存储器中的已有软件程序;获取安装更新软件程序的进度信息,并展示进度信息。
安装提示信息是提示是否确认需要安装更新的信息。已有软件程序是备份存储器此前保存的软件程序,可以是以前更新至该存储器的旧版本的软件程序。进度信息用于指示安装该更新软件程序的进度。
采用上述方式,匹配使用者的实际安装需求,将更新软件程序更新到备份存储器中,并且能够展示安装进度,便于使用者了解安装的情况,同时不影响正常行车,能够提高车辆的使用体验。
步骤S103:在车辆重启后,切换至备份存储器运行更新软件程序,以通过更新软件程序控制待更新系统运行,并停止通过运行存储器运行程序。
由于更新软件程序被更新到备份存储器中,从而需要切换至备份存储器运行其中的程序,以通过该程序控制待更新系统运行,以使得车辆按照更新后的程序运行,此外,由于此前确定的运行存储器已经暂时不再用于运行程序,从而需要停止运行其中的程序。
在一实施例中,在切换至备份存储器运行更新软件程序之后,将备份存储器标记为新的运行存储器,将此前确定的已经停止运行程序的运行存储器标记为备份存储器。若检测到待更新系统进一步需要更新,则根据新的标记为备份存储器的程序存储器,更新新的软件程序。如此,每次更新都可以在行车过程中进行,提高车辆的使用体验。
在一实施例中,停止通过运行存储器运行程序之后,该方法还包括:重新检测当前运行程序的运行存储器,并根据重新检测的运行存储器的存储数据获取版本信息;将重新检测到的运行存储器的标识以及重新获取的版本信息发送至云端服务器;若检测到云端服务器反馈的更新指令,则重新下载更新指令对应的更新软件程序,并将更新指令对应的更新软件程序更新至车辆当前未运行的备份存储器中。
在通过备份存储器运行之后,如果后续需要进一步更新,则备份存储器将由于其运行程序而被确定为新的运行存储器,比如程序存储器A,在某次更新过程中作为备份存储器更新了软件程序,而由于后续切换至该备份存储器运行程序,则此时该程序存储器A的属性则变为运行存储器,此后更新过程中,需要结合运行存储器中的软件版本发送至云端服务器进行更新检测,如果云端服务器返回更新指令,则表明后续存在新的更新软件程序,从而需要重新下载更新指令对应的更新软件程序,并将更新指令对应的更新软件程序更新至车辆当前未运行的备份存储器,即程序存储器B中。采用此方式,可以使得车辆的后续迭代更新均能够在行车过程中进行,提高车辆使用体验。
在本实施例中,在车辆运行过程中,多个程序存储器中包括当前正在运行程序的程序存储器以及当前未运行程序的程序存储器,更新软件的过程中,运行存储器可以继续正常运行程序,以使得车辆正常行车,同时可以将更新软件程序安装至备份存储器,以对待更新系统的软件进行更新;由于更新软件程序安装在独立于运行存储器的备份存储器中,在车辆重启之后,可以直接切换至备份存储器运行更新软件程序,使得通过更新软件程序控制待更新系统运行而完成车辆软件的更新,并且可以停止通过此前的运行存储器来运行程序。在车辆软件的更新过程中,车辆无需停车即可将更新软件程序更新至未运行程序的备份存储器,而重启之后即可快速切换至备份存储器来运行更新的软件程序,减少了停车等待更新的时间,极大程度降低了对正常驾驶的干扰,从而提高了车辆的使用体验。
图2示出了根据本申请一个实施例的车辆软件的更新方法的流程示意图,该方法包括:
步骤S201:在车辆运行过程中,从车辆的多个程序存储器中,确定当前运行程序的运行存储器以及当前未运行程序的备份存储器。
在本实施例中,根据动力系统的不同状态,分别输出两种不同的提示,以使得使用者根据提示适时地进行车辆重启,完成运行程序的存储器的切换,以提高车辆使用体验。
步骤S202:获取车辆中待更新系统的更新软件程序,将更新软件程序安装至备份存储器。
步骤S203:获取动力系统的运行状态。
待更新系统包括动力系统。动力系统的运行状态包括发动机状态、车速、挡位等,对于混合动力车型和纯电动车型,还涉及高压系统状态,如驱动电机转速,高压电池状态等。
步骤S204:若运行状态匹配参考状态,则输出更新提示信息。
参考状态是动力系统停机时的状态。动力系统停机的情况下进行相应软件的更新从而满足车辆安全性要求。在动力系统停机时,发动机状态为关闭状态,车速为0,挡位为P挡。更新提示信息是提示使用者确认安装更新软件程序的信息,在更新提示信息中还可以包括重启的描述信息,以使得使用者了解更新过程中会重启车辆。
步骤S205:响应于对更新提示信息的确定指令,重启车辆。
由于此时动力系统已经处于停机状态,车辆已经脱离行车状态,从而重启也不会干扰正常用车,并且重启车辆后待更新系统通过更新软件程序运行实现了车辆软件更新完整流程,提高了车辆的使用体验。
步骤S206:若运行状态不匹配参考状态,则输出停机更新提示信息。
如果运行状态不匹配参考状态,则动力系统可能未停机,此时为了避免影响车辆正常使用,先输出停机更新提示信息,使得使用者了解车辆需要进行停机才会重启车辆以切换运行程序的程序存储器。
步骤S207:响应于对停机更新提示信息的确定指令,控制动力系统停机,并重启车辆。
如果使用者此时正在行车,则可以忽略该停机更新提示信息,直至其用车完成,可以对该停机更新提示信息进行确认,此时控制动力系统停机,并重启车辆,进一步可以快速切换至备份存储器运行更新软件程序,从而可以在当前动力系统暂未停机的情况下,匹配使用者的用车需要,择机停机后重启车辆完成程序存储器的切换,实现待更新系统按照更新后的程序运行,更新过程不会影响使用者正常用车,提高了车辆的使用者体验。
在一实施例中,响应于对停机更新提示信息的取消指令,隐藏停机更新提示信息,间隔预设等待时长后,重新检测动力系统的运行状态是否匹配参考状态,如果匹配该参考状态,则输出更新提示信息,如果不匹配该参考状态,则重新输出停机更新提示信息。采用此方式,可以避免遗漏对车辆软件的更新。
步骤S208:在车辆重启后,切换至备份存储器运行更新软件程序,以通过更新软件程序控制待更新系统运行,并停止通过运行存储器运行程序。
采用上述方式,分别在动力系统运行和停机时提示使用者进行相应的确认操作,在各种使用场景中灵活进行车辆软件更新,不干扰使用者正常用车,同时匹配使用者的用车情况,提高车辆的使用体验。
图3示出了根据本申请一个实施例的车辆软件的更新方法的流程示意图,该方法包括:
步骤S301:在车辆运行过程中,从车辆的多个程序存储器中,确定当前运行程序的运行存储器以及当前未运行程序的备份存储器。
在本实施例中,还可以对车辆的软件程序进行回滚,以使得在安装更新失败的情况下,保留正常软件程序,以避免车辆软件出现异常。
步骤S302:获取车辆中待更新系统的更新软件程序,将更新软件程序安装至备份存储器。
步骤S303:若检测到安装至备份存储器成功,则重启车辆。
步骤S304:若检测到安装至备份存储器失败,则从运行存储器中读取当前版本的软件数据,并将当前版本的软件数据写入至备份存储器。
安装至备份存储器失败的原因比如网络中断、总线信号中断、电压过低以及电磁干扰等导致下载更新程序失败。此时,为了使得备份存储器中存储正常可运行的程序,通过从运行存储器中读取当前本版的软件数据,并将当前版本的软件数据写入至备份存储器。
步骤S305:在车辆重启后,切换至备份存储器运行更新软件程序,以通过更新软件程序控制待更新系统运行,并停止通过运行存储器运行程序。
采用上述方式,在安装更新失败的情况下,可将备份存储器中的程序回滚至当前可正常运行的程序版本,此外,由于运行存储器中的数据并未被擦除,即便更新失败也不会对运行存储器的程序造成干扰,不会影响正常车辆正常运行,从而可以在保证安全性的基础上,进行车辆软件的更新,提高车辆使用体验。
图4示出了根据本申请一个具体实现方式中的车辆软件的更新流程示意图,该流程包括:
步骤S401:车载客户端检测云端服务器的OTA更新需求。
图5示出了云端服务器、车载客户端以及ECU之间通信交互的示意图。车载客户端与云端服务器之间无线通信,并通过识别零部件号、软件版本号发送至云端服务器,以检测云端服务器有软件OTA更新需求。车载客户端如TBOX,车载客户端和云端服务器采用以太网通讯,遵守ISO 13400以太网传输协议。车载客户端与ECU之间通过内部总线通信。
步骤S402:车载客户端发送对应零部件软件更新内容至车载多媒体主机,请求用户进行OTA软件下载。
TBOX通过总线发送零部件名称、零部件号、软件版本以及预更新内容至多媒体主机,由多媒体主机进行软件OTA下载请求。
步骤S403:用户同意下载的基础上,车载客户端基于加密手段下载更新程序,并提示用户车辆需要安装更新。
用户同意下载后,车载客户端通过数字签名等加密方式请求云端服务器进行程序下载,下载完成后多媒体主机推送信息提示用户进行零部件软件安装更新。其中,TBOX采用标准以太网诊断接口模型进行数据下载。
步骤S404:用户同意安装更新的基础上,车载客户端将软件程序更新至对应ECU的备份区。
图6示出了MCU与两个FLASH的通信交互示意图。其中,A/B双FLASH程序存储器同时连接MCU(或MPU),AFLASH进行程序运行,B FLASH进行后台更新。AFLASH为运行存储器,BFLASH为备份存储器。通过多媒体主机提示用户进行软件更新,用户同意更新后,TBOX与对应预更新车载ECU进行安全秘钥校验,通过后进行程序下载至B FLASH存储器,车载客户端将下载好的软件程序更新至对应ECU的B FLASH备份存储器,并将更新进度显示至用户进行参考。更新进度也可缩至主机后台界面。
步骤S405:更新完成后,提示用户进行择机下电切换,ECU将运行BFLASH区,并将AFLASH作为下次备份的程序存储器。
动力系统ECU在程序下载至B FLASH区后,综合发动机状态、发动机转速、车速、档位等条件(混合动力或纯电动车型还涉及高压系统状态,如驱动电机转速、高压电池状态等)发送允许切换标志位至TBOX和多媒体主机,如满足阈值条件,则通过多媒体主机提示用户进行停车退电切换;如不满足切换条件,则通过多媒体主机提示用户择机停车退电切换。
步骤S406:切换完成后将更新后的对应ECU信息回传至云端服务器,完成此次OTA升级。
切换完成后车载ECU将存储后的当前零部件号、软件版本号、车辆VIN及当前MCU主运行程序存储分区FLASH号等重要信息回传至云端服务器,并且上述信息可以体现在车载主机零部件版本信息中。
采用上述方式,双FLASH互不影响,在程序下载完成给以用户通知后,由用户选择适时切换或者车辆满足切换条件(如P档静态下电重启)则切换,能更快更安全地进行程序下载及切换,达到无感切换的目的。并且可实现车辆动力系统相关程序OTA空中升级,采用MCU连接双FLASH进行内部连接,AFALSH进行当前程序运行,B FLASH进行程序升级冗余,除实现无感切换保证驾驶员车辆稳定运行外,还为驾驶员节约OTA升级完成时间,另外还能进一步提升动力域控制器的安全性,A FLASH运行出错,无缝切换到B FLASH,AFLASH进行功能冗余,从而保证车辆功能安全。
图7示出了根据本申请一实施例的车辆软件的更新装置的结构示意图,该装置包括:
确定模块501,用于在车辆运行过程中,从车辆的多个程序存储器中,确定当前运行程序的运行存储器以及当前未运行程序的备份存储器;
安装模块502,用于获取车辆中待更新系统的更新软件程序,将更新软件程序安装至备份存储器;
切换模块503,用于在车辆重启后,切换至备份存储器运行更新软件程序,以通过更新软件程序控制待更新系统运行,并停止通过运行存储器运行程序。
在本申请的一些实施例中,基于以上技术方案,该装置配置为:
获取动力系统的运行状态;待更新系统包括动力系统;
若运行状态匹配参考状态,则输出更新提示信息;参考状态是动力系统停机时运行状态所在区间;
响应于对更新提示信息的确定指令,重启车辆;
若运行状态不匹配参考状态,则输出停机更新提示信息;
响应于对停机更新提示信息的确定指令,控制动力系统停机,并重启车辆。
在本申请的一些实施例中,基于以上技术方案,该装置配置为:
输出针对车辆中待更新系统的数据下载提示信息;
响应于对数据下载提示信息的确定指令,从云端服务器下载待更新系统的更新软件程序以及数字签名;
若校验数字签名通过,则保存更新软件程序。
在本申请的一些实施例中,基于以上技术方案,该装置配置为:
获取车辆中预设系统的版本信息;
若根据版本信息,检测到预设系统存在新版本,则获取新版本的更新描述信息;
生成包括更新描述信息的下载提示信息。
在本申请的一些实施例中,基于以上技术方案,该装置配置为:
输出针对更新软件程序的安装提示信息;
响应于对安装提示信息的确定指令,将下载的更新软件程序写入至备份存储器,并覆盖备份存储器中的已有软件程序;
获取安装更新软件程序的进度信息,并展示进度信息。
在本申请的一些实施例中,基于以上技术方案,该装置配置为:
若检测到安装至备份存储器成功,则重启车辆;
若检测到安装至备份存储器失败,则从运行存储器中读取当前版本的软件数据,并将当前版本的软件数据写入至备份存储器。
在本申请的一些实施例中,基于以上技术方案,该装置配置为:
重新检测当前运行程序的运行存储器,并根据重新检测的运行存储器的存储数据获取版本信息;
将重新检测到的运行存储器的标识以及重新获取的版本信息发送至云端服务器;
若检测到云端服务器反馈的更新指令,则重新下载更新指令对应的更新软件程序,并将更新指令对应的更新软件程序更新至车辆当前未运行的备份存储器中。
下面参考图8来描述根据本申请实施例的车辆60。图8显示的车辆60仅仅是一个示例,不应对本申请实施例的功能和使用范围带来任何限制。
如图8所示,车辆60以通用计算设备的形式表现。车辆60的组件可以包括但不限于:上述至少一个处理单元610、上述至少一个存储单元620、连接不同系统组件(包括存储单元620和处理单元610)的总线630。
其中,存储单元存储有程序代码,程序代码可以被处理单元610执行,使得处理单元610执行本说明书上述示例性方法的描述部分中描述的根据本申请各种示例性实施方式的步骤。例如,处理单元610可以执行如图1中所示的各个步骤。
存储单元620可以包括易失性存储单元形式的可读介质,例如随机存取存储单元(RAM)6201和/或高速缓存存储单元6202,还可以进一步包括只读存储单元(ROM)6203。
存储单元620还可以包括具有一组(至少一个)程序模块6205的程序/实用工具6204,这样的程序模块6205包括但不限于:操作系统、一个或者多个应用程序、其它程序模块以及程序数据,这些示例中的每一个或某种组合中可能包括网络环境的实现。
总线630可以为表示几类总线结构中的一种或多种,包括存储单元总线或者存储单元控制器、外围总线、图形加速端口、处理单元或者使用多种总线结构中的任意总线结构的局域总线。
车辆60也可以与一个或多个外部设备700(例如蓝牙设备等)通信,还可与一个或者多个使得用户能与该车辆60交互的设备通信,和/或与使得该车辆60能与一个或多个其它计算设备进行通信的任何设备(例如路由器、调制解调器等等)通信。这种通信可以通过输入/输出(I/O)接口650进行。输入/输出(I/O)接口650与显示单元640相连。并且,车辆60还可以通过网络适配器660与一个或者多个网络(例如局域网(LAN),广域网(WAN)和/或公共网络,例如因特网)通信。如图所示,网络适配器660通过总线630与车辆60的其它模块通信。应当明白,尽管图中未示出,可以结合车辆60使用其它硬件和/或软件模块,包括但不限于:微代码、设备驱动器、冗余处理单元、外部磁盘驱动阵列、RAID系统、磁带驱动器以及数据备份存储系统等。
通过以上的实施方式的描述,本领域的技术人员易于理解,这里描述的示例实施方式可以通过软件实现,也可以通过软件结合必要的硬件的方式来实现。因此,根据本申请实施方式的技术方案可以以软件产品的形式体现出来,该软件产品可以存储在一个非易失性存储介质(可以是CD-ROM,U盘,移动硬盘等)中或网络上,包括若干指令以使得一台车辆执行根据本申请实施方式的方法。
在本申请的示例性实施例中,还提供了一种计算机可读存储介质,其上存储有计算机可读指令,当计算机可读指令被计算机的处理器执行时,使计算机执行上述方法实施例部分描述的方法。
根据本申请的一个实施例,还提供了一种用于实现上述方法实施例中的方法的程序产品,其可以采用便携式紧凑盘只读存储器(CD-ROM)并包括程序代码,并可以在终端设备,例如个人电脑上运行。然而,本申请的程序产品不限于此,在本文件中,可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。
程序产品可以采用一个或多个可读介质的任意组合。可读介质可以是可读信号介质或者可读存储介质。可读存储介质例如可以为但不限于电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。可读存储介质的更具体的例子(非穷举的列表)包括:具有一个或多个导线的电连接、便携式盘、硬盘、随机存取存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、光纤、便携式紧凑盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。
计算机可读信号介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了可读程序代码。这种传播的数据信号可以采用多种形式,包括但不限于电磁信号、光信号或上述的任意合适的组合。可读信号介质还可以是可读存储介质以外的任何可读介质,该可读介质可以发送、传播或者传输用于由指令执行系统、装置或者器件使用或者与其结合使用的程序。
可读介质上包含的程序代码可以用任何适当的介质传输,包括但不限于无线、有线、光缆、RF等等,或者上述的任意合适的组合。
可以以一种或多种程序设计语言的任意组合来编写用于执行本申请操作的程序代码,程序设计语言包括面向对象的程序设计语言—诸如JAVA、C++等,还包括常规的过程式程序设计语言—诸如“C”语言或类似的程序设计语言。程序代码可以完全地在用户计算设备上执行、部分地在用户设备上执行、作为一个独立的软件包执行、部分在用户计算设备上部分在远程计算设备上执行、或者完全在远程计算设备或服务器上执行。在涉及远程计算设备的情形中,远程计算设备可以通过任意种类的网络,包括局域网(LAN)或广域网(WAN),连接到用户计算设备,或者,可以连接到外部计算设备(例如利用因特网服务提供商来通过因特网连接)。
应当注意,尽管在上文详细描述中提及了用于动作执行的设备的若干模块或者单元,但是这种划分并非强制性的。实际上,根据本申请的实施方式,上文描述的两个或更多模块或者单元的特征和功能可以在一个模块或者单元中具体化。反之,上文描述的一个模块或者单元的特征和功能可以进一步划分为由多个模块或者单元来具体化。
此外,尽管在附图中以特定顺序描述了本申请中方法的各个步骤,但是,这并非要求或者暗示必须按照该特定顺序来执行这些步骤,或是必须执行全部所示的步骤才能实现期望的结果。附加的或备选的,可以省略某些步骤,将多个步骤合并为一个步骤执行,以及/或者将一个步骤分解为多个步骤执行等。
通过以上的实施方式的描述,本领域的技术人员易于理解,这里描述的示例实施方式可以通过软件实现,也可以通过软件结合必要的硬件的方式来实现。因此,根据本申请实施方式的技术方案可以以软件产品的形式体现出来,该软件产品可以存储在一个非易失性存储介质(可以是CD-ROM,U盘,移动硬盘等)中或网络上,包括若干指令以使得一台车辆执行根据本申请实施方式的方法。
本领域技术人员在考虑说明书及实践这里公开的发明后,将容易想到本申请的其它实施方案。本申请旨在涵盖本申请的任何变型、用途或者适应性变化,这些变型、用途或者适应性变化遵循本申请的一般性原理并包括本申请未公开的本技术领域中的公知常识或惯用技术手段。说明书和实施例仅被视为示例性的,本申请的真正范围和精神由所附的权利要求指出。

Claims (10)

1.一种车辆软件的更新方法,其特征在于,所述方法包括:
在车辆运行过程中,从所述车辆的多个程序存储器中,确定当前运行程序的运行存储器以及当前未运行程序的备份存储器;
获取车辆中待更新系统的更新软件程序,将所述更新软件程序安装至所述备份存储器;
在所述车辆重启后,切换至所述备份存储器运行所述更新软件程序,以通过所述更新软件程序控制所述待更新系统运行,并停止通过所述运行存储器运行程序。
2.根据权利要求1所述的方法,其特征在于,所述待更新系统包括动力系统;将所述更新软件程序安装至所述备份存储器之后,所述方法还包括:
获取所述动力系统的运行状态;
若所述运行状态匹配参考状态,则输出更新提示信息;所述参考状态是所述动力系统停机时的状态;
响应于对所述更新提示信息的确定指令,重启所述车辆;
若所述运行状态不匹配所述参考状态,则输出停机更新提示信息;
响应于对所述停机更新提示信息的确定指令,控制所述动力系统停机,并重启所述车辆。
3.根据权利要求1所述的方法,其特征在于,获取车辆中待更新系统的更新软件程序,包括:
输出针对所述车辆中待更新系统的数据下载提示信息;
响应于对所述数据下载提示信息的确定指令,从云端服务器下载所述待更新系统的更新软件程序以及数字签名;
若校验所述数字签名通过,则保存所述更新软件程序。
4.根据权利要求3所述的方法,其特征在于,输出针对所述车辆中待更新系统的数据下载提示信息之前,所述方法还包括:
获取所述车辆中预设系统的版本信息;
若根据所述版本信息,检测到所述预设系统存在新版本,则获取所述新版本的更新描述信息;
生成包括所述更新描述信息的所述下载提示信息。
5.根据权利要求3所述的方法,其特征在于,将所述更新软件程序安装至所述备份存储器,包括:
输出针对所述更新软件程序的安装提示信息;
响应于对所述安装提示信息的确定指令,将下载的所述更新软件程序写入至所述备份存储器,并覆盖所述备份存储器中的已有软件程序;
获取安装所述更新软件程序的进度信息,并展示所述进度信息。
6.根据权利要求1所述的方法,其特征在于,将所述更新软件程序安装至所述备份存储器之后,所述方法还包括:
若检测到安装至所述备份存储器成功,则重启所述车辆;
若检测到安装至所述备份存储器失败,则从所述运行存储器中读取当前版本的软件数据,并将所述当前版本的软件数据写入至所述备份存储器。
7.根据权利要求1所述的方法,其特征在于,停止通过所述运行存储器运行程序之后,所述方法还包括:
重新检测当前运行程序的运行存储器,并根据重新检测的运行存储器的存储数据获取版本信息;
将重新检测到的运行存储器的标识以及重新获取的所述版本信息发送至云端服务器;
若检测到所述云端服务器反馈的更新指令,则重新下载所述更新指令对应的更新软件程序,并将所述更新指令对应的更新软件程序更新至所述车辆当前未运行的备份存储器中。
8.一种车辆软件的更新装置,其特征在于,所述装置包括:
确定模块,用于在车辆运行过程中,从所述车辆的多个程序存储器中,确定当前运行程序的运行存储器以及当前未运行程序的备份存储器;
安装模块,用于获取车辆中待更新系统的更新软件程序,将所述更新软件程序安装至所述备份存储器;
切换模块,用于在所述车辆重启后,切换至所述备份存储器运行所述更新软件程序,以通过所述更新软件程序控制所述待更新系统运行,并停止通过所述运行存储器运行程序。
9.一种车辆,其特征在于,包括:
一个或多个处理器;
存储装置,用于存储一个或多个程序,当所述一个或多个程序被所述一个或多个处理器执行时,使得所述车辆实现如权利要求1至7中任一项所述的方法。
10.一种计算机可读存储介质,其特征在于,其上存储有计算机可读指令,当所述计算机可读指令被计算机的处理器执行时,使计算机执行权利要求1至7中任一项所述的方法。
CN202310505102.8A 2023-05-06 2023-05-06 车辆软件的更新方法、装置、车辆及存储介质 Pending CN116610340A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202310505102.8A CN116610340A (zh) 2023-05-06 2023-05-06 车辆软件的更新方法、装置、车辆及存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202310505102.8A CN116610340A (zh) 2023-05-06 2023-05-06 车辆软件的更新方法、装置、车辆及存储介质

Publications (1)

Publication Number Publication Date
CN116610340A true CN116610340A (zh) 2023-08-18

Family

ID=87684606

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202310505102.8A Pending CN116610340A (zh) 2023-05-06 2023-05-06 车辆软件的更新方法、装置、车辆及存储介质

Country Status (1)

Country Link
CN (1) CN116610340A (zh)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN117667163A (zh) * 2024-01-31 2024-03-08 北京鲲鹏凌昊智能技术有限公司 一种通过以太网远程更新dsp程序的方法、设备和存储介质

Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN104252369A (zh) * 2013-06-27 2014-12-31 上海博泰悦臻电子设备制造有限公司 车载设备及其双系统备份方法及装置
CN105573787A (zh) * 2015-12-15 2016-05-11 上海博泰悦臻网络技术服务有限公司 基于车载T-Box实现软件升级的方法及装置
CN106339242A (zh) * 2016-07-26 2017-01-18 深圳市英威腾交通技术有限公司 一种电力机车控制设备的软件更新方法和系统
CN106648768A (zh) * 2016-12-09 2017-05-10 福建三元达网络技术有限公司 一种升级设备的方法及系统
CN110275726A (zh) * 2019-06-27 2019-09-24 四川宜途汽车电子科技有限公司 一种车载电控单元控制程序备份升级方法
CN111698307A (zh) * 2020-06-04 2020-09-22 中国第一汽车股份有限公司 一种车辆远程升级方法、装置、设备及存储介质
CN113805926A (zh) * 2021-09-14 2021-12-17 上汽通用五菱汽车股份有限公司 软件升级方法、车辆及计算机可读存储介质
CN114153484A (zh) * 2021-11-20 2022-03-08 浙江智柔科技有限公司 更新程序的运行方法、装置、电子装置和存储介质

Patent Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN104252369A (zh) * 2013-06-27 2014-12-31 上海博泰悦臻电子设备制造有限公司 车载设备及其双系统备份方法及装置
CN105573787A (zh) * 2015-12-15 2016-05-11 上海博泰悦臻网络技术服务有限公司 基于车载T-Box实现软件升级的方法及装置
CN106339242A (zh) * 2016-07-26 2017-01-18 深圳市英威腾交通技术有限公司 一种电力机车控制设备的软件更新方法和系统
CN106648768A (zh) * 2016-12-09 2017-05-10 福建三元达网络技术有限公司 一种升级设备的方法及系统
CN110275726A (zh) * 2019-06-27 2019-09-24 四川宜途汽车电子科技有限公司 一种车载电控单元控制程序备份升级方法
CN111698307A (zh) * 2020-06-04 2020-09-22 中国第一汽车股份有限公司 一种车辆远程升级方法、装置、设备及存储介质
CN113805926A (zh) * 2021-09-14 2021-12-17 上汽通用五菱汽车股份有限公司 软件升级方法、车辆及计算机可读存储介质
CN114153484A (zh) * 2021-11-20 2022-03-08 浙江智柔科技有限公司 更新程序的运行方法、装置、电子装置和存储介质

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN117667163A (zh) * 2024-01-31 2024-03-08 北京鲲鹏凌昊智能技术有限公司 一种通过以太网远程更新dsp程序的方法、设备和存储介质
CN117667163B (zh) * 2024-01-31 2024-04-05 北京鲲鹏凌昊智能技术有限公司 一种通过以太网远程更新dsp程序的方法、设备和存储介质

Similar Documents

Publication Publication Date Title
JP5629927B2 (ja) 車載機のオンライン更新方法
JP6332580B1 (ja) 制御装置、プログラム更新方法、およびコンピュータプログラム
CN109673009B (zh) 一种vcu软件空中升级方法及装置
CN110659038B (zh) 车载毫米波雷达升级方法、装置、计算机设备和存储介质
CN111949299A (zh) 一种车载软件ota升级的控制方法及装置
CN116610340A (zh) 车辆软件的更新方法、装置、车辆及存储介质
WO2018176692A1 (zh) 系统的固件更新方法、装置和电池管理系统
WO2022237122A1 (zh) 车载迎宾动画更新方法、装置、车载终端及存储介质
CN113377384A (zh) 一种程序烧录方法、装置、车载终端及介质
CN115543395A (zh) 一种车载ecu升级方法、装置、电子设备和存储介质
CN113672254A (zh) 车辆ota升级方法、装置、存储介质和无人驾驶设备
CN113093694A (zh) 一种基于uds的车载电控单元数据刷写方法及系统
CN115061713A (zh) 升级电子设备的方法及装置
US20220391192A1 (en) Ota master, center, system, method, non-transitory storage medium, and vehicle
WO2022160816A1 (zh) 一种数据处理方法以及相关设备
CN114546455A (zh) 一种双分区的mcu软件升级方法及装置
CN114780114A (zh) 固件升级方法、系统、车辆及存储介质
CN114895947A (zh) 车载控制器的软件升级方法、装置、设备和存储介质
KR20160071260A (ko) Autosar 기반 차량 ecu 상태 관리 방법
CN113703801A (zh) 一种车载终端固件升级方法及电子装置
KR20140057739A (ko) 전자 제어 장치 및 그 업데이트 방법
CN112732301A (zh) 一种车辆升级方法和装置
CN116909609B (zh) 车载智能设备的软件升级方法、装置及车载智能设备
CN116707819B (zh) 一种车辆ota升级安全机制的构建方法
CN116909808A (zh) 车辆电子控制单元的升级方法、装置、设备以及存储介质

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination