CN116841584A - 一种固件升级方法、装置、设备及介质 - Google Patents
一种固件升级方法、装置、设备及介质 Download PDFInfo
- Publication number
- CN116841584A CN116841584A CN202310796696.2A CN202310796696A CN116841584A CN 116841584 A CN116841584 A CN 116841584A CN 202310796696 A CN202310796696 A CN 202310796696A CN 116841584 A CN116841584 A CN 116841584A
- Authority
- CN
- China
- Prior art keywords
- firmware
- basic
- new
- module
- current
- 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
Links
- 238000000034 method Methods 0.000 title claims abstract description 80
- 230000008569 process Effects 0.000 claims abstract description 31
- 230000008859 change Effects 0.000 claims abstract description 14
- 230000006870 function Effects 0.000 claims description 59
- 238000012544 monitoring process Methods 0.000 claims description 19
- 238000012545 processing Methods 0.000 claims description 19
- 238000013213 extrapolation Methods 0.000 claims description 17
- 238000004590 computer program Methods 0.000 claims description 15
- 238000012790 confirmation Methods 0.000 description 4
- 238000010586 diagram Methods 0.000 description 4
- 230000009471 action Effects 0.000 description 3
- 238000011161 development Methods 0.000 description 3
- 230000006978 adaptation Effects 0.000 description 2
- 238000013473 artificial intelligence Methods 0.000 description 2
- 238000004891 communication Methods 0.000 description 2
- 238000012986 modification Methods 0.000 description 2
- 230000004048 modification Effects 0.000 description 2
- 238000009877 rendering Methods 0.000 description 2
- 230000000694 effects Effects 0.000 description 1
- 238000005516 engineering process Methods 0.000 description 1
- 238000010801 machine learning Methods 0.000 description 1
- 230000007246 mechanism Effects 0.000 description 1
- 230000005055 memory storage Effects 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
- 230000002093 peripheral effect Effects 0.000 description 1
- 230000000750 progressive effect Effects 0.000 description 1
- 230000001052 transient effect Effects 0.000 description 1
- 230000001960 triggered effect Effects 0.000 description 1
- 238000010200 validation analysis Methods 0.000 description 1
- 238000012795 verification Methods 0.000 description 1
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/60—Software deployment
- G06F8/65—Updates
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
本发明公开了一种固件升级方法、装置、设备及介质,涉及服务器技术领域。方案考虑到基本输入输出系统固件升级前后布局的变化,在升级过程中对新的基础固件进行监测;当确认新的基础固件相比于当前保留的基础固件具有新增的功能模块时,基于新增的功能模块对当前的基础固件进行刷新,使其适应基本输入输出系统的固件升级。避免了将原始布局固件对应更新后的设备状态,防止了服务器外插网卡的丢失,提高了用户体验。
Description
技术领域
本发明涉及服务器技术领域,特别是涉及一种固件升级方法、装置、设备及介质。
背景技术
目前,主流的服务器架构以Intel x86架构系列为主。由于时代的发展需要,现在迫切需要一种新的形态的服务器架构。因此,进阶精简指令集机器(Advanced RISCMachine,ARM)架构的服务器应运而生。近年来,ARM架构的服务器得到迅猛发展。
然而,ARM服务器相对于目前已经成熟Intel x86服务器的生态环境还存在一定差距。其中,ARM服务器通过基本输入输出系统(Basic Input Output System,BIOS)对中央处理器(Central Processing Unit,CPU)升级自身的基础固件时,通常保留原有的基础固件配置;但是BIOS的布局(layout)前后存在变化,导致服务器在使用外插网卡时,例如使用高速串行计算机扩展总线标准(Peripheral Component Interconnect Express,PCIE)外插网卡时,存在外插网卡丢失的现象。
鉴于上述问题,如何避免服务器BIOS升级基础固件导致外插网卡丢失,是该领域技术人员亟待解决的问题。
发明内容
本发明的目的是提供一种固件升级方法、装置、设备及介质,以避免服务器BIOS升级基础固件导致外插网卡丢失的问题。
为解决上述技术问题,本发明提供一种固件升级方法,包括:
保留服务器的中央处理器当前的基础固件,并启动对所述服务器的基本输入输出系统的固件升级;
通过所述基本输入输出系统监测升级过程中新的基础固件;
判断新的所述基础固件相比于当前的所述基础固件是否具有新增的功能模块;
若是,则基于新增的所述功能模块对当前的所述基础固件进行刷新;
重启所述服务器,以完成对所述基本输入输出系统的固件升级。
一方面,所述判断新的所述基础固件相比于当前的所述基础固件是否具有新增的功能模块包括:
获取新的所述基础固件的所述功能模块的大小与当前的所述基础固件的所述功能模块的大小的差值;
判断所述差值是否大于第一阈值;
若是,则确认新的所述基础固件相比于当前的所述基础固件具有新增的所述功能模块。
另一方面,所述判断新的所述基础固件相比于当前的所述基础固件是否具有新增的功能模块包括:
分别获取新的所述基础固件的所述功能模块的16进制模块解析值和哈希值;
分别获取当前的所述基础固件的所述功能模块的所述16进制模块解析值和所述哈希值;
判断是否新的所述基础固件的所述功能模块的16进制模块解析值与当前的所述基础固件的所述功能模块的所述16进制模块解析值不同,且新的所述基础固件的所述功能模块的所述哈希值与当前的所述基础固件的所述功能模块的所述哈希值不同;
若是,则确认新的所述基础固件相比于当前的所述基础固件具有新增的所述功能模块。
另一方面,所述基于新增的所述功能模块对当前的所述基础固件进行刷新包括:
根据新的所述基础固件对当前的所述基础固件进行全部清除刷新,以将新的所述基础固件作为当前的所述基础固件。
另一方面,所述基于新增的所述功能模块对当前的所述基础固件进行刷新包括:
获取新的所述基础固件中相比于当前的所述基础固件新增的所述功能模块;
将新增的所述功能模块刷新至当前的所述基础固件中。
另一方面,在确认新的所述基础固件相比于当前的所述基础固件具有新增的所述功能模块之后,还包括:
输出表征在所述基本输入输出系统固件升级过程中所述基础固件发生变化的提示信息。
另一方面,还包括:
监测所述服务器的各外插部件在每次所述服务器重启后的在位状态;
分别判断各所述外插部件的所述在位状态是否发生变化;
若是,则获取对应所述外部插件的初始化引导文件;
根据所述初始化引导文件初始化对应的所述外部插件。
为解决上述技术问题,本发明还提供一种固件升级装置,包括:
升级启动模块,用于保留服务器的中央处理器当前的基础固件,并启动对所述服务器的基本输入输出系统的固件升级;
监测模块,用于通过所述基本输入输出系统监测升级过程中新的基础固件;
判断模块,用于判断新的所述基础固件相比于当前的所述基础固件是否具有新增的功能模块;若是,则触发刷新模块;
所述刷新模块,用于基于新增的所述功能模块对当前的所述基础固件进行刷新;
重启模块,用于重启所述服务器,以完成对所述基本输入输出系统的固件升级。
为解决上述技术问题,本发明还提供一种固件升级设备,包括:
存储器,用于存储计算机程序;
处理器,用于执行所述计算机程序时实现上述的固件升级方法的步骤。
为解决上述技术问题,本发明还提供一种计算机可读存储介质,所述计算机可读存储介质上存储有计算机程序,所述计算机程序被处理器执行时实现上述的固件升级方法的步骤。
本发明所提供的固件升级方法,通过保留服务器的中央处理器当前的基础固件,并启动对服务器的基本输入输出系统的固件升级;通过基本输入输出系统监测升级过程中新的基础固件;判断新的基础固件相比于当前的基础固件是否具有新增的功能模块;若是,则基于新增的功能模块对当前的基础固件进行刷新;重启服务器,以完成对基本输入输出系统的固件升级。由此可知,上述方案考虑到基本输入输出系统固件升级前后布局的变化,在升级过程中对新的基础固件进行监测;当确认新的基础固件相比于当前保留的基础固件具有新增的功能模块时,基于新增的功能模块对当前的基础固件进行刷新,使其适应基本输入输出系统的固件升级。避免了将原始布局固件对应更新后的设备状态,防止了服务器外插网卡的丢失,提高了用户体验。
此外,本发明还提供了一种固件升级装置、设备及介质,效果同上。
附图说明
为了更清楚地说明本发明实施例,下面将对实施例中所需要使用的附图做简单的介绍,显而易见地,下面描述中的附图仅仅是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1为本发明实施例提供的一种固件升级方法的流程图;
图2为本发明实施例提供的一种固件升级装置的示意图;
图3为本发明实施例提供的一种固件升级设备的示意图。
具体实施方式
下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分实施例,而不是全部实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下,所获得的所有其他实施例,都属于本发明保护范围。
本发明的核心是提供一种固件升级方法、装置、设备及介质,以避免服务器BIOS升级基础固件导致外插网卡丢失的问题。
为了使本技术领域的人员更好地理解本发明方案,下面结合附图和具体实施方式对本发明作进一步的详细说明。
目前,主流的服务器还是Intel x86架构系列为主。Intel x86架构的服务器在近些年的发展一直停滞不前;由于时代的发展需要,服务器设备更新换代的提速,现在迫切需要一种新的形态服务器架构。因此,ARM架构的服务器应运而生。近年来,ARM架构的服务器得到迅猛发展。但是ARM服务器相对于已经成熟Intel x86服务器的生态环境还存在一定差距。ARM架构服务器的生态系统环境在起步阶段还存在着一些意想不到的问题。
其中,在ARM服务器的CPU升级自身的基础固件时,使用保留配置的更新场景,即保留原有的基础固件;同时由于BIOS layout前后存在变化,导致服务器在使用例如PCIE网卡的外插网卡时,存在外插网卡丢失的现象,这样会对用户造成不可挽回的损失。因此,为了解决上述问题,本发明提供了一种固件升级方法。需要注意的是,本发明所提供的方法应用于ARM架构的服务器中,包括但不限于FT2000+ARM服务器。
图1为本发明实施例提供的一种固件升级方法的流程图。如图1所示,方法包括:
S10:保留服务器的中央处理器当前的基础固件,并启动对服务器的基本输入输出系统的固件升级。
在具体实施中,存在外插网卡的ARM服务器(例如FT2000+服务器)上电开机,准备对服务器固件BIOS进行升级。在升级之前保留服务器的CPU当前的基础固件,并启动对服务器的基本输入输出系统的固件升级,即保留配置刷新。可以理解的是,基础固件是固化在集成电路内部的程序代码,负责控制和协调集成电路的功能。
S11:通过基本输入输出系统监测升级过程中新的基础固件。
本实施例中,在服务器更新BIOS固件时,增加服务器固件BIOS对基础固件的功能模块的识别区分能力。具体通过基本输入输出系统监测升级过程中新的基础固件。
S12:判断新的基础固件相比于当前的基础固件是否具有新增的功能模块;若是,则进入步骤S13。若否,则进入步骤S14。
S13:基于新增的功能模块对当前的基础固件进行刷新。
S14:重启服务器,以完成对基本输入输出系统的固件升级。
进一步判断新的基础固件相比于保留的当前的基础固件是否具有新增的功能模块。本实施例中对于是否存在新增的功能模块的具体的判断依据不做限制,可通过比较新的基础固件与当前的基础固件的大小确定,还可通过其他方式确定,根据具体的实施情况而定。
当确认新的基础固件相比于当前的基础固件具有新增的功能模块时,为了使新增的功能模块跟随更新,具体需要基于新增的功能模块对当前的基础固件进行刷新,从而使当前的基础固件具有新增的功能模块。最后重启服务器,完成对基本输入输出系统的固件升级。需要注意的是,本实施例中对于基础固件具体的刷新方式不做限制,根据具体的实施情况而定。此外,当确认新的基础固件相比于当前的基础固件不具有新增的功能模块时,则重启服务器即可。重启服务器后外插网卡不会丢失。
本实施例中,通过保留服务器的中央处理器当前的基础固件,并启动对服务器的基本输入输出系统的固件升级;通过基本输入输出系统监测升级过程中新的基础固件;判断新的基础固件相比于当前的基础固件是否具有新增的功能模块;若是,则基于新增的功能模块对当前的基础固件进行刷新;重启服务器,以完成对基本输入输出系统的固件升级。由此可知,上述方案考虑到基本输入输出系统固件升级前后布局的变化,在升级过程中对新的基础固件进行监测;当确认新的基础固件相比于当前保留的基础固件具有新增的功能模块时,基于新增的功能模块对当前的基础固件进行刷新,使其适应基本输入输出系统的固件升级。避免了将原始布局固件对应更新后的设备状态,防止了服务器外插网卡的丢失,提高了用户体验。
为了实现对CPU的基础固件是否存在新增的功能模块的判断,在上述实施例的基础上,作为一种优选的实施例,判断新的基础固件相比于当前的基础固件是否具有新增的功能模块包括:
S120:获取新的基础固件的功能模块的大小与当前的基础固件的功能模块的大小的差值。
S121:判断差值是否大于第一阈值;若是,则进入步骤S122。
S122:确认新的基础固件相比于当前的基础固件具有新增的功能模块。
一般情况下,基础固件不会出现特别重大的变化,尤其是基础的layout的布局变化。由于在上述实施例中,为了能够对基础固件的变化进行准确捕捉,增加了BIOS对于CPU的基础固件基础的模块变化识别功能;因此,本实施例中可具体通过获取新的基础固件的功能模块的大小与当前的基础固件的功能模块的大小的差值,根据差值大小对CPU的基础固件模块大小进行比对校验。可以理解的是,大小校验的精确度可更改,以增加可以识别的最小分辨值。
当确认差值大于第一阈值时,可确认新的基础固件相比于当前的基础固件具有新增的功能模块。反之则不具有新增的功能模块。需要注意的是,本实施例中对于第一阈值大小不做限制,根据具体的实施情况而定。
此外,在一些实施例中还可通过其他方式对CPU的基础固件是否存在新增的功能模块进行判断。具体地,判断新的基础固件相比于当前的基础固件是否具有新增的功能模块包括:
S123:分别获取新的基础固件的功能模块的16进制模块解析值和哈希值。
S124:分别获取当前的基础固件的功能模块的16进制模块解析值和哈希值。
S125:判断是否新的基础固件的功能模块的16进制模块解析值与当前的基础固件的功能模块的16进制模块解析值不同,且新的基础固件的功能模块的哈希值与当前的基础固件的功能模块的哈希值不同;若是,则进入步骤S126。
S126:确认新的基础固件相比于当前的基础固件具有新增的功能模块。
在具体实施中,增加对基础固件的功能模块的模块值的比对。通过引入16进制模块解析值的全栈比对校验机制,使得功能模块通过解析得到16进制值形式的模块值以进行比对;同时采用功能模块的哈希值比对作为辅助校验方式引入。
具体通过分别获取新的基础固件的功能模块的16进制模块解析值和哈希值,并分别获取当前的基础固件的功能模块的16进制模块解析值和哈希值。进一步判断是否新的基础固件的功能模块的16进制模块解析值与当前的基础固件的功能模块的16进制模块解析值不同,且新的基础固件的功能模块的哈希值与当前的基础固件的功能模块的哈希值不同;若是,则确认新的基础固件相比于当前的基础固件具有新增的功能模块。
以上,实现了对CPU的基础固件是否存在新增的功能模块的判断,以便于对当前的基础固件的刷新。
当BIOS固件识别到CPU的基础固件出现变化时,即确定CPU的基础固件存在新增的功能模块,此时保留原有的CPU的基础固件配置可能存在问题。因此,在上述实施例的基础上,在一些实施例中,基于新增的功能模块对当前的基础固件进行刷新包括:
S130:根据新的基础固件对当前的基础固件进行全部清除刷新,以将新的基础固件作为当前的基础固件。
在具体实施中,可直接根据新的基础固件对当前的基础固件进行全部清除刷新,以将新的基础固件作为当前的基础固件。从而使新增的功能模块得到刷新升级,能够有效避免服务器外插网卡的丢失。
此外,由于新的基础固件与当前的基础固件实际上只相差了新增的功能模块,因此在一些实施例中还可采用另一种CPU的基础固件的刷新方式。基于新增的功能模块对当前的基础固件进行刷新包括:
S131:获取新的基础固件中相比于当前的基础固件新增的功能模块;
S132:将新增的功能模块刷新至当前的基础固件中。
具体获取新的基础固件中相比于当前的基础固件新增的功能模块,将新增的功能模块刷新至当前的基础固件中,从而通过局部替换的方式使当前的基础固件完成新增的功能模块的刷新。
以上,通过两种方式完成了对当前的基础固件的刷新,避免了新增的功能模块表征的重要更新功能无法更新导致外插网卡丢失的问题。
在具体实施中,为了提醒用户CPU的基础固件存在新增的功能模块,同时使用户对刷新方式进行自主选择,在上述实施例的基础上,在一些实施例中,在确认新的基础固件相比于当前的基础固件具有新增的功能模块之后,还包括:
S15:输出表征在基本输入输出系统固件升级过程中基础固件发生变化的提示信息。
具体地,当BIOS固件识别到CPU的基础固件出现变化时,即确认新的基础固件相比于当前的基础固件具有新增的功能模块,此时输出表征在基本输入输出系统固件升级过程中基础固件发生变化的提示信息,从而使用户注意到当前的基础固件的情况,进而选择是采取全部清除刷新的方式,还是通过局部替换的方式进行刷新,具有良好的自主选择权。
为了在服务器不断重启过程中进一步避免外插设备丢失,在一些实施例中,上述方法还包括:
S16:监测服务器的各外插部件在每次服务器重启后的在位状态。
S17:分别判断各外插部件的在位状态是否发生变化;若是,则进入步骤S18。
S18:获取对应外部插件的初始化引导文件。
S19:根据初始化引导文件初始化对应的外部插件。
具体地,持续监测服务器的各外插部件在每次服务器重启后的在位状态,将各外插部件在每次服务器重启后的在位状态进行记录。进一步分别判断各外插部件的在位状态是否发生变化。可以理解的是,在位状态发生变化即代表连续两次的在位状态不同。
若确认外插部件的在位状态发生变化,则确认该外插部件在服务器两次重启后的在位状态不同。此时需要通过服务器的BIOS固件搜寻该外插部件上次的初始化引导文件,通过该初始化引导文件对外插部件进行初始化,以避免外插部件的丢失。
在上述实施例中,对于固件升级方法进行了详细描述,本发明还提供固件升级装置对应的实施例。
图2为本发明实施例提供的一种固件升级装置的示意图。如图2所示,固件升级装置包括:
升级启动模块10,用于保留服务器的中央处理器当前的基础固件,并启动对服务器的基本输入输出系统的固件升级。
监测模块11,用于通过基本输入输出系统监测升级过程中新的基础固件。
判断模块12,用于判断新的基础固件相比于当前的基础固件是否具有新增的功能模块;若是,则触发刷新模块13。
刷新模块13,用于基于新增的功能模块对当前的基础固件进行刷新。
重启模块14,用于重启服务器,以完成对基本输入输出系统的固件升级。
作为一种优选的实施例,判断模块包括:
差值获取模块,用于获取新的基础固件的功能模块的大小与当前的基础固件的功能模块的大小的差值;
阈值判断模块,用于判断差值是否大于第一阈值;若是,则触发确认模块;
确认模块,用于确认新的基础固件相比于当前的基础固件具有新增的功能模块。
作为一种优选的实施例,判断模块包括:
第一数值获取模块,用于分别获取新的基础固件的功能模块的16进制模块解析值和哈希值;
第二数值获取模块,用于分别获取当前的基础固件的功能模块的16进制模块解析值和哈希值;
比较判断模块,用于判断是否新的基础固件的功能模块的16进制模块解析值与当前的基础固件的功能模块的16进制模块解析值不同,且新的基础固件的功能模块的哈希值与当前的基础固件的功能模块的哈希值不同;若是,则触发确认模块;
确认模块,用于确认新的基础固件相比于当前的基础固件具有新增的功能模块。
作为一种优选的实施例,刷新模块包括:
清除刷新模块,用于根据新的基础固件对当前的基础固件进行全部清除刷新,以将新的基础固件作为当前的基础固件。
作为一种优选的实施例,刷新模块包括:
功能模块获取模块,用于获取新的基础固件中相比于当前的基础固件新增的功能模块;
替换刷新模块,用于将新增的功能模块刷新至当前的基础固件中。
作为一种优选的实施例,还包括:
提示信息输出模块,用于在确认新的基础固件相比于当前的基础固件具有新增的功能模块之后,输出表征在基本输入输出系统固件升级过程中基础固件发生变化的提示信息。
作为一种优选的实施例,还包括:
在位状态监测模块,用于监测服务器的各外插部件在每次服务器重启后的在位状态;
在位状态判断模块,用于分别判断各外插部件的在位状态是否发生变化;若是,则触发文件获取模块;
文件获取模块,用于获取对应外部插件的初始化引导文件;
初始化模块,用于根据初始化引导文件初始化对应的外部插件。
本实施例中,固件升级装置包括升级启动模块、监测模块、判断模块、刷新模块和重启模块。固件升级装置在运行时能够实现上述固件升级方法的全部步骤。通过保留服务器的中央处理器当前的基础固件,并启动对服务器的基本输入输出系统的固件升级;通过基本输入输出系统监测升级过程中新的基础固件;判断新的基础固件相比于当前的基础固件是否具有新增的功能模块;若是,则基于新增的功能模块对当前的基础固件进行刷新;重启服务器,以完成对基本输入输出系统的固件升级。由此可知,上述方案考虑到基本输入输出系统固件升级前后布局的变化,在升级过程中对新的基础固件进行监测;当确认新的基础固件相比于当前保留的基础固件具有新增的功能模块时,基于新增的功能模块对当前的基础固件进行刷新,使其适应基本输入输出系统的固件升级。避免了将原始布局固件对应更新后的设备状态,防止了服务器外插网卡的丢失,提高了用户体验。
图3为本发明实施例提供的一种固件升级设备的示意图。如图3所示,固件升级设备包括:
存储器20,用于存储计算机程序。
处理器21,用于执行计算机程序时实现如上述实施例中所提到的固件升级方法的步骤。
本实施例提供的固件升级设备可以包括但不限于智能手机、平板电脑、笔记本电脑或台式电脑等。
其中,处理器21可以包括一个或多个处理核心,比如4核心处理器、8核心处理器等。处理器21可以采用数字信号处理器(Digital Signal Processor,DSP)、现场可编程门阵列(Field-Programmable Gate Array,FPGA)、可编程逻辑阵列(Programmable LogicArray,PLA)中的至少一种硬件形式来实现。处理器21也可以包括主处理器和协处理器,主处理器是用于对在唤醒状态下的数据进行处理的处理器,也称中央处理器(CentralProcessing Unit,CPU);协处理器是用于对在待机状态下的数据进行处理的低功耗处理器。在一些实施例中,处理器21可以在集成有图形处理器(Graphics Processing Unit,GPU),GPU用于负责显示屏所需要显示的内容的渲染和绘制。一些实施例中,处理器21还可以包括人工智能(Artificial Intelligence,AI)处理器,该AI处理器用于处理有关机器学习的计算操作。
存储器20可以包括一个或多个计算机可读存储介质,该计算机可读存储介质可以是非暂态的。存储器20还可包括高速随机存取存储器,以及非易失性存储器,比如一个或多个磁盘存储设备、闪存存储设备。本实施例中,存储器20至少用于存储以下计算机程序201,其中,该计算机程序被处理器21加载并执行之后,能够实现前述任一实施例公开的固件升级方法的相关步骤。另外,存储器20所存储的资源还可以包括操作系统202和数据203等,存储方式可以是短暂存储或者永久存储。其中,操作系统202可以包括Windows、Unix、Linux等。数据203可以包括但不限于固件升级方法涉及到的数据。
在一些实施例中,固件升级设备还可包括有显示屏22、输入输出接口23、通信接口24、电源25以及通信总线26。
本领域技术人员可以理解,图3中示出的结构并不构成对固件升级设备的限定,可以包括比图示更多或更少的组件。
本实施例中,固件升级设备包括存储器和处理器。存储器用于存储计算机程序。处理器用于执行计算机程序时实现如上述实施例中所提到的固件升级方法的步骤。通过保留服务器的中央处理器当前的基础固件,并启动对服务器的基本输入输出系统的固件升级;通过基本输入输出系统监测升级过程中新的基础固件;判断新的基础固件相比于当前的基础固件是否具有新增的功能模块;若是,则基于新增的功能模块对当前的基础固件进行刷新;重启服务器,以完成对基本输入输出系统的固件升级。由此可知,上述方案考虑到基本输入输出系统固件升级前后布局的变化,在升级过程中对新的基础固件进行监测;当确认新的基础固件相比于当前保留的基础固件具有新增的功能模块时,基于新增的功能模块对当前的基础固件进行刷新,使其适应基本输入输出系统的固件升级。避免了将原始布局固件对应更新后的设备状态,防止了服务器外插网卡的丢失,提高了用户体验。
最后,本发明还提供一种计算机可读存储介质对应的实施例。计算机可读存储介质上存储有计算机程序,计算机程序被处理器执行时实现如上述方法实施例中记载的步骤。
可以理解的是,如果上述实施例中的方法以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分或者该技术方案的全部或部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,执行本发明各个实施例所述方法的全部或部分步骤。而前述的存储介质包括:U盘、移动硬盘、只读存储器(Read-Only Memory,ROM)、随机存取存储器(Random Access Memory,RAM)、磁碟或者光盘等各种可以存储程序代码的介质。
本实施例中,计算机可读存储介质上存储有计算机程序,计算机程序被处理器执行时实现如上述方法实施例中记载的步骤。通过保留服务器的中央处理器当前的基础固件,并启动对服务器的基本输入输出系统的固件升级;通过基本输入输出系统监测升级过程中新的基础固件;判断新的基础固件相比于当前的基础固件是否具有新增的功能模块;若是,则基于新增的功能模块对当前的基础固件进行刷新;重启服务器,以完成对基本输入输出系统的固件升级。由此可知,上述方案考虑到基本输入输出系统固件升级前后布局的变化,在升级过程中对新的基础固件进行监测;当确认新的基础固件相比于当前保留的基础固件具有新增的功能模块时,基于新增的功能模块对当前的基础固件进行刷新,使其适应基本输入输出系统的固件升级。避免了将原始布局固件对应更新后的设备状态,防止了服务器外插网卡的丢失,提高了用户体验。
以上对本发明所提供的一种固件升级方法、装置、设备及介质进行了详细介绍。说明书中各个实施例采用递进的方式描述,每个实施例重点说明的都是与其他实施例的不同之处,各个实施例之间相同相似部分互相参见即可。对于实施例公开的装置而言,由于其与实施例公开的方法相对应,所以描述的比较简单,相关之处参见方法部分说明即可。应当指出,对于本技术领域的普通技术人员来说,在不脱离本发明原理的前提下,还可以对本发明进行若干改进和修饰,这些改进和修饰也落入本发明权利要求的保护范围内。
还需要说明的是,在本说明书中,诸如第一和第二等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、物品或者设备中还存在另外的相同要素。
Claims (10)
1.一种固件升级方法,其特征在于,包括:
保留服务器的中央处理器当前的基础固件,并启动对所述服务器的基本输入输出系统的固件升级;
通过所述基本输入输出系统监测升级过程中新的基础固件;
判断新的所述基础固件相比于当前的所述基础固件是否具有新增的功能模块;
若是,则基于新增的所述功能模块对当前的所述基础固件进行刷新;
重启所述服务器,以完成对所述基本输入输出系统的固件升级。
2.根据权利要求1所述的固件升级方法,其特征在于,所述判断新的所述基础固件相比于当前的所述基础固件是否具有新增的功能模块包括:
获取新的所述基础固件的所述功能模块的大小与当前的所述基础固件的所述功能模块的大小的差值;
判断所述差值是否大于第一阈值;
若是,则确认新的所述基础固件相比于当前的所述基础固件具有新增的所述功能模块。
3.根据权利要求1所述的固件升级方法,其特征在于,所述判断新的所述基础固件相比于当前的所述基础固件是否具有新增的功能模块包括:
分别获取新的所述基础固件的所述功能模块的16进制模块解析值和哈希值;
分别获取当前的所述基础固件的所述功能模块的所述16进制模块解析值和所述哈希值;
判断是否新的所述基础固件的所述功能模块的16进制模块解析值与当前的所述基础固件的所述功能模块的所述16进制模块解析值不同,且新的所述基础固件的所述功能模块的所述哈希值与当前的所述基础固件的所述功能模块的所述哈希值不同;
若是,则确认新的所述基础固件相比于当前的所述基础固件具有新增的所述功能模块。
4.根据权利要求3所述的固件升级方法,其特征在于,所述基于新增的所述功能模块对当前的所述基础固件进行刷新包括:
根据新的所述基础固件对当前的所述基础固件进行全部清除刷新,以将新的所述基础固件作为当前的所述基础固件。
5.根据权利要求3所述的固件升级方法,其特征在于,所述基于新增的所述功能模块对当前的所述基础固件进行刷新包括:
获取新的所述基础固件中相比于当前的所述基础固件新增的所述功能模块;
将新增的所述功能模块刷新至当前的所述基础固件中。
6.根据权利要求1所述的固件升级方法,其特征在于,在确认新的所述基础固件相比于当前的所述基础固件具有新增的所述功能模块之后,还包括:
输出表征在所述基本输入输出系统固件升级过程中所述基础固件发生变化的提示信息。
7.根据权利要求1至6任意一项所述的固件升级方法,其特征在于,还包括:
监测所述服务器的各外插部件在每次所述服务器重启后的在位状态;
分别判断各所述外插部件的所述在位状态是否发生变化;
若是,则获取对应所述外部插件的初始化引导文件;
根据所述初始化引导文件初始化对应的所述外部插件。
8.一种固件升级装置,其特征在于,包括:
升级启动模块,用于保留服务器的中央处理器当前的基础固件,并启动对所述服务器的基本输入输出系统的固件升级;
监测模块,用于通过所述基本输入输出系统监测升级过程中新的基础固件;
判断模块,用于判断新的所述基础固件相比于当前的所述基础固件是否具有新增的功能模块;若是,则触发刷新模块;
所述刷新模块,用于基于新增的所述功能模块对当前的所述基础固件进行刷新;
重启模块,用于重启所述服务器,以完成对所述基本输入输出系统的固件升级。
9.一种固件升级设备,其特征在于,包括:
存储器,用于存储计算机程序;
处理器,用于执行所述计算机程序时实现如权利要求1至7任一项所述的固件升级方法的步骤。
10.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质上存储有计算机程序,所述计算机程序被处理器执行时实现如权利要求1至7任一项所述的固件升级方法的步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202310796696.2A CN116841584A (zh) | 2023-06-30 | 2023-06-30 | 一种固件升级方法、装置、设备及介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202310796696.2A CN116841584A (zh) | 2023-06-30 | 2023-06-30 | 一种固件升级方法、装置、设备及介质 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN116841584A true CN116841584A (zh) | 2023-10-03 |
Family
ID=88162919
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202310796696.2A Pending CN116841584A (zh) | 2023-06-30 | 2023-06-30 | 一种固件升级方法、装置、设备及介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN116841584A (zh) |
-
2023
- 2023-06-30 CN CN202310796696.2A patent/CN116841584A/zh active Pending
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JP6272991B2 (ja) | プリブートファームウェア更新のための選択的パワーマネジメント | |
US8132055B2 (en) | Operating system-firmware interface update recovery | |
CN109408122B (zh) | 一种设备启动方法、电子设备和计算机存储介质 | |
US20140149644A1 (en) | Electronic apparatus, method of updating firmware, and computer-readable recording medium | |
CN112506745B (zh) | 内存温度读取方法、装置及计算机可读存储介质 | |
EP3614258B1 (en) | Retrieving updated firmware code | |
US7818622B2 (en) | Method for recovering data processing system failures | |
CN108701026A (zh) | 用于在存储器约束下管理进程的方法和装置 | |
CN116360831A (zh) | 一种应用程序升级方法、装置、电子设备及存储介质 | |
CN113010215B (zh) | 一种操作系统快速重启的方法、装置、设备及可读介质 | |
CN116578327B (zh) | 一种程序更新方法、装置及电子设备和存储介质 | |
CN116775413A (zh) | 一种pcie拓扑扫描方法、装置、设备及可读存储介质 | |
CN116841584A (zh) | 一种固件升级方法、装置、设备及介质 | |
CN115033261A (zh) | 一种程序更新方法、装置、设备及存储介质 | |
CN115357355A (zh) | 一种软件跨系统迁移的方法、装置、设备及可读存储介质 | |
CN113849229A (zh) | 服务器开机方法、装置、电子设备及可读存储介质 | |
CN111399871B (zh) | 一种hba卡的系统更新方法、装置、设备及介质 | |
CN114020211A (zh) | 存储空间管理方法、装置、设备及存储介质 | |
CN117806924B (zh) | 一种指示装置的控制方法、装置、服务器及介质 | |
CN112540889B (zh) | 在用户态调整硬盘启动顺序的方法、装置、设备及介质 | |
CN113268266B (zh) | 小程序渲染框架多版本并存管理方法、系统和介质 | |
CN114924802B (zh) | 基于bmc和bios的系统启动方法、装置设备及介质 | |
CN116841789A (zh) | 一种内存故障处理方法、装置、设备及介质 | |
CN117873441A (zh) | 一种定制选项的确定方法、装置、设备和介质 | |
CN116578309A (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 |