CN110399167A - 固件启动方法及装置、设备、存储介质 - Google Patents
固件启动方法及装置、设备、存储介质 Download PDFInfo
- Publication number
- CN110399167A CN110399167A CN201910578887.5A CN201910578887A CN110399167A CN 110399167 A CN110399167 A CN 110399167A CN 201910578887 A CN201910578887 A CN 201910578887A CN 110399167 A CN110399167 A CN 110399167A
- Authority
- CN
- China
- Prior art keywords
- firmware
- data
- management controller
- starting
- acquisition system
- 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.)
- Granted
Links
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/44—Arrangements for executing specific programs
- G06F9/4401—Bootstrapping
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- Theoretical Computer Science (AREA)
- Computer Security & Cryptography (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Stored Programmes (AREA)
Abstract
本申请实施例公开了固件启动方法及装置、设备、存储介质,其中,所述方法包括:启动管理控制器;控制所述管理控制器预先加载至少一个第一固件在启动中需要调用的数据集合;控制所述第一固件从所述数据集合中调用所需的第一数据;控制所述第一固件依据所述第一数据继续进行启动。
Description
技术领域
本申请实施例涉及电子技术,涉及但不限于固件启动方法及装置、设备、存储介质。
背景技术
基本输入/输出系统(Basic Input Output System,BIOS)是一组固化在计算机内主板上一个只读存储器(Read Only Memory,ROM)芯片上的程序,它保存着计算机最重要的基本输入输出程序、系统设置信息、开机后自检程序和系统自启动程序。
随着硬件发展迅速,传统式BIOS成为进步的包袱,目前已发展出最新的统一的可扩展固件接口(Unified Extensible Firmware Interface,UEFI),是一种详细描述类型接口的标准。这种接口用于操作系统自动从预启动的操作环境,加载到一种操作系统上。相比于传统BIOS,UEFI启动模式虽然能够缩短系统启动时间,但是系统启动时间仍然较长。
发明内容
有鉴于此,本申请实施例为解决相关技术中存在的至少一个问题而提供固件启动方法及装置、设备、存储介质。
本申请实施例的技术方案是这样实现的:
第一方面,本申请实施例提供一种固件启动方法,所述方法包括:启动管理控制器;控制所述管理控制器预先加载至少一个第一固件在启动中需要调用的数据集合;控制所述第一固件从所述数据集合中调用所需的第一数据;控制所述第一固件依据所述第一数据继续进行启动。
在其他实施例中,所述控制所述第一固件从所述数据集合中调用所需的第一数据,包括:控制所述第一固件查询所述第一数据的标志位;如果所述标志位表征所述第一数据已经完成加载,控制所述第一固件从所述数据集合中调用所述第一数据。
在其他实施例中,所述方法还包括:如果所述标志位表征所述第一数据没有被加载,控制所述第一固件向所述管理控制器发送调用请求;在所述第一固件向所述管理控制器发送调用请求之后,在控制所述管理控制器加载所述第一数据之前,继续启动下一个固件。
在其他实施例中,所述方法还包括:控制所述管理控制器根据所述调用请求,加载所述第一数据;控制所述管理控制器将所述第一数据发送给所述第一固件;控制所述第一固件依据所述第一数据继续进行启动。
在其他实施例中,所述方法还包括:如果所述标志位表征所述第一数据正在被加载,控制所述第一固件等待预设时长之后再次查询所述第一数据的标志位;继续启动下一个固件。
在其他实施例中,所述方法还包括:在所述管理控制器完成启动之后,清除所述标志位;控制待启动的第一固件向所述管理控制器发送调用请求;控制所述管理控制器加载所述待启动的第一固件所需的数据。
在其他实施例中,所述方法还包括:在启动所述至少一个第一固件之前,启动第二固件;其中,所述第二固件在启动过程中不依赖于所述管理控制器加载的数据。
第二方面,本申请实施例提供一种固件启动装置,所述装置包括:第一启动模块,配置为启动管理控制器;
预加载模块,配置为控制所述管理控制器预先加载至少一个第一固件在启动中需要调用的数据集合;数据调用模块,配置为控制所述第一固件从所述数据集合中调用所需的第一数据;第二启动模块,配置为控制所述第一固件依据所述第一数据继续进行启动。
第三方面,本申请实施例提供一种电子设备,包括存储器和处理器,所述存储器存储有可在处理器上运行的计算机程序,所述处理器执行所述程序时实现以下步骤:启动管理控制器;控制所述管理控制器预先加载至少一个第一固件在启动中需要调用的数据集合;控制所述第一固件从所述数据集合中调用所需的第一数据;控制所述第一固件依据所述第一数据继续进行启动。
本申请实施例中,启动管理控制器,并控制所述管理控制器预先加载至少一个第一固件在启动中需要调用的数据集合;如此,所述第一固件在启动过程中需要所述管理控制器加载所需的第一数据时,控制所述第一固件直接从预先加载的数据集合中调用所述第一数据,从而使所述第一固件能够依据所述第一数据继续进行启动,进而缩短第一固件的启动时长。
附图说明
图1为本申请实施例固件启动方法的实现流程示意图;
图2为本申请实施例固件启动装置的结构示意图;
图3为本申请实施例另一固件启动方法的实现流程示意图;
图4为本申请实施例另一固件启动装置的组成结构示意图;
图5为本申请实施例电子设备的一种硬件实体示意图。
具体实施方式
为使本申请实施例的目的、技术方案和优点更加清楚,下面将结合本申请实施例中的附图,对本申请的具体技术方案做进一步详细描述。以下实施例用于说明本申请,但不用来限制本申请的范围。
除非另有定义,本文所使用的所有的技术和科学术语与属于本申请的技术领域的技术人员通常理解的含义相同。本文中所使用的术语只是为了描述本申请实施例的目的,不是旨在限制本申请。
在以下的描述中,涉及到“一些实施例”,其描述了所有可能实施例的子集,但是可以理解,“一些实施例”可以是所有可能实施例的相同子集或不同子集,并且可以在不冲突的情况下相互结合。
需要指出,本申请实施例所涉及的术语“第一\第二\第三”仅仅是是区别类似的对象,不代表针对对象的特定排序,可以理解地,“第一\第二\第三”在允许的情况下可以互换特定的顺序或先后次序,以使这里描述的本申请实施例能够以除了在这里图示或描述的以外的顺序实施。
本申请实施例提供一种固件启动方法,该方法可以应用于电子设备,所述电子设备可以是笔记本电脑、平板电脑、台式计算机、服务器、手机等。图1为本申请实施例固件启动方法的实现流程示意图,如图1所示,所述方法包括以下步骤:
步骤S101,所述电子设备启动管理控制器。
一般来说,电子设备在上电开机之后,首先需要启动管理控制器和多个固件,才能够完成操作系统的整体启动。在本申请实施例中,对所述管理控制器和固件的类型均不做限定。例如,所述管理控制器可以为基板管理控制器(Baseboard Management Controller,BMC),所述固件可以为统一的可扩展固件接口(Unified Extensible FirmwareInterface,UEFI)。
在实现时,所述电子设备可以并行启动管理控制器和所述固件,管理控制器的启动时间点和所述固件的启动时间点之间的时间差较短。例如,所述电子设备同时启动管理控制器和所述固件,其中,所述固件可以是如下实施例所述的第一固件或者第二固件。
步骤S102,所述电子设备控制所述管理控制器预先加载至少一个第一固件在启动中需要调用的数据集合。
实现时,在管理控制器启动的早期,所述电子设备控制管理控制器开始加载所述数据集合。例如,管理控制器在启动其他应用程序之前,预先加载所述数据集合。这样在第一固件还没开始启动时,管理控制器就已经完成该第一固件在启动中所需数据的加载,当该第一固件在启动过程中需要从管理控制器中调用对应的数据时,直接从所述数据集合中获取即可,如此,就大大缩短了第一固件的启动时长,进而缩短电子设备的整体启动时长。
所述数据集合中的数据可以是多种多样的。以所述第一固件为UEFI为例,所述数据集合中可以包括智能平台管理接口(Intelligent Platform Management Interface,IPMI)命令对应的响应数据、系统配置信息、系统硬件信息等。在实现时,管理控制器可以是将所述数据集合预先加载至所述第一固件可以访问的共享存储空间。
步骤S103,所述电子设备控制所述第一固件从所述数据集合中调用所需的第一数据。
仍以UEFI为例,UEFI在启动过程中可以直接从所述共享存储空间中调用所需的数据。
步骤S104,所述电子设备控制所述第一固件依据所述第一数据继续进行启动。
在本申请实施例中,所述电子设备启动管理控制器,并控制所述管理控制器预先加载至少一个第一固件在启动中需要调用的数据集合,这样,在所述第一固件在启动中需要所述管理控制器加载启动所需的数据的情况下,所述电子设备控制所述第一固件直接从所述数据集合中调用启动所需的数据,从而缩短所述第一固件的启动时长,进而缩短所述电子设备的整体启动时长。
本申请实施例再提供一种固件启动方法,所述方法包括以下步骤:
步骤S201,所述电子设备启动管理控制器;
步骤S202,所述电子设备控制所述管理控制器预先加载至少一个第一固件在启动中需要调用的数据集合;
步骤S203,所述第一固件在启动中需要调用所述管理控制器加载的第一数据时,所述电子设备控制所述第一固件查询所述第一数据的标志位。
如果所述标志位表征所述第一数据已经完成加载,执行步骤S204;如果所述标志位表征所述第一数据没有被加载,执行步骤S206;如果所述标志位表征所述第一数据正在被加载,执行步骤S208。
在实现时,当所述第一固件在启动过程中需要调用所述第一数据时,所述第一固件可以向所述管理控制器发送调用请求,此时所述电子设备可以控制所述第一固件查询所述第一数据的标志位。标志位的数值不同,表征的含义不同。例如,标志位为01,表征所述第一数据已经完成加载;标志位为11,表征所述第一数据没有被加载;标志位为10,表征所述第一数据正在被加载。
步骤S204,所述电子设备控制所述第一固件从所述数据集合中调用所述第一数据;然后执行步骤S205;
步骤S205,所述电子设备控制所述第一固件依据所述第一数据继续进行启动。
可以理解地,如果所述标志位表征所述第一数据已经完成加载,即所述数据集合中包括所述第一数据,此时所述第一固件可以从所述数据集合中直接调用所述第一数据以继续进行启动,如此可以缩短第一固件的启动时长。
步骤S206,所述电子设备控制所述第一固件向所述管理控制器发送调用请求;然后,执行步骤S207;
步骤S207,在所述电子设备控制所述管理控制器加载所述第一数据之前,所述电子设备继续启动下一个固件。
可以理解地,如果所述标志位表征所述第一数据没有被加载,即所述数据集合中没有所述第一数据,此时所述电子设备可以控制所述第一固件向所述管理控制器发送调用请求,以请求所述管理控制器加载所述第一数据。然而,通常情况下,所述管理控制器在完成启动之后才会依据所述调用请求加载所述第一数据,此时如果所述电子设备停止在第一固件的当前启动状态,等待所述管理控制器返回所述第一数据后才继续启动,这样就会增加所述电子设备的整体启动时长。
在步骤S207中,所述电子设备采用回调机制,即,所述第一固件在向所述管理控制器发送所述调用请求之后,不等待所述管理控制器加载所述第一数据,而是继续启动下一个固件,如此,可以更加紧凑地进行每一固件的启动,从而缩短电子设备的整体启动时长。
步骤S208,所述电子设备控制所述第一固件等待预设时长之后再次查询所述第一数据的标志位;并执行步骤S209。
在其他实施例中,可以以轮询的方式访问所述第一数据的标志位。
步骤S209,所述电子设备继续启动下一个固件。
需要说明的是,在实现时,步骤S208和步骤S209可以并行处理,即,所述第一固件在等待预设时长的过程中可以继续启动下一个固件,从而缩短电子设备的整体启动时长。在其他实施例中,所述第一固件在等待预设时长的过程中也可以不启动下一个固件。
在本申请实施例中,通过设置标志位来表征数据加载状态,在所述标志位表征所述第一固件所需的第一数据没有被加载时,可以使用回调机制,即,控制所述第一固件向所述管理控制器发送调用请求之后,在所述电子设备控制所述管理控制器加载所述第一数据之前,所述电子设备继续启动下一个固件,从而缩短所述电子设备的整体启动时长。
在其他实施例中,在步骤S206之后,所述方法还包括以下步骤:
步骤S211,所述电子设备控制所述管理控制器根据所述调用请求,加载所述第一数据。
这里不限定所述管理控制器何时加载所述第一数据。所述管理控制器可以在自身启动的过程中就加载所述第一数据;所述管理控制器还可以在自身启动完成后再加载所述第一数据。
不同的调用请求,加载的第一数据是不同的。例如,所述调用请求为IPMI命令,即所述第一固件向所述管理控制器发送IPMI命令,对应地,所述管理控制器需要响应所述IPMI命令对应的响应数据;再如,所述调用请求用于请求调用系统配置信息,对应地,所述管理控制器加载的第一数据为所述系统配置信息。
步骤S212,所述电子设备控制所述管理控制器将所述第一数据发送给所述第一固件。
步骤S213,所述电子设备控制所述第一固件依据所述第一数据继续进行启动。
在其他实施例中,在所述管理控制器完成启动之后,所述方法还包括以下步骤:
步骤S221,所述电子设备清除所述标志位;
步骤S222,所述电子设备控制待启动的第一固件向所述管理控制器发送调用请求;
步骤S223,所述电子设备控制所述管理控制器加载所述待启动的第一固件所需的数据。
可以理解地,在所述管理控制器完成启动之后,所述管理控制器能够及时处理接收的调用请求,此时所述电子设备如果继续控制所述管理控制器将第一固件启动所需的数据加载至数据集合中,就会造成存储空间的资源浪费。所以,在本申请实施例中,在所述管理控制器完成启动之后,就清除所述标志位,从而在待启动的第一固件向所述管理控制器发送调用请求时,直接控制所述管理控制器加载所述待启动的第一固件所需的数据。
本申请实施例再提供一种固件启动方法,所述方法可以应用于电子设备,所述方法包括以下步骤:
步骤S301,启动管理控制器;
步骤S302,在启动所述至少一个第一固件之前,启动第二固件;其中,所述第二固件在启动过程中不依赖于所述管理控制器加载的数据。
可以理解地,所述电子设备在启动的过程中,需要启动多个固件,而这些固件中,并非所有的固件在启动过程中都需要所述管理控制器参与。也就是说,有些固件(即步骤S302中的第二固件)在启动过程中是不依赖于所述管理控制器加载的数据的。
基于此,在本申请实施例中,可以将至少一个第二固件放在第一固件之前启动,即优先启动第二固件,如此,在至少一个第一固件在启动中需要调用管理控制器加载的数据之前,既可以给所述管理控制器预留更多的时间来预先加载所述数据集合,可以缩短电子设备的整体启动时长。另外,优先启动第二固件,在多个第二固件启动完成之后,启动所述第一固件时,所述管理控制器可能已经完成了启动,此时所述管理控制器就可以及时处理第一固件发送的调用请求,而无需再继续预先加载未启动的第一固件所需的数据,从而简化了电子设备的启动过程,例如,无需再查询所述第一数据的标志位,即无需执行上述实施例中的步骤S204至步骤S209,而是执行类似于步骤S211至步骤S213。
步骤S303,控制所述管理控制器预先加载至少一个第一固件在启动中需要调用的数据集合;
步骤S304,控制所述第一固件从所述数据集合中调用所需的第一数据;
步骤S305,控制所述第一固件依据所述第一数据继续进行启动。
服务器(即所述电子设备的一种示例)的UEFI在启动过程中,因为有大量的功能和BMC相关,所以UEFI在启动过程中需要访问BMC数据或者与BMC互动才能完成整体重启过程。而服务器的操作系统在断电后BMC也会被关闭,服务器再次上电后,BMC需要重新启动,此时UEFI通常就需要先等BMC启动完成之后才能继续进行启动,从而造成操作系统的启动时间较长。
基于此,下面将说明本申请实施例在一个实际的应用场景中的示例性应用。
在一个实施例中,可以将UEFI启动早期对BMC的输出,使用回调机制,从而缩短操作系统的整体启动时长。
需要说明的是,所述回调机制,也可以称为异步机制,即,UEFI在启动早期向BMC发送调用请求之后,操作系统不停在当前状态等待BMC响应,而是继续启动下一个UEFI。在BMC根据所述调用请求向该UEFI返回加载的第一数据之后,该UEFI依据所述第一数据继续进行启动。
在另一个实施例中,可以通过优化设计将依赖于BMC的UEFI启动挪移到操作系统启动后期,这样,启动过程依赖于BMC的UEFI,在给BMC发送调用请求时,BMC IPMI可能已经准备好了,BMC能够及时处理UEFI发送的调用请求,从而节约系统的整体启动时长。
在又一个实施例中,如图3所示,在BMC启动初期,将UEFI需要用的资料先加载到UEFI可以访问的共享存储空间中,并且在UEFI的BMC驱动模块中设置UEFI的BMC预加载模块,当UEFI子程序通过BMC驱动模块向BMC发送BMC访问请求(即所述调用请求的一种示例)时,通过BMC预加载模块从共享存储空间中获取UEFI子程序启动所需的数据,从而实现对UEFI上层程序的无缝衔接,以达到UEFI和BMC大部分时间同时启动的效果,缩短操作系统的启动时长。
采用本实施例的优势是,在对当前操作系统的启动机制改动最小的前提下,节约大约50%的系统启动时长。
进一步地,在本实施例中,如图3所示,在服务器上电开机时,同时启动BMC和UEFI。
在BMC启动过程中,先初始化共享存储设备和根文件系统,这样一旦根文件系统可以访问后,BMC开始以协定的数据格式预加载UEFI启动过程中可能需要的所有数据,并且设定预加载数据准备好的标志位,以标记加载好的数据。在记载完UEFI所需数据之后,启动BMC其他应用,在BMB启动完成之后,清除标记,即清除所述标志位。
在UEFI启动过程中,在BMC没有准备好之前,如果遇到对BMC的访问,先判断预加载数据是否准备好(例如判断标志位)。如果预加载数据未准备好,UEFI等待BMC完成预加载;在BMC完成预加载之后,UEFI预加载图2所示的BMC驱动模块,实现BMC驱动安装。在实现时,UEFI对BMC的访问全部由图2所示的BMC预加载模块来获取共享存储空间中存储的BMC预加载的数据。如果UEFI不需要访问BMC,则BMC驱动模块可以通过自行预处理的方式返回对上层UEFI的BMC访问。如果BMC没有预加载对应的数据,则UEFI等待BMC准备好再切回传统方式访问,或者使用回调机制轮询等待BMC准备好再访问;需要说明的是,所述传统方式指的是,UEFI向BMC发送访问请求,BMC根据所述访问请求加载对应的数据,并返回给UEFI,也就是说,此时,BMC不再预先加载未启动的UEFI所需的数据。
在UEFI启动过程中,在BMC没有准备好之前,如果有对BMC的写数据操作,则使用回调机制等待BMC完成再访问。
在BMC启动完成后,BMC清除预加载数据标志位。在UEFI启动后期,等待BMC准备好之后再完成系统启动。
基于前述的实施例,本申请实施例提供一种固件启动装置,该装置包括所包括的各模块、以及各模块所包括的各单元,可以通过终端中的处理器来实现;当然也可通过具体的逻辑电路实现;在实施的过程中,处理器可以为中央处理器(CPU)、微处理器(MPU)、数字信号处理器(DSP)或现场可编程门阵列(FPGA)等。
图4为本申请实施例固件启动装置的组成结构示意图,如图4所示,固件启动装置400包括第一启动模块401、预加载模块402、数据调用模块403和第二启动模块404,其中:
第一启动模块401,配置为启动管理控制器;
预加载模块402,配置为控制所述管理控制器预先加载至少一个第一固件在启动中需要调用的数据集合;
数据调用模块403,配置为控制所述第一固件从所述数据集合中调用所需的第一数据;
第二启动模块404,配置为控制所述第一固件依据所述第一数据继续进行启动。
在其他实施例中,数据调用模块403,配置为:
控制所述第一固件查询所述第一数据的标志位;
如果所述标志位表征所述第一数据已经完成加载,控制所述第一固件从所述数据集合中调用所述第一数据;
如果所述标志位表征所述第一数据没有被加载,控制所述第一固件向所述管理控制器发送调用请求;在所述第一固件向所述管理控制器发送调用请求之后,在控制所述管理控制器加载所述第一数据之前,继续启动下一个固件;
如果所述标志位表征所述第一数据正在被加载,控制所述第一固件等待预设时长之后再次查询所述第一数据的标志位;继续启动下一个固件。
在其他实施例中,所述第二启动模块404,还配置为:
控制所述管理控制器根据所述调用请求,加载所述第一数据;
控制所述管理控制器将所述第一数据发送给所述第一固件;
控制所述第一固件依据所述第一数据继续进行启动。
在其他实施例中,固件启动装置400还包括清除模块405,
清除模块405,配置为在所述管理控制器完成启动之后,清除所述标志位;
数据调用模块403,还配置为:控制待启动的第一固件向所述管理控制器发送调用请求;控制所述管理控制器加载所述待启动的第一固件所需的数据。
在其他实施例中,所述第二启动模块404配置为:在启动所述至少一个第一固件之前,启动第二固件;其中,所述第二固件在启动过程中不依赖于所述管理控制器加载的数据。
以上装置实施例的描述,与上述方法实施例的描述是类似的,具有同方法实施例相似的有益效果。对于本申请装置实施例中未披露的技术细节,请参照本申请方法实施例的描述而理解。
需要说明的是,本申请实施例中,如果以软件功能模块的形式实现上述的固件启动方法,并作为独立的产品销售或使用时,也可以存储在一个计算机可读取存储介质中。基于这样的理解,本申请实施例的技术方案本质上或者说对相关技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,包括若干指令用以使得电子设备(可以是笔记本电脑、平板电脑、台式计算机、服务器、手机等)执行本申请各个实施例所述方法的全部或部分。而前述的存储介质包括:U盘、移动硬盘、只读存储器(Read Only Memory,ROM)、磁碟或者光盘等各种可以存储程序代码的介质。这样,本申请实施例不限制于任何特定的硬件和软件结合。
本申请实施例提供一种电子设备,图5为本申请实施例电子设备的一种硬件实体示意图,如图5所示,该电子设备500的硬件实体包括:包括存储器501和处理器502,所述存储器501存储有可在处理器502上运行的计算机程序,所述处理器502执行所述程序时实现上述实施例中提供的固件启动方法中的步骤。
存储器501配置为存储由处理器502可执行的指令和应用,还可以缓存待处理器502以及电子设备500中各模块待处理或已经处理的数据(例如,图像数据、音频数据、语音通信数据和视频通信数据),可以通过闪存(FLASH)或随机访问存储器(Random AccessMemory,RAM)实现。
本申请实施例提供一种计算机可读存储介质,其上存储有计算机程序,该计算机程序被处理器执行时实现上述实施例中提供的固件启动方法中的步骤。
这里需要指出的是:以上存储介质和设备实施例的描述,与上述方法实施例的描述是类似的,具有同方法实施例相似的有益效果。对于本申请存储介质和设备实施例中未披露的技术细节,请参照本申请方法实施例的描述而理解。
应理解,说明书通篇中提到的“一个实施例”或“一实施例”意味着与实施例有关的特定特征、结构或特性包括在本申请的至少一个实施例中。因此,在整个说明书各处出现的“在一个实施例中”或“在一实施例中”未必一定指相同的实施例。此外,这些特定的特征、结构或特性可以任意适合的方式结合在一个或多个实施例中。应理解,在本申请的各种实施例中,上述各过程的序号的大小并不意味着执行顺序的先后,各过程的执行顺序应以其功能和内在逻辑确定,而不应对本申请实施例的实施过程构成任何限定。上述本申请实施例序号仅仅为了描述,不代表实施例的优劣。
需要说明的是,在本文中,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者装置不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者装置所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括该要素的过程、方法、物品或者装置中还存在另外的相同要素。
在本申请所提供的几个实施例中,应该理解到,所揭露的设备和方法,可以通过其它的方式实现。以上所描述的设备实施例仅仅是示意性的,例如,所述单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,如:多个单元或组件可以结合,或可以集成到另一个系统,或一些特征可以忽略,或不执行。另外,所显示或讨论的各组成部分相互之间的耦合、或直接耦合、或通信连接可以是通过一些接口,设备或单元的间接耦合或通信连接,可以是电性的、机械的或其它形式的。
上述作为分离部件说明的单元可以是、或也可以不是物理上分开的,作为单元显示的部件可以是、或也可以不是物理单元;既可以位于一个地方,也可以分布到多个网络单元上;可以根据实际的需要选择其中的部分或全部单元来实现本实施例方案的目的。
另外,在本申请各实施例中的各功能单元可以全部集成在一个处理单元中,也可以是各单元分别单独作为一个单元,也可以两个或两个以上单元集成在一个单元中;上述集成的单元既可以采用硬件的形式实现,也可以采用硬件加软件功能单元的形式实现。
本领域普通技术人员可以理解:实现上述方法实施例的全部或部分步骤可以通过程序指令相关的硬件来完成,前述的程序可以存储于计算机可读取存储介质中,该程序在执行时,执行包括上述方法实施例的步骤;而前述的存储介质包括:移动存储设备、只读存储器(Read Only Memory,ROM)、磁碟或者光盘等各种可以存储程序代码的介质。
或者,本申请上述集成的单元如果以软件功能模块的形式实现并作为独立的产品销售或使用时,也可以存储在一个计算机可读取存储介质中。基于这样的理解,本申请实施例的技术方案本质上或者说对相关技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,包括若干指令用以使得电子设备(可以是笔记本电脑、平板电脑、台式计算机、服务器、手机等)执行本申请各个实施例所述方法的全部或部分。而前述的存储介质包括:移动存储设备、ROM、磁碟或者光盘等各种可以存储程序代码的介质。
本申请所提供的几个方法实施例中所揭露的方法,在不冲突的情况下可以任意组合,得到新的方法实施例。
本申请所提供的几个产品实施例中所揭露的特征,在不冲突的情况下可以任意组合,得到新的产品实施例。
本申请所提供的几个方法或设备实施例中所揭露的特征,在不冲突的情况下可以任意组合,得到新的方法实施例或设备实施例。
以上所述,仅为本申请的实施方式,但本申请的保护范围并不局限于此,任何熟悉本技术领域的技术人员在本申请揭露的技术范围内,可轻易想到变化或替换,都应涵盖在本申请的保护范围之内。因此,本申请的保护范围应以所述权利要求的保护范围为准。
Claims (10)
1.一种固件启动方法,其特征在于,所述方法包括:
启动管理控制器;
控制所述管理控制器预先加载至少一个第一固件在启动中需要调用的数据集合;
控制所述第一固件从所述数据集合中调用所需的第一数据;
控制所述第一固件依据所述第一数据继续进行启动。
2.根据权利要求1所述的方法,其特征在于,所述控制所述第一固件从所述数据集合中调用所需的第一数据,包括:
控制所述第一固件查询所述第一数据的标志位;
如果所述标志位表征所述第一数据已经完成加载,控制所述第一固件从所述数据集合中调用所述第一数据。
3.根据权利要求2所述的方法,其特征在于,所述方法还包括:
如果所述标志位表征所述第一数据没有被加载,控制所述第一固件向所述管理控制器发送调用请求;
在所述第一固件向所述管理控制器发送调用请求之后,在控制所述管理控制器加载所述第一数据之前,继续启动下一个固件。
4.根据权利要求3所述的方法,其特征在于,所述方法还包括:
控制所述管理控制器根据所述调用请求,加载所述第一数据;
控制所述管理控制器将所述第一数据发送给所述第一固件;
控制所述第一固件依据所述第一数据继续进行启动。
5.根据权利要求2所述的方法,其特征在于,所述方法还包括:
如果所述标志位表征所述第一数据正在被加载,控制所述第一固件等待预设时长之后再次查询所述第一数据的标志位;
继续启动下一个固件。
6.根据权利要求2所述的方法,其特征在于,所述方法还包括:
在所述管理控制器完成启动之后,清除所述标志位;
控制待启动的第一固件向所述管理控制器发送调用请求;
控制所述管理控制器加载所述待启动的第一固件所需的数据。
7.根据权利要求1至6任一项所述的方法,其特征在于,所述方法还包括:
在启动所述至少一个第一固件之前,启动第二固件;其中,所述第二固件在启动过程中不依赖于所述管理控制器加载的数据。
8.一种固件启动装置,其特征在于,所述装置包括:
第一启动模块,配置为启动管理控制器;
预加载模块,配置为控制所述管理控制器预先加载至少一个第一固件在启动中需要调用的数据集合;
数据调用模块,配置为控制所述第一固件从所述数据集合中调用所需的第一数据;
第二启动模块,配置为控制所述第一固件依据所述第一数据继续进行启动。
9.根据权利要求8所述的装置,其特征在于,数据调用模块,配置为:
控制所述第一固件查询所述第一数据的标志位;
如果所述标志位表征所述第一数据已经完成加载,控制所述第一固件从所述数据集合中调用所述第一数据。
10.一种电子设备,包括存储器和处理器,所述存储器存储有可在处理器上运行的计算机程序,所述处理器执行所述程序时实现以下步骤:
启动管理控制器;
控制所述管理控制器预先加载至少一个第一固件在启动中需要调用的数据集合;
控制所述第一固件从所述数据集合中调用所需的第一数据;
控制所述第一固件依据所述第一数据继续进行启动。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201910578887.5A CN110399167B (zh) | 2019-06-28 | 2019-06-28 | 固件启动方法及装置、设备、存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201910578887.5A CN110399167B (zh) | 2019-06-28 | 2019-06-28 | 固件启动方法及装置、设备、存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN110399167A true CN110399167A (zh) | 2019-11-01 |
CN110399167B CN110399167B (zh) | 2021-01-15 |
Family
ID=68323699
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201910578887.5A Active CN110399167B (zh) | 2019-06-28 | 2019-06-28 | 固件启动方法及装置、设备、存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN110399167B (zh) |
Cited By (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN111142955A (zh) * | 2019-12-31 | 2020-05-12 | 联想(北京)有限公司 | 一种信息处理方法及装置 |
CN114296837A (zh) * | 2021-12-31 | 2022-04-08 | 西安易朴通讯技术有限公司 | 固件的控制方法、装置、电子设备及计算机可读存储介质 |
CN114564243A (zh) * | 2022-03-01 | 2022-05-31 | 联想(北京)有限公司 | 一种服务器开机方法及服务器 |
CN114721735A (zh) * | 2022-03-04 | 2022-07-08 | 珠海海奇半导体有限公司 | 一种程序动态加载方法、装置及电子设备 |
Citations (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102467379A (zh) * | 2010-11-15 | 2012-05-23 | 中国人民解放军63928部队 | 基于构件技术的轻量级可扩展应用集成框架 |
US8627054B2 (en) * | 2010-12-29 | 2014-01-07 | American Megatrends, Inc. | Method and apparatus to create single firmware image for multiple server platforms |
CN104598254A (zh) * | 2015-02-17 | 2015-05-06 | 福州瑞芯微电子有限公司 | 一种安卓系统快速开机的方法及装置 |
CN105653376A (zh) * | 2016-01-05 | 2016-06-08 | 浪潮电子信息产业股份有限公司 | Arm平台中bios与bmc同时启动时保证信息同步的优化算法 |
CN106095439A (zh) * | 2016-06-12 | 2016-11-09 | 联想(北京)有限公司 | 一种信息处理方法及电子设备 |
CN107506663A (zh) * | 2017-08-02 | 2017-12-22 | 中电科技(北京)有限公司 | 基于可信bmc的服务器安全启动方法 |
CN108829460A (zh) * | 2018-06-12 | 2018-11-16 | 深圳市众鸿科技股份有限公司 | 车载终端快速启动的方法、装置及车载终端 |
CN109240754A (zh) * | 2017-07-03 | 2019-01-18 | 中兴通讯股份有限公司 | 一种配置bios启动项的逻辑器件及方法、系统 |
CN109725940A (zh) * | 2017-10-31 | 2019-05-07 | 杭州华为数字技术有限公司 | 用于计算系统启动的方法和计算系统 |
-
2019
- 2019-06-28 CN CN201910578887.5A patent/CN110399167B/zh active Active
Patent Citations (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102467379A (zh) * | 2010-11-15 | 2012-05-23 | 中国人民解放军63928部队 | 基于构件技术的轻量级可扩展应用集成框架 |
US8627054B2 (en) * | 2010-12-29 | 2014-01-07 | American Megatrends, Inc. | Method and apparatus to create single firmware image for multiple server platforms |
CN104598254A (zh) * | 2015-02-17 | 2015-05-06 | 福州瑞芯微电子有限公司 | 一种安卓系统快速开机的方法及装置 |
CN105653376A (zh) * | 2016-01-05 | 2016-06-08 | 浪潮电子信息产业股份有限公司 | Arm平台中bios与bmc同时启动时保证信息同步的优化算法 |
CN106095439A (zh) * | 2016-06-12 | 2016-11-09 | 联想(北京)有限公司 | 一种信息处理方法及电子设备 |
CN109240754A (zh) * | 2017-07-03 | 2019-01-18 | 中兴通讯股份有限公司 | 一种配置bios启动项的逻辑器件及方法、系统 |
CN107506663A (zh) * | 2017-08-02 | 2017-12-22 | 中电科技(北京)有限公司 | 基于可信bmc的服务器安全启动方法 |
CN109725940A (zh) * | 2017-10-31 | 2019-05-07 | 杭州华为数字技术有限公司 | 用于计算系统启动的方法和计算系统 |
CN108829460A (zh) * | 2018-06-12 | 2018-11-16 | 深圳市众鸿科技股份有限公司 | 车载终端快速启动的方法、装置及车载终端 |
Non-Patent Citations (2)
Title |
---|
HENRY TUCKER: "Boot Boosting", 《ITNOW》 * |
孙璠: "UEFI固件文件系统安全更新体系研究与实现", 《中国优秀硕士学位论文全文数据库信息科技辑》 * |
Cited By (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN111142955A (zh) * | 2019-12-31 | 2020-05-12 | 联想(北京)有限公司 | 一种信息处理方法及装置 |
CN111142955B (zh) * | 2019-12-31 | 2021-07-16 | 联想(北京)有限公司 | 一种信息处理方法及装置 |
CN114296837A (zh) * | 2021-12-31 | 2022-04-08 | 西安易朴通讯技术有限公司 | 固件的控制方法、装置、电子设备及计算机可读存储介质 |
CN114564243A (zh) * | 2022-03-01 | 2022-05-31 | 联想(北京)有限公司 | 一种服务器开机方法及服务器 |
CN114721735A (zh) * | 2022-03-04 | 2022-07-08 | 珠海海奇半导体有限公司 | 一种程序动态加载方法、装置及电子设备 |
Also Published As
Publication number | Publication date |
---|---|
CN110399167B (zh) | 2021-01-15 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN110399167A (zh) | 固件启动方法及装置、设备、存储介质 | |
EP3063620B1 (en) | Selective power management for pre-boot firmware updates | |
US7673131B2 (en) | Booting an operating system in discrete stages | |
US11036494B2 (en) | Embedded application upgrade | |
US7162629B2 (en) | Method to suspend-and-resume across various operational environment contexts | |
TW200530910A (en) | Method and apparatus for remote modification of system configuration | |
JP2016035770A (ja) | コンピュータシステムにおけるオペレーティングシステムの通信ネットワーク経由でのロードおよびブートを最適化するための方法、コンピュータプログラム、および装置 | |
CN101313277A (zh) | 用于携带多个挂起的运行时映像的方法与系统 | |
CN107870769A (zh) | 操作系统的安装方法及装置 | |
CN109582385A (zh) | 应用程序启动方法和装置、存储介质及电子设备 | |
CN103729210A (zh) | 一种实现一个刷机包支持多种制式智能终端的方法及装置 | |
CN102662884A (zh) | 一种基于网络的设备驱动程序配置方法 | |
WO2019144621A1 (zh) | 一种获取uefi os启动项的方法、装置及服务器 | |
CN115269025A (zh) | 一种内核快速启动方法、装置、电子设备及存储介质 | |
CN103544151A (zh) | linux系统中数据处理的方法及系统 | |
CN107179934A (zh) | 云计算环境中虚拟机自动还原的方法和系统 | |
CN108153553A (zh) | 一种高端服务器启动方法、系统、装置及计算机存储介质 | |
CN109669727B (zh) | 一种服务器的配置方法、系统及相关组件 | |
WO2009034316A2 (en) | Boot loading | |
CN113741945B (zh) | 基于云应用的应用磁盘热更新方法、装置、介质及设备 | |
CN105204876A (zh) | 系统启动方法以及电子设备 | |
CN115794303A (zh) | 一种容器的资源管理方法及装置 | |
KR101118111B1 (ko) | 이동통신단말기 및 그 부팅방법 | |
CN114416148A (zh) | 一种虚拟机管理程序热升级方法、装置及存储介质 | |
CN111061521B (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 | ||
GR01 | Patent grant | ||
GR01 | Patent grant |