CN116225500A - 一种固件升级方法、装置、电子设备及存储介质 - Google Patents

一种固件升级方法、装置、电子设备及存储介质 Download PDF

Info

Publication number
CN116225500A
CN116225500A CN202111470630.1A CN202111470630A CN116225500A CN 116225500 A CN116225500 A CN 116225500A CN 202111470630 A CN202111470630 A CN 202111470630A CN 116225500 A CN116225500 A CN 116225500A
Authority
CN
China
Prior art keywords
upgrading
module file
target module
unified extensible
firmware interface
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
CN202111470630.1A
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.)
Loongson Technology Corp Ltd
Original Assignee
Loongson Technology Corp 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 Loongson Technology Corp Ltd filed Critical Loongson Technology Corp Ltd
Priority to CN202111470630.1A priority Critical patent/CN116225500A/zh
Publication of CN116225500A publication Critical patent/CN116225500A/zh
Pending legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/60Software deployment
    • G06F8/65Updates
    • G06F8/654Updates using techniques specially adapted for alterable solid state memories, e.g. for EEPROM or flash memories
    • 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)
  • Computer Security & Cryptography (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Stored Programmes (AREA)

Abstract

本发明实施例提供了一种固件升级方法和装置。方法包括:在所述统一可扩展固件接口下,运行网页服务;其中,所述网页服务用于对所述统一可扩展固件接口的模块文件进行升级,接收所述网页服务返回的升级后的目标模块文件和对应的升级指令,响应于所述升级指令,将所述升级后的目标模块文件写入闪存,并覆盖所述闪存中存储的升级前的目标模块文件,使得通过在统一可扩展固件接口下的网页服务,实现了对统一可扩展固件接口的模块文件的升级,避免了通过U盘进行升级存在的操作繁琐,效率低的问题,克服了在操作系统下升级存在的对统一可扩展固件接口的使用和调试不方便的问题。提高了对统一可扩展固件接口升级的便捷性。

Description

一种固件升级方法、装置、电子设备及存储介质
技术领域
本发明涉及计算机技术领域,特别是涉及一种固件升级方法、一种固件升级装置、一种电子设备以及一种可读存储介质。
背景技术
UEFI(Unified Extensible Firmware Interface,统一可扩展固件接口)是一种个人电脑系统规格,用来定义操作系统与系统固件之间的软件界面,作为BIOS(BasicInput Output System,基本输入输出系统)的替代方案。可扩展固件接口负责上电自检、联系操作系统以及提供连接操作系统与硬件的接口。
目前对UEFI进行升级有两种方法。一种是使用一个U盘插在UEFI的设备上来实现的,在调试中如果要反复验证,需要反复的插拔U盘来传输更新文件,存在操作繁琐,效率低的问题。另一种是在操作系统下更新,缺点是需要进入到操作系统中,不方便对UEFI的使用和调试。
发明内容
本发明实施例所要解决的技术问题是提供一种固件升级方法、装置、电子设备及可读存储介质,以便解决操作繁琐,效率低,不方便对UEFI的使用和调试的问题。
为了解决上述问题,本发明提供了一种固件升级方法,应用于统一可扩展固件接口,包括:
在所述统一可扩展固件接口下,运行网页服务;其中,所述网页服务用于对所述统一可扩展固件接口的模块文件进行升级;
接收所述网页服务返回的升级后的目标模块文件和对应的升级指令;
响应于所述升级指令,将所述升级后的目标模块文件写入闪存,并覆盖所述闪存中存储的升级前的目标模块文件。
可选地,所述接收所述网页服务返回的升级后的目标模块文件和对应的升级指令包括:
在所述统一可扩展固件接口下,通过超文本传输协议,接收基于胶囊结构封装的所述升级后的目标模块文件,以及对应的升级指令。
可选地,所述响应于所述升级指令,将所述升级后的目标模块文件写入闪存,并覆盖所述闪存中存储的升级前的目标模块文件包括:
响应于所述升级指令,通过胶囊式固件升级协议,对所述基于胶囊结构封装的所述升级后的目标模块文件进行解析和校验,得到所述升级后的目标模块文件;
若校验通过,则对所述统一可扩展固件接口进行重启,并在重启后将所述升级后的目标模块文件写入闪存,并覆盖所述闪存中存储的升级前的目标模块文件;
若校验不通过,则向所述网页服务返回重新发送请求。
可选地,在所述对所述统一可扩展固件接口进行重启之前,所述方法还包括:
向所述网页服务返回开始升级的状态;
所述方法还包括:
向所述网页服务回复所述升级后的目标模块文件的升级进度。
本发明还提供了一种固件升级方法,应用于远程终端,包括:
访问统一可扩展固件接口上运行的网页服务;其中,所述网页服务用于对所述统一可扩展固件接口的模块文件进行升级;
通过所述网页服务,从所述统一可扩展固件接口的模块文件中,选择要升级的目标模块文件;
针对所述要升级的目标模块文件,将升级后的目标模块文件和对应的升级指令发送给所述统一可扩展固件接口,以供所述统一可扩展固件接口接收所述网页服务返回的升级后的目标模块文件和对应的升级指令,响应于所述升级指令,将所述升级后的目标模块文件写入闪存,并覆盖所述闪存中存储的升级前的目标模块文件。
本发明还提供了一种固件升级装置,应用于统一可扩展固件接口,包括:
服务运行模块,用于在所述统一可扩展固件接口下,运行网页服务;其中,所述网页服务用于对所述统一可扩展固件接口的模块文件进行升级;
指令接收模块,用于接收所述网页服务返回的升级后的目标模块文件和对应的升级指令;
文件写入模块,用于响应于所述升级指令,将所述升级后的目标模块文件写入闪存,并覆盖所述闪存中存储的升级前的目标模块文件。
可选地,所述指令接收模块包括:
接收子模块,用于在所述统一可扩展固件接口下,通过超文本传输协议,接收基于胶囊结构封装的所述升级后的目标模块文件,以及对应的升级指令。
可选地,所述文件写入模块包括:
解析校验子模块,用于响应于所述升级指令,通过胶囊式固件升级协议,对所述基于胶囊结构封装的所述升级后的目标模块文件进行解析和校验,得到所述升级后的目标模块文件;
重启子模块,用于若校验通过,则对所述统一可扩展固件接口进行重启,并在重启后将所述升级后的目标模块文件写入闪存,并覆盖所述闪存中存储的升级前的目标模块文件;
重发子模块,用于若校验不通过,则向所述网页服务返回重新发送请求。
可选地,所述装置还包括:
状态返回模块,用于在所述对所述统一可扩展固件接口进行重启之前,向所述网页服务返回开始升级的状态;
所述装置还包括:
进度回复模块,用于向所述网页服务回复所述升级后的目标模块文件的升级进度。
本发明还提供了一种固件升级装置,应用于远程终端,包括:
服务访问模块,用于访问统一可扩展固件接口上运行的网页服务;其中,所述网页服务用于对所述统一可扩展固件接口的模块文件进行升级;
文件选择模块,用于通过所述网页服务,从所述统一可扩展固件接口的模块文件中,选择要升级的目标模块文件;
指令发送模块,用于针对所述要升级的目标模块文件,将升级后的目标模块文件和对应的升级指令发送给所述统一可扩展固件接口,以供所述统一可扩展固件接口接收所述网页服务返回的升级后的目标模块文件和对应的升级指令,响应于所述升级指令,将所述升级后的目标模块文件写入闪存,并覆盖所述闪存中存储的升级前的目标模块文件。
本发明实施例还公开了一种电子设备,其特征在于,包括处理器、通信接口、存储器和通信总线,其中,处理器,通信接口,存储器通过通信总线完成相互间的通信;
存储器,用于存放计算机程序;
处理器,用于执行存储器上所存放的程序时,实现如上所述的方法步骤。
本发明实施例还公开了一种可读存储介质,当所述存储介质中的指令由电子设备的处理器执行时,使得电子设备能够执行本发明实施例中一个或多个所述的方法。
依据本发明实施例,通过在所述统一可扩展固件接口下,运行网页服务;其中,所述网页服务用于对所述统一可扩展固件接口的模块文件进行升级,接收所述网页服务返回的升级后的目标模块文件和对应的升级指令,响应于所述升级指令,将所述升级后的目标模块文件写入闪存,并覆盖所述闪存中存储的升级前的目标模块文件,使得通过在统一可扩展固件接口下的网页服务,实现了对统一可扩展固件接口的模块文件的升级,避免了通过U盘进行升级存在的操作繁琐,效率低的问题,克服了在操作系统下升级存在的对统一可扩展固件接口的使用和调试不方便的问题。提高了对统一可扩展固件接口升级的便捷性。
附图说明
图1示出了本发明的一个实施例提供的一种固件升级方法的步骤流程图;
图2示出了本发明的另一个实施例提供的一种固件升级方法的步骤流程图;
图3示出了通过Web浏览器的UEFI升级过程的示意图;
图4示出了本发明的又一个实施例提供的一种固件升级方法的步骤流程图;
图5示出了本发明的一个实施例提供的一种固件升级装置实施例的结构框图;
图6示出了本发明的另一个实施例提供的一种固件升级装置实施例的结构框图;
图7示出了根据一示例性实施例示出的一种用于固件升级的电子设备的结构框图。
具体实施方式
为使本发明的上述目的、特征和优点能够更加明显易懂,下面结合附图和具体实施方式对本发明作进一步详细的说明。
参照图1,示出了本发明实施例提供的一种固件升级方法的步骤流程图,具体可以包括如下步骤:
步骤101,在所述统一可扩展固件接口下,运行网页服务;其中,所述网页服务用于对所述统一可扩展固件接口的模块文件进行升级。
在本发明实施例中,统一可扩展固件接口是一种模块化设计的方案,因此,在对统一可扩展固件接口进行升级时,可以通过对需要升级的一个或多个模块文件进行升级。其中,模块文件是存储在闪存中的,组成统一可扩展固件接口的一部分。
在本发明实施例中,在统一可扩展固件接口中实现网页服务(Web Server),创建的Web Server能够接收来自远程终端(如浏览器端)的HTTP(Hyper Text TransferProtocol,超文本传输协议)请求,并且能够传递给对应的统一可扩展固件接口进行处理,最后将处理结果返回给远程终端。在该网页服务的基础上,实现了对统一可扩展固件接口的模块文件进行升级的功能。
例如,EDK2是一个遵循UEFI标准和PI(Platform Initialization,平台初始化)标准的跨平台固件开发环境,EDK2的源码中已经实现了Web Server的Demo(Demonstration,示例)源码。在这个Demo源码的基础上实现对统一可扩展固件接口的模块文件进行升级的功能。
在本发明实施例中,在统一可扩展固件接口下,运行上述实现的网页服务,以使远程终端能够访问上述实现的网页服务。远程终端可以通过局域网、或万维网、或其他任意适用的网络访问该网页服务。为此,需要通过网络配置,使得统一可扩展固件接口能够连接到网络。例如,通过ifconfig命令设置动态IP地址,或者配置静态的IP地址。
步骤102,访问统一可扩展固件接口上运行的网页服务;其中,所述网页服务用于对所述统一可扩展固件接口的模块文件进行升级。
在本发明实施例中,远程终端通过网络可以连接到统一可扩展固件接口。远程终端通过网络访问统一可扩展固件接口上运行的网页服务。例如,在浏览器上对上述实现的网页服务的网址进行访问,从而打开对统一可扩展固件接口的模块文件进行升级的页面。
步骤103,通过所述网页服务,从所述统一可扩展固件接口的模块文件中,选择要升级的目标模块文件。
在本发明实施例中,远程终端通过上述网页服务,可以显示统一可扩展固件接口的能够升级的各个模块文件。从统一可扩展固件接口的模块文件中,选择本次要升级的一个或多个目标模块文件。
其中,目标模块文件为本次升级的模块文件。将统一可扩展固件接口的设备上原本存储的目标模块文件,记为升级前的目标模块文件,例如,版本为v1的模块文件a。将远程终端针对该目标模块文件,要发送给统一可扩展固件接口的目标模块文件,记为升级后的目标模块文件,例如,版本为v2的模块文件a。
例如,浏览器中,在打开的对统一可扩展固件接口的模块文件进行升级的页面上,选择要升级的目标模块文件。
步骤104,针对所述要升级的目标模块文件,将升级后的目标模块文件和对应的升级指令发送给所述统一可扩展固件接口。
在本发明实施例中,针对上述选择的要升级的目标模块文件,远程终端通过上述网页服务,将升级后的目标模块文件发送给统一可扩展固件接口,并且发送对应的升级指令。其中,升级指令用于指示统一可扩展固件接口开始对模块文件进行升级。
例如,浏览器中,在打开的对统一可扩展固件接口的模块文件进行升级的页面上,提供一个上传文件的入口,通过该入口将升级后的目标模块文件进行上传,同时向统一可扩展固件接口发出升级指令。
步骤105,接收所述网页服务返回的升级后的目标模块文件和对应的升级指令。
在本发明实施例中,网页服务将远程终端上传的升级后的目标模块文件和对应的升级指令返回给统一可扩展固件接口。统一可扩展固件接口接收网页服务返回的升级后的目标模块文件和对应的升级指令。
步骤106,响应于所述升级指令,将所述升级后的目标模块文件写入闪存,并覆盖所述闪存中存储的升级前的目标模块文件。
在本发明实施例中,统一可扩展固件接口响应于接收到的升级指令,将升级后的目标模块文件写入闪存,并覆盖闪存中存储的升级前的目标模块文件。
依据本发明实施例,通过在所述统一可扩展固件接口下,运行网页服务;其中,所述网页服务用于对所述统一可扩展固件接口的模块文件进行升级,访问统一可扩展固件接口上运行的网页服务;其中,所述网页服务用于对所述统一可扩展固件接口的模块文件进行升级,通过所述网页服务,从所述统一可扩展固件接口的模块文件中,选择要升级的目标模块文件,针对所述要升级的目标模块文件,将升级后的目标模块文件和对应的升级指令发送给所述统一可扩展固件接口,接收所述网页服务返回的升级后的目标模块文件和对应的升级指令,响应于所述升级指令,将所述升级后的目标模块文件写入闪存,并覆盖所述闪存中存储的升级前的目标模块文件,使得通过在统一可扩展固件接口下的网页服务,实现了对统一可扩展固件接口的模块文件的升级,避免了通过U盘进行升级存在的操作繁琐,效率低的问题,克服了在操作系统下升级存在的对统一可扩展固件接口的使用和调试不方便的问题。提高了对统一可扩展固件接口升级的便捷性。
参照图2,示出了本发明实施例提供的一种固件升级方法的步骤流程图,应用于统一可扩展固件接口,具体可以包括如下步骤:
步骤201,在所述统一可扩展固件接口下,运行网页服务;其中,所述网页服务用于对所述统一可扩展固件接口的模块文件进行升级。
在本发明实施例中,此步骤的具体实现方式可以参见前述实施例中的描述,此处不另赘述。
步骤202,接收所述网页服务返回的升级后的目标模块文件和对应的升级指令。
在本发明实施例中,此步骤的具体实现方式可以参见前述实施例中的描述,此处不另赘述。
步骤203,响应于所述升级指令,将所述升级后的目标模块文件写入闪存,并覆盖所述闪存中存储的升级前的目标模块文件。
在本发明实施例中,此步骤的具体实现方式可以参见前述实施例中的描述,此处不另赘述。
在本发明的一种可选实施例中,接收所述网页服务返回的升级后的目标模块文件和对应的升级指令的一种具体实现方式中,可以包括:在所述统一可扩展固件接口下,通过超文本传输协议,接收基于胶囊结构封装的所述升级后的目标模块文件,以及对应的升级指令。
胶囊(Capsule)式固件升级协议是UEFI定义用于操作系统与固件系统进行数据传输的一种规范。基于UEFI的胶囊式固件升级协议在数据传输阶段把待升级的目标模块文件封装成胶囊结构,在固件系统启动过程再解析基于胶囊结构封装的所述升级后的目标模块文件。
为了实现远程终端与统一可扩展固件接口进行数据传输,利用胶囊式固件升级协议,将升级后的目标模块文件封装成基于胶囊结构封装的所述升级后的目标模块文件。网页服务在返回升级后的目标模块文件时,通过超文本传输协议,将基于胶囊结构封装的所述升级后的目标模块文件,以及对应的升级指令发送给统一可扩展固件接口。
在本发明的一种可选实施例中,响应于所述升级指令,将所述升级后的目标模块文件写入闪存,并覆盖所述闪存中存储的升级前的目标模块文件的一种具体实现方式中,可以包括:响应于所述升级指令,通过胶囊式固件升级协议,对所述基于胶囊结构封装的所述升级后的目标模块文件进行解析和校验,得到所述升级后的目标模块文件,若校验通过,则对所述统一可扩展固件接口进行重启,并在重启后将所述升级后的目标模块文件写入闪存,并覆盖所述闪存中存储的升级前的目标模块文件,若校验不通过,则向所述网页服务返回重新发送请求。
统一可扩展固件接口响应于升级指令,通过胶囊式固件升级协议,解析基于胶囊结构封装的所述升级后的目标模块文件,提取其中的升级后的目标模块文件。胶囊式固件升级协议还可以对升级后的目标模块文件进行校验,校验升级后的目标模块文件的数据完整性和合法性。
若校验通过,这时统一可扩展固件接口进行重启。需要注意的是,此时的重启并非真正的重启,而是利用睡眠状态,内存不丢失,这样解析出的升级后的目标模块文件一直在内存中。统一可扩展固件接口重启之后,将升级后的目标模块文件写入闪存,并覆盖所述闪存中存储的升级前的目标模块文件。
若校验不通过,则向所述网页服务返回重新发送请求。网页服务将重新发送请求返回给对应的远程终端,要求远程终端重新上传升级后的目标模块文件。
例如,如图3所示的通过Web浏览器的UEFI升级过程的示意图。Web浏览器在远程的PC(Personal Computer,个人计算机)上,PC通过网络与UEFI的设备连接。在UEFI下运行WebServer。Web浏览器访问该Web Server,通过Web Server将升级后的目标模块文件发送给UEFI,这里的升级后的目标模块文件采用的是基于Capsule结构封装的数据包,解析该基于Capsule结构封装的数据包,UEFI得到升级后的目标模块文件,并将升级后的目标模块文件写入Flash(闪存)中。
在本发明的一种可选实施例中,在对所述统一可扩展固件接口进行重启之前,还可以包括:向所述网页服务返回开始升级的状态;对应的,还可以包括:向所述网页服务回复所述升级后的目标模块文件的升级进度。
在校验通过后,并在对统一可扩展固件接口进行重启之前,向网页服务返回开始升级的状态,以通过网页服务将开始升级的状态发送给远程终端。并在升级过程中,获取升级后的目标模块文件的升级进度,例如,正在重启、开始写入、写入百分比、写入完成等各个阶段的升级进度,并将升级进度返回给网页服务,以通过网页服务将写入进度发送给远程终端,从而在远程终端上就可以显示升级的进度。
依据本发明实施例,通过在所述统一可扩展固件接口下,运行网页服务;其中,所述网页服务用于对所述统一可扩展固件接口的模块文件进行升级,接收所述网页服务返回的升级后的目标模块文件和对应的升级指令,响应于所述升级指令,将所述升级后的目标模块文件写入闪存,并覆盖所述闪存中存储的升级前的目标模块文件,使得通过在统一可扩展固件接口下的网页服务,实现了对统一可扩展固件接口的模块文件的升级,避免了通过U盘进行升级存在的操作繁琐,效率低的问题,克服了在操作系统下升级存在的对统一可扩展固件接口的使用和调试不方便的问题。提高了对统一可扩展固件接口升级的便捷性。
参照图4,示出了本发明又一实施例提供的一种固件升级方法的步骤流程图,应用于远程终端,具体可以包括如下步骤:
步骤301,访问统一可扩展固件接口上运行的网页服务;其中,所述网页服务用于对所述统一可扩展固件接口的模块文件进行升级。
在本发明实施例中,此步骤的具体实现方式可以参见前述实施例中的描述,此处不另赘述。
步骤302,通过所述网页服务,从所述统一可扩展固件接口的模块文件中,选择要升级的目标模块文件。
在本发明实施例中,此步骤的具体实现方式可以参见前述实施例中的描述,此处不另赘述。
步骤303,针对所述要升级的目标模块文件,将升级后的目标模块文件和对应的升级指令发送给所述统一可扩展固件接口,以供所述统一可扩展固件接口接收所述网页服务返回的升级后的目标模块文件和对应的升级指令,响应于所述升级指令,将所述升级后的目标模块文件写入闪存,并覆盖所述闪存中存储的升级前的目标模块文件。
在本发明实施例中,此步骤的具体实现方式可以参见前述实施例中的描述,此处不另赘述。
依据本发明实施例,通过访问统一可扩展固件接口上运行的网页服务;其中,所述网页服务用于对所述统一可扩展固件接口的模块文件进行升级,通过所述网页服务,从所述统一可扩展固件接口的模块文件中,选择要升级的目标模块文件,针对所述要升级的目标模块文件,将升级后的目标模块文件和对应的升级指令发送给所述统一可扩展固件接口,以供所述统一可扩展固件接口接收所述网页服务返回的升级后的目标模块文件和对应的升级指令,响应于所述升级指令,将所述升级后的目标模块文件写入闪存,并覆盖所述闪存中存储的升级前的目标模块文件,使得通过在统一可扩展固件接口下的网页服务,实现了对统一可扩展固件接口的模块文件的升级,避免了通过U盘进行升级存在的操作繁琐,效率低的问题,克服了在操作系统下升级存在的对统一可扩展固件接口的使用和调试不方便的问题。提高了对统一可扩展固件接口升级的便捷性。
需要说明的是,对于方法实施例,为了简单描述,故将其都表述为一系列的动作组合,但是本领域技术人员应该知悉,本发明实施例并不受所描述的动作顺序的限制,因为依据本发明实施例,某些步骤可以采用其他顺序或者同时进行。其次,本领域技术人员也应该知悉,说明书中所描述的实施例均属于优选实施例,所涉及的动作并不一定是本发明实施例所必须的。
参照图5,示出了本发明另一实施例提供的一种固件升级装置实施例的结构框图,应用于统一可扩展固件接口,具体可以包括如下模块:
服务运行模块401,用于在所述统一可扩展固件接口下,运行网页服务;其中,所述网页服务用于对所述统一可扩展固件接口的模块文件进行升级;
指令接收模块402,用于接收所述网页服务返回的升级后的目标模块文件和对应的升级指令;
文件写入模块403,用于响应于所述升级指令,将所述升级后的目标模块文件写入闪存,并覆盖所述闪存中存储的升级前的目标模块文件。
在本发明的一种可选实施例中,所述指令接收模块包括:
接收子模块,用于在所述统一可扩展固件接口下,通过超文本传输协议,接收基于胶囊结构封装的所述升级后的目标模块文件,以及对应的升级指令。
在本发明的一种可选实施例中,所述文件写入模块包括:
解析校验子模块,用于响应于所述升级指令,通过胶囊式固件升级协议,对所述基于胶囊结构封装的所述升级后的目标模块文件进行解析和校验,得到所述升级后的目标模块文件;
重启子模块,用于若校验通过,则对所述统一可扩展固件接口进行重启,并在重启后将所述升级后的目标模块文件写入闪存,并覆盖所述闪存中存储的升级前的目标模块文件;
重发子模块,用于若校验不通过,则向所述网页服务返回重新发送请求。
在本发明的一种可选实施例中,所述装置还包括:
状态返回模块,用于在所述对所述统一可扩展固件接口进行重启之前,向所述网页服务返回开始升级的状态;
所述装置还包括:
进度回复模块,用于向所述网页服务回复所述升级后的目标模块文件的升级进度。
依据本发明实施例,通过在所述统一可扩展固件接口下,运行网页服务;其中,所述网页服务用于对所述统一可扩展固件接口的模块文件进行升级,接收所述网页服务返回的升级后的目标模块文件和对应的升级指令,响应于所述升级指令,将所述升级后的目标模块文件写入闪存,并覆盖所述闪存中存储的升级前的目标模块文件,使得通过在统一可扩展固件接口下的网页服务,实现了对统一可扩展固件接口的模块文件的升级,避免了通过U盘进行升级存在的操作繁琐,效率低的问题,克服了在操作系统下升级存在的对统一可扩展固件接口的使用和调试不方便的问题。提高了对统一可扩展固件接口升级的便捷性。
参照图6,示出了本发明另一实施例提供的一种固件升级装置实施例的结构框图,应用于远程终端,具体可以包括如下模块:
服务访问模块501,用于访问统一可扩展固件接口上运行的网页服务;其中,所述网页服务用于对所述统一可扩展固件接口的模块文件进行升级;
文件选择模块502,用于通过所述网页服务,从所述统一可扩展固件接口的模块文件中,选择要升级的目标模块文件;
指令发送模块503,用于针对所述要升级的目标模块文件,将升级后的目标模块文件和对应的升级指令发送给所述统一可扩展固件接口,以供所述统一可扩展固件接口接收所述网页服务返回的升级后的目标模块文件和对应的升级指令,响应于所述升级指令,将所述升级后的目标模块文件写入闪存,并覆盖所述闪存中存储的升级前的目标模块文件。
依据本发明实施例,通过访问统一可扩展固件接口上运行的网页服务;其中,所述网页服务用于对所述统一可扩展固件接口的模块文件进行升级,通过所述网页服务,从所述统一可扩展固件接口的模块文件中,选择要升级的目标模块文件,针对所述要升级的目标模块文件,将升级后的目标模块文件和对应的升级指令发送给所述统一可扩展固件接口,以供所述统一可扩展固件接口接收所述网页服务返回的升级后的目标模块文件和对应的升级指令,响应于所述升级指令,将所述升级后的目标模块文件写入闪存,并覆盖所述闪存中存储的升级前的目标模块文件,使得通过在统一可扩展固件接口下的网页服务,实现了对统一可扩展固件接口的模块文件的升级,避免了通过U盘进行升级存在的操作繁琐,效率低的问题,克服了在操作系统下升级存在的对统一可扩展固件接口的使用和调试不方便的问题。提高了对统一可扩展固件接口升级的便捷性。
对于装置实施例而言,由于其与方法实施例基本相似,所以描述的比较简单,相关之处参见方法实施例的部分说明即可。
图7是根据一示例性实施例示出的一种用于固件升级的电子设备700的结构框图。例如,电子设备700可以是移动电话,计算机,数字广播终端,消息收发设备,游戏控制台,平板设备,医疗设备,健身设备,个人数字助理等。
参照图7,电子设备700可以包括以下一个或多个组件:处理组件702,存储器704,电源组件706,多媒体组件708,音频组件710,输入/输出(I/O)的接口712,传感器组件714,以及通信组件716。
处理组件702通常控制电子设备700的整体操作,诸如与显示,电话呼叫,数据通信,相机操作和记录操作相关联的操作。处理元件702可以包括一个或多个处理器720来执行指令,以完成上述的方法的全部或部分步骤。此外,处理组件702可以包括一个或多个模块,便于处理组件702和其他组件之间的交互。例如,处理部件702可以包括多媒体模块,以方便多媒体组件708和处理组件702之间的交互。
存储器704被配置为存储各种类型的数据以支持在设备700的操作。这些数据的示例包括用于在电子设备700上操作的任何应用程序或方法的指令,联系人数据,电话簿数据,消息,图片,视频等。存储器704可以由任何类型的易失性或非易失性存储设备或者它们的组合实现,如静态随机存取存储器(SRAM),电可擦除可编程只读存储器(EEPROM),可擦除可编程只读存储器(EPROM),可编程只读存储器(PROM),只读存储器(ROM),磁存储器,快闪存储器,磁盘或光盘。
电力组件704为电子设备700的各种组件提供电力。电力组件704可以包括电源管理系统,一个或多个电源,及其他与为电子设备700生成、管理和分配电力相关联的组件。
多媒体组件708包括在所述电子设备700和用户之间的提供一个输出接口的屏幕。在一些实施例中,屏幕可以包括液晶显示器(LCD)和触摸面板(TP)。如果屏幕包括触摸面板,屏幕可以被实现为触摸屏,以接收来自用户的输入信号。触摸面板包括一个或多个触摸传感器以感测触摸、滑动和触摸面板上的手势。所述触摸传感器可以不仅感测触摸或滑动动作的边界,而且还检测与所述触摸或滑动操作相关的持续时间和压力。在一些实施例中,多媒体组件708包括一个前置摄像头和/或后置摄像头。当电子设备700处于操作模式,如拍摄模式或视频模式时,前置摄像头和/或后置摄像头可以接收外部的多媒体数据。每个前置摄像头和后置摄像头可以是一个固定的光学透镜系统或具有焦距和光学变焦能力。
音频组件710被配置为输出和/或输入音频信号。例如,音频组件710包括一个麦克风(MIC),当电子设备700处于操作模式,如呼叫模式、记录模式和语音识别模式时,麦克风被配置为接收外部音频信号。所接收的音频信号可以被进一步存储在存储器704或经由通信组件716发送。在一些实施例中,音频组件710还包括一个扬声器,用于输出音频信号。
I/O接口712为处理组件702和外围接口模块之间提供接口,上述外围接口模块可以是键盘,点击轮,按钮等。这些按钮可包括但不限于:主页按钮、音量按钮、启动按钮和锁定按钮。
传感器组件714包括一个或多个传感器,用于为电子设备700提供各个方面的状态评估。例如,传感器组件714可以检测到设备700的打开/关闭状态,组件的相对定位,例如所述组件为电子设备700的显示器和小键盘,传感器组件714还可以检测电子设备700或电子设备700一个组件的位置改变,用户与电子设备700接触的存在或不存在,电子设备700方位或加速/减速和电子设备700的温度变化。传感器组件714可以包括接近传感器,被配置用来在没有任何的物理接触时检测附近物体的存在。传感器组件714还可以包括光传感器,如CMOS或CCD图像传感器,用于在成像应用中使用。在一些实施例中,该传感器组件714还可以包括加速度传感器,陀螺仪传感器,磁传感器,压力传感器或温度传感器。
通信组件716被配置为便于电子设备700和其他设备之间有线或无线方式的通信。电子设备700可以接入基于通信标准的无线网络,如WiFi,2G或3G,或它们的组合。在一个示例性实施例中,通信部件714经由广播信道接收来自外部广播管理系统的广播信号或广播相关信息。在一个示例性实施例中,所述通信部件714还包括近场通信(NFC)模块,以促进短程通信。例如,在NFC模块可基于射频识别(RFID)技术,红外数据协会(IrDA)技术,超宽带(UWB)技术,蓝牙(BT)技术和其他技术来实现。
在示例性实施例中,电子设备700可以被一个或多个应用专用集成电路(ASIC)、数字信号处理器(DSP)、数字信号处理设备(DSPD)、可编程逻辑器件(PLD)、现场可编程门阵列(FPGA)、控制器、微控制器、微处理器或其他电子元件实现,用于执行上述方法。
在示例性实施例中,还提供了一种包括指令的非临时性计算机可读存储介质,例如包括指令的存储器704,上述指令可由电子设备700的处理器720执行以完成上述方法。例如,所述非临时性计算机可读存储介质可以是ROM、随机存取存储器(RAM)、CD-ROM、磁带、软盘和光数据存储设备等。
一种非临时性计算机可读存储介质,当所述存储介质中的指令由终端的处理器执行时,使得终端能够执行一种固件升级方法,所述方法包括:
在所述统一可扩展固件接口下,运行网页服务;其中,所述网页服务用于对所述统一可扩展固件接口的模块文件进行升级;
接收所述网页服务返回的升级后的目标模块文件和对应的升级指令;
响应于所述升级指令,将所述升级后的目标模块文件写入闪存,并覆盖所述闪存中存储的升级前的目标模块文件。
可选地,所述接收所述网页服务返回的升级后的目标模块文件和对应的升级指令包括:
在所述统一可扩展固件接口下,通过超文本传输协议,接收基于胶囊结构封装的所述升级后的目标模块文件,以及对应的升级指令。
可选地,所述响应于所述升级指令,将所述升级后的目标模块文件写入闪存,并覆盖所述闪存中存储的升级前的目标模块文件包括:
响应于所述升级指令,通过胶囊式固件升级协议,对所述基于胶囊结构封装的所述升级后的目标模块文件进行解析和校验,得到所述升级后的目标模块文件;
若校验通过,则对所述统一可扩展固件接口进行重启,并在重启后将所述升级后的目标模块文件写入闪存,并覆盖所述闪存中存储的升级前的目标模块文件;
若校验不通过,则向所述网页服务返回重新发送请求。
可选地,在所述对所述统一可扩展固件接口进行重启之前,所述方法还包括:
向所述网页服务返回开始升级的状态;
所述方法还包括:
向所述网页服务回复所述升级后的目标模块文件的升级进度。
一种非临时性计算机可读存储介质,当所述存储介质中的指令由终端的处理器执行时,使得终端能够执行一种固件升级方法,所述方法包括:
访问统一可扩展固件接口上运行的网页服务;其中,所述网页服务用于对所述统一可扩展固件接口的模块文件进行升级;
通过所述网页服务,从所述统一可扩展固件接口的模块文件中,选择要升级的目标模块文件;
针对所述要升级的目标模块文件,将升级后的目标模块文件和对应的升级指令发送给所述统一可扩展固件接口,以供所述统一可扩展固件接口接收所述网页服务返回的升级后的目标模块文件和对应的升级指令,响应于所述升级指令,将所述升级后的目标模块文件写入闪存,并覆盖所述闪存中存储的升级前的目标模块文件。
本说明书中的各个实施例均采用递进的方式描述,每个实施例重点说明的都是与其他实施例的不同之处,各个实施例之间相同相似的部分互相参见即可。
本领域内的技术人员应明白,本发明实施例的实施例可提供为方法、装置、或计算机程序产品。因此,本发明实施例可采用完全硬件实施例、完全软件实施例、或结合软件和硬件方面的实施例的形式。而且,本发明实施例可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器、CD-ROM、光学存储器等)上实施的计算机程序产品的形式。
本发明实施例是参照根据本发明实施例的方法、终端设备(系统)、和计算机程序产品的流程图和/或方框图来描述的。应理解可由计算机程序指令实现流程图和/或方框图中的每一流程和/或方框、以及流程图和/或方框图中的流程和/或方框的结合。可提供这些计算机程序指令到通用计算机、专用计算机、嵌入式处理机或其他可编程数据处理终端设备的处理器以产生一个机器,使得通过计算机或其他可编程数据处理终端设备的处理器执行的指令产生用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的装置。
这些计算机程序指令也可存储在能引导计算机或其他可编程数据处理终端设备以特定方式工作的计算机可读存储器中,使得存储在该计算机可读存储器中的指令产生包括指令装置的制造品,该指令装置实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能。
这些计算机程序指令也可装载到计算机或其他可编程数据处理终端设备上,使得在计算机或其他可编程终端设备上执行一系列操作步骤以产生计算机实现的处理,从而在计算机或其他可编程终端设备上执行的指令提供用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的步骤。
尽管已描述了本发明实施例的优选实施例,但本领域内的技术人员一旦得知了基本创造性概念,则可对这些实施例做出另外的变更和修改。所以,所附权利要求意欲解释为包括优选实施例以及落入本发明实施例范围的所有变更和修改。
最后,还需要说明的是,在本文中,诸如第一和第二等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者终端设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者终端设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、物品或者终端设备中还存在另外的相同要素。
以上对本发明所提供的一种固件升级方法、一种固件升级装置、一种电子设备、一种可读存储介质,进行了详细介绍,本文中应用了具体个例对本发明的原理及实施方式进行了阐述,以上实施例的说明只是用于帮助理解本发明的方法及其核心思想;同时,对于本领域的一般技术人员,依据本发明的思想,在具体实施方式及应用范围上均会有改变之处,综上所述,本说明书内容不应理解为对本发明的限制。

Claims (12)

1.一种固件升级方法,其特征在于,应用于统一可扩展固件接口,包括:
在所述统一可扩展固件接口下,运行网页服务;其中,所述网页服务用于对所述统一可扩展固件接口的模块文件进行升级;
接收所述网页服务返回的升级后的目标模块文件和对应的升级指令;
响应于所述升级指令,将所述升级后的目标模块文件写入闪存,并覆盖所述闪存中存储的升级前的目标模块文件。
2.根据权利要求1所述的方法,其特征在于,所述接收所述网页服务返回的升级后的目标模块文件和对应的升级指令包括:
在所述统一可扩展固件接口下,通过超文本传输协议,接收基于胶囊结构封装的所述升级后的目标模块文件,以及对应的升级指令。
3.根据权利要求2所述的方法,其特征在于,所述响应于所述升级指令,将所述升级后的目标模块文件写入闪存,并覆盖所述闪存中存储的升级前的目标模块文件包括:
响应于所述升级指令,通过胶囊式固件升级协议,对所述基于胶囊结构封装的所述升级后的目标模块文件进行解析和校验,得到所述升级后的目标模块文件;
若校验通过,则对所述统一可扩展固件接口进行重启,并在重启后将所述升级后的目标模块文件写入闪存,并覆盖所述闪存中存储的升级前的目标模块文件;
若校验不通过,则向所述网页服务返回重新发送请求。
4.根据权利要求3所述的方法,其特征在于,在所述对所述统一可扩展固件接口进行重启之前,所述方法还包括:
向所述网页服务返回开始升级的状态;
所述方法还包括:
向所述网页服务回复所述升级后的目标模块文件的升级进度。
5.一种固件升级方法,其特征在于,应用于远程终端,包括:
访问统一可扩展固件接口上运行的网页服务;其中,所述网页服务用于对所述统一可扩展固件接口的模块文件进行升级;
通过所述网页服务,从所述统一可扩展固件接口的模块文件中,选择要升级的目标模块文件;
针对所述要升级的目标模块文件,将升级后的目标模块文件和对应的升级指令发送给所述统一可扩展固件接口,以供所述统一可扩展固件接口接收所述网页服务返回的升级后的目标模块文件和对应的升级指令,响应于所述升级指令,将所述升级后的目标模块文件写入闪存,并覆盖所述闪存中存储的升级前的目标模块文件。
6.一种固件升级装置,其特征在于,应用于统一可扩展固件接口,包括:
服务运行模块,用于在所述统一可扩展固件接口下,运行网页服务;其中,所述网页服务用于对所述统一可扩展固件接口的模块文件进行升级;
指令接收模块,用于接收所述网页服务返回的升级后的目标模块文件和对应的升级指令;
文件写入模块,用于响应于所述升级指令,将所述升级后的目标模块文件写入闪存,并覆盖所述闪存中存储的升级前的目标模块文件。
7.根据权利要求6所述的装置,其特征在于,所述指令接收模块包括:
接收子模块,用于在所述统一可扩展固件接口下,通过超文本传输协议,接收基于胶囊结构封装的所述升级后的目标模块文件,以及对应的升级指令。
8.根据权利要求7所述的装置,其特征在于,所述文件写入模块包括:
解析校验子模块,用于响应于所述升级指令,通过胶囊式固件升级协议,对所述基于胶囊结构封装的所述升级后的目标模块文件进行解析和校验,得到所述升级后的目标模块文件;
重启子模块,用于若校验通过,则对所述统一可扩展固件接口进行重启,并在重启后将所述升级后的目标模块文件写入闪存,并覆盖所述闪存中存储的升级前的目标模块文件;
重发子模块,用于若校验不通过,则向所述网页服务返回重新发送请求。
9.根据权利要求8所述的装置,其特征在于,所述装置还包括:
状态返回模块,用于在所述对所述统一可扩展固件接口进行重启之前,向所述网页服务返回开始升级的状态;
所述装置还包括:
进度回复模块,用于向所述网页服务回复所述升级后的目标模块文件的升级进度。
10.一种固件升级装置,其特征在于,应用于远程终端,包括:
服务访问模块,用于访问统一可扩展固件接口上运行的网页服务;其中,所述网页服务用于对所述统一可扩展固件接口的模块文件进行升级;
文件选择模块,用于通过所述网页服务,从所述统一可扩展固件接口的模块文件中,选择要升级的目标模块文件;
指令发送模块,用于针对所述要升级的目标模块文件,将升级后的目标模块文件和对应的升级指令发送给所述统一可扩展固件接口,以供所述统一可扩展固件接口接收所述网页服务返回的升级后的目标模块文件和对应的升级指令,响应于所述升级指令,将所述升级后的目标模块文件写入闪存,并覆盖所述闪存中存储的升级前的目标模块文件。
11.一种电子设备,其特征在于,包括处理器、通信接口、存储器和通信总线,其中,处理器,通信接口,存储器通过通信总线完成相互间的通信;
存储器,用于存放计算机程序;
处理器,用于执行存储器上所存放的程序时,实现权利要求1-5任一所述的方法步骤。
12.一种可读存储介质,其特征在于,当所述存储介质中的指令由电子设备的处理器执行时,使得电子设备能够执行如方法权利要求1-5中一个或多个所述的固件升级方法。
CN202111470630.1A 2021-12-03 2021-12-03 一种固件升级方法、装置、电子设备及存储介质 Pending CN116225500A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202111470630.1A CN116225500A (zh) 2021-12-03 2021-12-03 一种固件升级方法、装置、电子设备及存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202111470630.1A CN116225500A (zh) 2021-12-03 2021-12-03 一种固件升级方法、装置、电子设备及存储介质

Publications (1)

Publication Number Publication Date
CN116225500A true CN116225500A (zh) 2023-06-06

Family

ID=86589685

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202111470630.1A Pending CN116225500A (zh) 2021-12-03 2021-12-03 一种固件升级方法、装置、电子设备及存储介质

Country Status (1)

Country Link
CN (1) CN116225500A (zh)

Similar Documents

Publication Publication Date Title
EP2998899A1 (en) Method and apparatus for running application program
US9886264B2 (en) Method and device for upgrading firmware
US9870239B2 (en) Method and device for running application program
JP2017505966A (ja) ファームウェアアップグレード方法、装置、プログラム及び記録媒体
CN105094931A (zh) 软件升级方法及装置
EP3428790B1 (en) Method and device for displaying application interface
CN107423218B (zh) 应用测试方法、装置及终端
CN107239351B (zh) 粘贴方法及装置
CN109117144B (zh) 页面处理方法、装置、终端及存储介质
CN107463372B (zh) 一种数据驱动的页面更新方法和装置
CN105183493A (zh) 网络信息的显示方法和装置
CN111222014B (zh) 请求处理方法、装置、电子设备及存储介质
CN115185717A (zh) 接口调用方法、装置、电子设备和存储介质
CN113596175A (zh) 场景同步方法、终端、服务器及系统
CN111198706A (zh) 更新系统功能的方法、更新系统功能的装置及存储介质
CN105808304B (zh) 代码部署方法、装置及系统
CN111061452A (zh) 用户界面的语音控制方法和装置
CN114416127A (zh) 终端软件升级方法、终端软件升级装置及存储介质
CN109976872B (zh) 数据处理方法、装置、电子设备及存储介质
CN107632835A (zh) 应用安装方法及装置
CN107861666B (zh) 桌面应用安装方法及装置
CN112860625B (zh) 数据获取方法、数据存储方法、装置、设备及存储介质
EP3185515B1 (en) Method and device for inputting information
CN116225500A (zh) 一种固件升级方法、装置、电子设备及存储介质
CN115086295A (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