CN116627513B - 一种计算机boot的启动方法及装置 - Google Patents
一种计算机boot的启动方法及装置 Download PDFInfo
- Publication number
- CN116627513B CN116627513B CN202310602914.4A CN202310602914A CN116627513B CN 116627513 B CN116627513 B CN 116627513B CN 202310602914 A CN202310602914 A CN 202310602914A CN 116627513 B CN116627513 B CN 116627513B
- Authority
- CN
- China
- Prior art keywords
- boot
- computer
- program
- configuration information
- starting
- 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.)
- Active
Links
- 238000000034 method Methods 0.000 title claims abstract description 30
- 239000011159 matrix material Substances 0.000 claims description 7
- 230000002093 peripheral effect Effects 0.000 claims description 7
- 238000004590 computer program Methods 0.000 claims description 3
- 230000009286 beneficial effect Effects 0.000 description 2
- 238000010586 diagram Methods 0.000 description 2
- 238000012986 modification Methods 0.000 description 2
- 230000004048 modification Effects 0.000 description 2
- 238000004891 communication Methods 0.000 description 1
- 239000000284 extract Substances 0.000 description 1
- 238000004904 shortening Methods 0.000 description 1
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
- G06F9/4406—Loading of operating system
-
- 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/445—Program loading or initiating
- G06F9/44521—Dynamic linking or loading; Link editing at or after load time, e.g. Java class loading
-
- Y—GENERAL 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
- Y02—TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
- Y02D—CLIMATE 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/00—Energy efficient computing, e.g. low power processors, power management or thermal management
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Computer Security & Cryptography (AREA)
- Stored Programmes (AREA)
Abstract
本发明公开了一种计算机boot的启动方法、装置、电子设备及计算机可读存储介质,所述方法包括:当确定计算机上电且完成硬件初始化后,获取配置信息,所述配置信息为计算机启动所需的信息;基于所述配置信息从预设的多个boot程序中匹配对应目标boot程序;加载并运行所述目标boot程序,以启动计算机。本发明可以预先整合多个boot程序,当需要启动服务器时采集所需要的boot类型,根据boot类型从多个boot程序筛选目标boot程序并运行,使开发团队可以利用现有知识即可开发目标主机的boot程序,既可以减少开发成本,又可以提升启动的操作效率,极大地增加了服务器启动的灵活性。
Description
技术领域
本发明涉及启动服务器技术领域,尤其涉及一种计算机boot的启动方法及装置。
背景技术
boot是指一个程序,在计算机操作系统运行前自动运行。通过这小程序,可以建立内存空间映射图和初始化硬件设备,将系统的软硬件环境带到合适的状态,为最终调用操作系统的核心准备正确的环境。
但目前常用的服务器或计算机仅支持一种boot,比如power架构仅使用hostboot,当需要开发一套系统启动服务器时,每次都要针对特定的计算机或服务器开发一套新的boot程序,再调用新开发的boot程序启动计算机,大大增加了研发成本且启动服务器的操作效率低,并且有些开发团队并不熟悉hostboot,还要去学习hostboot相关知识才能进行开发,这无疑又增加了开发成本与周期,在支持了其他boot启动之后,开发团队可以利用现有知识即可开发boot程序,节省开发成本,缩短开发周期。
发明内容
本发明提出一种计算机boot的启动方法及装置,所述方法可以预先整合多个boot程序,当需要启动服务器时采集所需要的boot类型,根据boot类型从多个boot程序筛选目标boot程序并运行,既可以减少开发成本,又可以提升启动的操作效率。
本发明实施例的第一方面提供了一种计算机boot的启动方法,所述方法包括:
当确定计算机上电且完成硬件初始化后,获取配置信息,所述配置信息为计算机启动所需的信息;
基于所述配置信息从预设的多个boot程序中匹配对应目标boot程序;
加载并运行所述目标boot程序,以启动计算机。
在第一方面的一种可能的实现方式中,所述基于所述配置信息从预设的多个boot程序中匹配对应目标boot程序,包括:
从所述配置信息中提取类型信息;
按照所述类型信息对应的地址在预设的多个boot程序中查找对应目标boot程序。
在第一方面的一种可能的实现方式中,所述类型信息,包括:boot类型、存储地址,程序容量以及加载地址。
在第一方面的一种可能的实现方式中,所述硬件初始化的操作,包括:
分别初始化串行外设接口、ESPI总线、I3C总线、CMN控制矩阵网络、内存、缓存和处理器。
本发明实施例的第二方面提供了一种计算机boot的启动装置,所述装置包括:
获取模块,用于当确定计算机上电且完成硬件初始化后,获取配置信息,所述配置信息为计算机启动所需的信息;
匹配模块,用于基于所述配置信息从预设的多个boot程序中匹配对应目标boot程序;
启动模块,用于加载并运行所述目标boot程序,以启动计算机。
在第二方面的一种可能的实现方式中,所述匹配模块,还用于:
从所述配置信息中提取类型信息;
按照所述类型信息对应的地址在预设的多个boot程序中查找对应目标boot程序。
在第二方面的一种可能的实现方式中,所述类型信息,包括:boot类型、存储地址,程序容量以及加载地址。
在第二方面的一种可能的实现方式中,所述硬件初始化的操作,包括:
分别初始化串行外设接口、ESPI总线、I3C总线、CMN控制矩阵网络、内存、缓存和处理器。
相比于现有技术,本发明实施例提供的一种计算机boot的启动方法及装置,其有益效果在于:本发明可以预先整合多个boot程序,当需要启动服务器时采集所需要的boot类型,根据boot类型从多个boot程序筛选目标boot程序并运行,使开发团队可以利用现有知识即可开发目标主机的boot程序,既可以减少开发成本,又可以提升启动的操作效率,极大地增加了服务器启动的灵活性。
附图说明
图1是本发明一实施例提供的一种计算机boot的启动方法的流程示意图;
图2是本发明一实施例提供的一种计算机boot的启动方法的操作流程图;
图3是本发明一实施例提供的一种计算机boot的启动装置的结构示意图。
具体实施方式
下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有作出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
为了解决上述问题,下面将通过以下具体的实施例对本申请实施例提供的一种计算机boot的启动方法进行详细介绍和说明。
参照图1,示出了本发明一实施例提供的一种计算机boot的启动方法的流程示意图。
在一实施例中,所述方法适用于计算机或智能终端。
其中,作为示例的,所述计算机boot的启动方法,可以包括:
S11、当确定计算机上电且完成硬件初始化后,获取配置信息,所述配置信息为计算机启动所需的信息。
在一实现方式中,可以先控制计算机上电,然后让计算机的各个硬件完成初始化。接着可以获取用户输入的配置信息,这些配置信息可以是启动计算机所需要的信息,具体可以是启动计算机的boot程序所需要的信息。例如,计算机的硬件配置、类型、操作型号等等。
其中,作为示例的,所述硬件初始化的操作可以包括以下子步骤:
S111、分别初始化串行外设接口、ESPI总线、I3C总线、CMN控制矩阵网络、内存、缓存和处理器。
具体地,需要初始化一系列硬件,主要包括以下硬件:
初始化串行外设接口SPI,SPI接口用于flash的读写,根据ip要求的初始化流程进行初始化;scp要启动host cpu的boot就需要读取flash上的boot image,并将这些bootimage加载到合适的位置;
初始化ESPI总线,ESPI总线用于与BMC的通信,根据ip要求的初始化流程进行初始化;host cpu启动boot阶段需要与BMC进行通信,而通信的接口就是ESPI;
初始化I3C总线,I3C总线用于访问DIMM条的SPD,后面进行DDR初始化和tranning需要。
初始化CMN控制矩阵网络,初始化CMN,需要知道SAM系统map表。
初始化DDR内存,如果scp要将boot image加载到内存,就要进行DDR的初始化以及tranning。
初始化缓存L3 cache,如果scp要将boot image加载到L3 cache中,就需要对L3cache进行初始化,并将L3 cache设置为OCM模式,即L3 cache可以当作主内存使用。
初始化处理器Host CPU,选定一个chip上的一个core上的一个thread并将执行权交给这个thread,执行boot image。
S12、基于所述配置信息从预设的多个boot程序中匹配对应目标boot程序。
在一实施例中,用户可以预先设定多个boot程序,每个boot程序均可以启动操作系统,scp也可以引导启动不同类型的多种boot。例如:hostboot、coreboot、uefi等。
在一可选的实施例中,步骤S12可以包括以下子步骤:
S121、从所述配置信息中提取类型信息。
在一实施例中,所述类型信息,包括:boot类型、存储地址,程序容量以及加载地址。
S122、按照所述类型信息对应的地址在预设的多个boot程序中查找对应目标boot程序。
具体地,配置信息可以是用户通过BMC的终端进行输入,从所述配置信息中提取类型信息,以确定要启动的boot的类型。
可选地,配置信息还可以在flash中的配置区域进行配置。
当scp提取类型信息以获取到boot的类型时,就根据类型信息(包括类型,地址,大小以及要加载的地址等信息)到不同位置加载这个目标boot程序。
S13、加载并运行所述目标boot程序,以启动计算机。
具体地,启动的目标boot程序包括:Hostboot,Coreboot,UEFI等。
在一实施例中,启动和运行目标boot程序之后,根据各种目标boot程序的不同实现,还会加载其他有效载荷。
比如,hostboot进行一些必要的操作之后会加载skiboot,这与hostboot的实现有关。启动uefi后可以加载skiboot也可以加载其他载荷。具体的操作可以根据实际加载的目标boot程序进行调整。
参照图2,示出了本发明一实施例提供的一种计算机boot的启动方法的操作流程图。
具体地,所述计算机boot的启动方法可以报包括以下步骤:
第一步,上电之后scp初始化相关的硬件。
第二步,检测配置的要启动的boot类型。
第三步,从不同存储区域加载相应的boot。
第四步,运行相应的boot。
另外,本发明还支持其他多种boot启动,比如uefi,coreboot等,厂商就能利用现有资源进行相应的开发就很快能够上手,节省研发成本,缩短研发周期。
在本实施例中,本发明实施例提供了一种计算机boot的启动方法,其有益效果在于:本发明可以预先整合多个boot程序,当需要启动服务器时采集所需要的boot类型,根据boot类型从多个boot程序筛选目标boot程序并运行,既可以减少开发成本,又可以提升启动的操作效率。
本发明实施例还提供了一种计算机boot的启动装置,参见图3,示出了本发明一实施例提供的一种计算机boot的启动装置的结构示意图。
其中,作为示例的,所述计算机boot的启动装置可以包括:
获取模块301,用于当确定计算机上电且完成硬件初始化后,获取配置信息,所述配置信息为计算机启动所需的信息;
匹配模块302,用于基于所述配置信息从预设的多个boot程序中匹配对应目标boot程序;
启动模块303,用于加载并运行所述目标boot程序,以启动计算机。
可选地,所述匹配模块,还用于:
从所述配置信息中提取类型信息;
按照所述类型信息对应的地址在预设的多个boot程序中查找对应目标boot程序。
可选地,所述类型信息,包括:boot类型、存储地址,程序容量以及加载地址。
可选地,所述硬件初始化的操作,包括:
分别初始化串行外设接口、ESPI总线、I3C总线、CMN控制矩阵网络、内存、缓存和处理器。
所属技术领域的技术人员可以清楚地了解到,为方便的描述和简洁,上述描述的装置的具体工作过程,可以参考前述方法实施例中的对应过程,在此不再赘述。
进一步的,本申请实施例还提供了一种电子设备,包括:存储器、处理器及存储在存储器上并可在处理器上运行的计算机程序,所述处理器执行所述程序时实现如上述实施例所述的计算机boot的启动方法。
进一步的,本申请实施例还提供了一种计算机可读存储介质,所述计算机可读存储介质存储有计算机可执行程序,所述计算机可执行程序用于使计算机执行如上述实施例所述的计算机boot的启动方法。
以上所述是本发明的优选实施方式,应当指出,对于本技术领域的普通技术人员来说,在不脱离本发明原理的前提下,还可以做出若干改进和润饰,这些改进和润饰也视为本发明的保护范围。
Claims (6)
1.一种计算机boot的启动方法,其特征在于,所述方法包括:
当确定计算机上电且完成硬件初始化后,获取配置信息,所述配置信息为计算机启动所需的信息;
基于所述配置信息从预设的多个boot程序中匹配对应目标boot程序;
加载并运行所述目标boot程序,以启动计算机;
所述基于所述配置信息从预设的多个boot程序中匹配对应目标boot程序,包括:
从所述配置信息中提取类型信息;
按照所述类型信息对应的地址在预设的多个boot程序中查找对应目标boot程序;
所述类型信息,包括:boot类型、存储地址,程序容量以及加载地址。
2.根据权利要求1所述的计算机boot的启动方法,其特征在于,所述硬件初始化的操作,包括:
分别初始化串行外设接口、ESPI总线、I3C总线、CMN控制矩阵网络、内存、缓存和处理器。
3.一种计算机boot的启动装置,其特征在于,所述装置包括:
获取模块,用于当确定计算机上电且完成硬件初始化后,获取配置信息,所述配置信息为计算机启动所需的信息;
匹配模块,用于基于所述配置信息从预设的多个boot程序中匹配对应目标boot程序;
启动模块,用于加载并运行所述目标boot程序,以启动计算机;
所述匹配模块,还用于:
从所述配置信息中提取类型信息;
按照所述类型信息对应的地址在预设的多个boot程序中查找对应目标boot程序;
所述类型信息,包括:boot类型、存储地址,程序容量以及加载地址。
4.根据权利要求3所述的计算机boot的启动装置,其特征在于,所述硬件初始化的操作,包括:
分别初始化串行外设接口、ESPI总线、I3C总线、CMN控制矩阵网络、内存、缓存和处理器。
5.一种电子设备,包括:存储器、处理器及存储在存储器上并可在处理器上运行的计算机程序,其特征在于,所述处理器执行所述计算机程序时实现如权利要求1-2任意一项所述的计算机boot的启动方法。
6.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质存储有计算机可执行程序,所述计算机可执行程序用于使计算机执行如权利要求1-2任意一项所述的计算机boot的启动方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202310602914.4A CN116627513B (zh) | 2023-05-25 | 2023-05-25 | 一种计算机boot的启动方法及装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202310602914.4A CN116627513B (zh) | 2023-05-25 | 2023-05-25 | 一种计算机boot的启动方法及装置 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN116627513A CN116627513A (zh) | 2023-08-22 |
CN116627513B true CN116627513B (zh) | 2024-02-23 |
Family
ID=87602164
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202310602914.4A Active CN116627513B (zh) | 2023-05-25 | 2023-05-25 | 一种计算机boot的启动方法及装置 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN116627513B (zh) |
Families Citing this family (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN117251216B (zh) * | 2023-09-15 | 2024-04-05 | 上海合芯数字科技有限公司 | 一种服务器固件启动优化方法、系统、服务器及存储介质 |
Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN115599451A (zh) * | 2021-07-09 | 2023-01-13 | 广州视源电子科技股份有限公司(Cn) | 多操作系统的引导启动方法及装置 |
CN116149742A (zh) * | 2023-04-17 | 2023-05-23 | 苏州萨沙迈半导体有限公司 | 芯片、芯片启动方法以及计算机可读存储介质 |
Family Cites Families (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US9501289B2 (en) * | 2014-12-26 | 2016-11-22 | American Megatrends Inc. | Method of a UEFI firmware and computer system thereof |
-
2023
- 2023-05-25 CN CN202310602914.4A patent/CN116627513B/zh active Active
Patent Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN115599451A (zh) * | 2021-07-09 | 2023-01-13 | 广州视源电子科技股份有限公司(Cn) | 多操作系统的引导启动方法及装置 |
CN116149742A (zh) * | 2023-04-17 | 2023-05-23 | 苏州萨沙迈半导体有限公司 | 芯片、芯片启动方法以及计算机可读存储介质 |
Also Published As
Publication number | Publication date |
---|---|
CN116627513A (zh) | 2023-08-22 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN106990958B (zh) | 一种扩展组件、电子设备及启动方法 | |
US8423991B2 (en) | Embedded network device and firmware upgrading method | |
CN101794235B (zh) | 基于操作系统网络驱动的无盘计算机启动方法 | |
CN116627513B (zh) | 一种计算机boot的启动方法及装置 | |
CN109408122B (zh) | 一种设备启动方法、电子设备和计算机存储介质 | |
CN107766084B (zh) | 启动装载及安装方法及其计算系统 | |
CN113835644B (zh) | 整机迁移方法、装置、设备及存储介质 | |
CN112783761A (zh) | 一种应用程序的冷启动时长测试方法、装置及系统 | |
CN107135462B (zh) | Uefi固件的蓝牙配对方法及其计算系统 | |
CN115220797B (zh) | 操作系统启动及部署方法、装置、设备、介质及程序产品 | |
EP2645239A1 (en) | Electronic apparatus and booting method | |
CN111880818B (zh) | 一种虚拟机操作系统的安装方法、系统及装置 | |
CN115664953B (zh) | 一种外接设备的资源分配方法及相关装置 | |
CN109471665B (zh) | 一种自动安装Windows操作系统的方法 | |
CN116627472A (zh) | 高速外围组件设备的固件程序升级方法及服务器 | |
WO2023060893A1 (zh) | 存储空间管理方法、装置、设备及存储介质 | |
US20150212866A1 (en) | Management system for service of multiple operating environments, and methods thereof | |
CN111399926A (zh) | 下载启动程序的方法和装置 | |
CN102455919A (zh) | 基本输入输出系统自动最佳化设定方法 | |
CN112069102B (zh) | Gpio控制器配置方法和系统 | |
WO2008048581A1 (en) | A processing device operation initialization system | |
CN114385255B (zh) | Pos机的控制方法、系统、装置以及计算可读介质 | |
CN117472458B (zh) | 系统功能优化配置方法、装置、电子设备及存储介质 | |
CN112540889B (zh) | 在用户态调整硬盘启动顺序的方法、装置、设备及介质 | |
TWI733157B (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 |