CN104679540A - 计算机系统与计算机系统启动方法 - Google Patents
计算机系统与计算机系统启动方法 Download PDFInfo
- Publication number
- CN104679540A CN104679540A CN201310628316.0A CN201310628316A CN104679540A CN 104679540 A CN104679540 A CN 104679540A CN 201310628316 A CN201310628316 A CN 201310628316A CN 104679540 A CN104679540 A CN 104679540A
- Authority
- CN
- China
- Prior art keywords
- computer system
- bios
- hardware unit
- hardware
- basic input
- 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
- 238000000034 method Methods 0.000 title claims abstract description 31
- 230000015654 memory Effects 0.000 claims abstract description 40
- 238000009434 installation Methods 0.000 claims description 13
- 238000001514 detection method Methods 0.000 claims description 12
- 238000000151 deposition Methods 0.000 claims description 6
- 238000010586 diagram Methods 0.000 description 13
- 230000000875 corresponding effect Effects 0.000 description 10
- 230000006870 function Effects 0.000 description 3
- 230000005540 biological transmission Effects 0.000 description 1
- 230000002596 correlated effect Effects 0.000 description 1
- 230000000694 effects Effects 0.000 description 1
- 239000012467 final product Substances 0.000 description 1
- 238000005192 partition Methods 0.000 description 1
- 230000002093 peripheral effect Effects 0.000 description 1
- 238000004088 simulation Methods 0.000 description 1
- 239000007858 starting material Substances 0.000 description 1
- 230000003068 static effect Effects 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/4411—Configuring for operating with peripheral devices; Loading of device drivers
-
- 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/4416—Network booting; Remote initial program loading [RIPL]
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
本发明公开了一种计算机系统启动方法,其步骤流程如下所述。根据多个硬件装置的BIOS启动规格目录的顺序建立对应的中断向量的顺序。当这些硬件装置进行初始化时,记忆体将预留多个空白空间,如果初始化的硬件装置是第一硬件装置,将第一硬件装置的BIOS启动规格目录插入到多个空白空间中。将除了第二硬件装置之外的其他硬件装置进行启动项禁能。从第二硬件装置启动PXE,并将远端的操作系统选择安装到某一第一硬件装置上,安装完成之后重新启动计算机系统。计算机系统重新从第二硬件装置启动PXE时,在PXE环境下选择从已安装操作系统的第一硬件装置启动操作系统。
Description
技术领域
本发明有关于一种计算机系统与计算机系统启动方法,且特别是有关于一种适用于具有预先启动执行环境(preboot execution environment,PXE)的计算机系统与计算机系统启动方法。
背景技术
随着网络传输速度的不断提升,现今对于网络的应用不再只是局限于浏览网页或传输数据而已,举例来说,目前已可利用网络来进行计算机系统(例如桌上型电脑、笔记型电脑或网络电脑)的操作系统(operating system,亦称操作系统)安装,或者是利用网络从远端服务器中抓取计算机系统运行所需的数据。
一般来说,利用网络来连结远端服务器的技术系采用预启动执行环境(preboot execution environment,PXE)的技术。此预启动执行环境技术除了可以撷取远端服务器的数据来支援计算机系统以进行开机的动作外,预启动执行环境技术也可以利用远端服务器来进行对计算机系统的操作系统或应用程式的安装。于实务上,为了能实现上述远端操作的功能,会将预启动执行环境烧录至网络卡(network card,亦称网络接口卡、网络接口控制器)上的快闪记忆体(Flash memory)中。
在计算机系统欲透过具有预启动执行环境的网络卡安装操作系统之前,使用者必须先将具有预启动执行环境的网络卡设置为启动选单20中的第一启动项(Boot Option#1),例如图1A所示。图1A为现有的主机装置于安装操作系统前的启动选单的设定示意图。于图1A中,启动选单20位于基本输入输出系统(basic input output system,BIOS)的接口中,且具有预启动执行环境的网络卡的型号为“IBA XE Slot0400v2196”。另外,区块30为用以供使用者了解按键的功能的注解。
接着,在透过具有预启动执行环境的网络卡安装完操作系统后,使用者还必须将操作系统所在的硬盘(hard disk drive,HDD)设置为启动选单20中的第一启动项(例如图1B所示),才能让计算机系统顺利进入操作系统,否则计算机系统将会一直重复安装操作系统的程序。图1B为现有的主机装置于安装完操作系统后的启动选单的设定示意图。
然而,现有的计算机系统于安装完操作系统的方法中,除了需要多次修改启动选单20中的启动项的优先顺序之外,在具有预启动执行环境的网络卡启动失败时,就会启动到启动选单20中的第一启动项之后的其他硬件装置,例如图1A的启动选单20中第二启动项(Boot Option#2)所指示的“HDD”或第三启动项(Boot Option#3)所指示的“USB”。此外,在远端服务器数量较多的情况下,当计算机系统透过具有预启动执行环境的网络卡安装操作系统时,由于具有预启动执行环境的网络卡随机性地透过某个远端服务器安装操作系统,将会导致无法准确得知计算机系统中的所有硬件装置的资讯。
发明内容
有鉴于以上的问题,本发明提出一种计算机系统与计算机系统启动方法,使得计算机系统于安装操作系统时只会启动到具有预先启动执行环境的硬件装置,且又能在预先启动执行环境中识别到其他的硬件装置。
根据本发明一实施例中的一种计算机系统启动方法,此计算机系统启动方法适用于计算机系统,其中此计算机系统包括多个硬件装置,每一个硬件装置提供BIOS启动规格目录。计算机系统启动方法的步骤流程依序如下所述。计算机系统于执行基本输入输出系统的上电检测时,根据所述多个硬件装置的BIOS启动规格目录的顺序来建立对应的中断的中断向量的顺序,当这些硬件装置进行初始化时,计算机系统的记忆体中的用于存放值这些硬件装置的BIOS启动规格目录的第一地址空间将预留多个空白空间,其中这些空白空间为连续或者非连续空间。初始化的该些硬件装置如果是多个第一硬件装置,则将这些第一硬件装置的BIOS启动规格目录按特定顺序插入到所述多个空白空间中,如果不是所述多个第一硬件装置其中之一,则将这些硬件装置的BIOS启动规格目录依次插入到第一地址空间中所述多个空白空间之外的空间中,以使得该些第一硬件装置的该BIOS启动规格目录按照相对连续的特定顺序排布。接着,基本输入输出系统将除了这些硬件装置中的第二硬件装置之外的其他硬件装置进行启动项禁能,以使得在基本输入输出系统的设置(setup)接口中的启动选项中只保留第二硬件装置,则计算机系统固定只能从第二硬件装置启动。然后,计算机系统从第二硬件装置启动预先启动执行环境(PXE),将远端的操作系统选择安装到计算机系统的某一个第一硬件装置上,安装完成之后计算机系统进行重新启动。最后,计算机系统重新从第二硬件装置启动PXE时,在PXE环境下选择从已安装操作系统的某一个第一硬件装置启动操作系统。
根据本发明一实施例中的一种计算机系统,此计算机系统包括多个硬件装置、记忆体以及基本输入输出系统芯片。所述多个硬件装置设置于计算机系统,且至少包括第一硬件装置与第二硬件装置,每一个硬件装置提供BIOS启动规格目录。记忆体中的用于存放所述多个硬件装置的BIOS启动规格目录的第一地址空间预留有多个空白空间。基本输入输出系统芯片用以执行基本输入输出系统。其中,于计算机系统开机并执行基本输入输出系统的上电检测时,根据这些硬件装置的BIOS启动规格目录的顺序来建立对应的中断的中断向量的顺序。当这些硬件装置进行初始化时,记忆体中的第一地址空间将预留多个空白空间,这些空白空间为连续或者非连续空间。初始化的这些硬件装置如果是第一硬件装置,则将第一硬件装置的BIOS启动规格目录按特定顺序插入到所述多个空白空间中,以使得基本输入输出系统获取此时产生的这些硬件装置的中断向量以进项排序;如果不是第一硬件装置,则将这些硬件装置的BIOS启动规格目录依次插入到第一地址空间中的这些空白空间之外的空间中,以使得第一硬件装置的BIOS启动规格目录按照相对连续的特定顺序排布。接着,基本输入输出系统将除了这些硬件装置中的第二硬件装置之外的其他硬件装置进行启动项禁能,以使得在基本输入输出系统的设置接口中的启动选项中只保留第二硬件装置,则计算机系统固定只能从第二硬件装置启动。然后,计算机系统从第二硬件装置启动PXE,将远端的操作系统选择安装到计算机系统的某一个第一硬件装置上,安装完成之后计算机系统进行重新启动。最后,计算机系统重新从第二硬件装置启动PXE时,在PXE环境下选择从已安装操作系统的某一个第一硬件装置启动操作系统,以达成无需多次重新启动以及修改启动项顺序,并且第二硬件装置启动失败时不会引导到其他硬件装置以顺利完成操作系统的启动。
综合以上所述,本发明提供一种计算机系统与计算机系统启动方法,其透过预留多个空白空间于第一地址空间之中,并且于初始化到欲第一个被识别到的硬件装置时,将对应于此硬件装置的启动规格目录的内容插入至第一个空白空间中,使得此硬件装置的中断指令的入口位元址会最先被调用,进而使此硬件装置于预先启动执行环境中会第一个被识别到。此外,由于在启动选单中禁能了除具有预先启动执行环境的硬件装置之外的其他硬件装置,而仅保留了具有预先启动执行环境的硬件装置,使得主机装置于安装操作系统时只会启动到具有预先启动执行环境的硬件装置,且又能在预先启动执行环境中识别到其他的硬件装置并按照已排布好的顺序启动硬件装置。
以上的关于本发明内容的说明及以下的实施方式的说明用以示范与解释本发明的精神与原理,并且提供本发明的权利要求保护范围更进一步的解释。
附图说明
图1A为现有的主机装置于安装操作系统前的启动选单的设定示意图。
图1B为现有的主机装置于安装完操作系统后的启动选单的设定示意图。
图2为根据本发明一实施例的计算机系统的功能方块图。
图3为根据本发明一实施例的第一位置空间的示意图。
图4为根据本发明一实施例的主机装置的启动选单的设定示意图。
图5为根据本发明一实施例的主机装置于磁盘操作系统的接口示意图。
图6为根据本发明一实施例的计算机系统启动方法的步骤流程图。
其中,附图标记:
1 计算机系统
10 第一硬件装置
12 第二硬件装置
14 记忆体
140 第一地址空间
1400 空白空间
1402 第一地址空间中的空白空间以外的地址空间
16 基本输入输出系统芯片20启动选单
30 注解
S600~S608 步骤流程
具体实施方式
以下在实施方式中详细叙述本发明的详细特征以及优点,其内容足以使任何本领域的技术人员了解本发明的技术内容并据以实施,且根据本说明书所发明的内容、权利要求保护范围及附图,任何本领域的技术人员可轻易地理解本发明相关的目的及优点。以下的实施例进一步详细说明本发明的观点,但非以任何观点限制本发明的范畴。
〔计算机系统的一实施例〕
请参照图2,图2为根据本发明一实施例的计算机系统的功能方块图。如图2所示,计算机系统1例如可以为桌上型电脑、笔记型电脑、一体成型电脑(All-In-One PC,AIO PC)或网络电脑,但不以此为限。计算机系统1主要包括第一硬件装置10、第二硬件装置12、记忆体14以及基本输入输出系统芯片16,其中基本输入输出系统芯片16电性连接第一硬件装置10、第二硬件装置12与记忆体14。以下将分别就计算机系统1中的各部功能模块作详细的说明。
第一硬件装置(hardware peripheral)10与第二硬件装置12皆设置于计算机系统1中,且每一个硬件装置皆提供一个BIOS启动规格目录(BIOS bootspecification table,BBS_table)。此BIOS启动规格目录的排序可用来表示硬件装置的启动顺序的排序。
于实务上,第一硬件装置10可以为电脑系统主机板直接连接的SATA硬盘、SAS硬盘以及主机板通过外接存储扩展卡电性连接的SATA硬盘、SAS硬盘和PCIE硬盘,也可以为通用串行总线(universal serial bus,USB),而第二硬件装置12可以为一种具有预先启动执行环境(preboot execute environment,PXE,亦即可网络)的网络卡(network card,亦称网络接口卡、网络接口控制器),换句话说,第二硬件装置12为一种可以网络开机的网络卡。需先一提的是,预先载入执行环境系为网络技术中远端程式载入(remote program load,RPL)技术的延伸,此预先载入执行环境适用于主机装置本身并无开机系统或根本没有硬盘时可透过远端服务器执行开机,以使用远端的系统,且预先载入执行环境也可透过远端服务器来执行操作系统或应用程式的安装。
此外,本发明在此不以限制主机装置中的硬件装置的数目,换句话说,主机装置除了可以具有第一硬件装置10与第二硬件装置12之外,更可以具有其他硬件装置,且这些硬件装置可以为硬盘、软盘(floppy disk,FD)、光盘机(亦称光盘驱动器)、显示卡与网络卡等接口卡(interface card、adapter)以及通用串行总线(universal serial bus,USB)与IEEE1394(亦称火线,FireWire)等总线。
记忆体14用以储存主机装置的数据,且记忆体14中的用于存放所述多个硬件装置的BIOS启动规格目录的第一地址空间140中预留有多个空白空间1400,如图3所示。图3为根据本发明一实施例的第一位置空间的示意图。于实务上,记忆体14可以为一种可程式化只读记忆体(programmable read-onlymemory,PROM)、可擦可程式化只读记忆体(erasable programmable read-onlymemory,EPROM)、可电擦可程式化只读记忆体(electrically erasableprogrammable read-only memory,EEPROM)、快闪记忆体(flash memory)等非挥发性记忆体(non-volatile memory),或者是可以为一种动态随机存取记忆体(dynamic random access memory,DRAM)、静态随机存取记忆体(staticrandom access memory,SRAM)等挥发性记忆体(volatile memory)。此外,上述的空白空间1400可以为连续空间或者非连续空间,本发明在此不加以限制。
基本输入输出系统芯片16用以执行基本输入输出系统。于实际的操作中,当计算机系统1开机并执行基本输入输出系统的上电检测(BIOS POST,亦称开机检测)时,基本输入输出系统芯片16会根据这些硬件装置(包括第一硬件装置10与第二硬件装置12)的BIOS启动规格目录的顺序来建立对应的中断的中断向量(interrupt vector)的顺序。
当这些硬件装置进行初始化(initialization)时,记忆体14中的第一地址空间140将预留多个空白空间1400,如果初始化的该些硬件装置是第一硬件装置10的话,则将第一硬件装置10的BIOS启动规格目录按特定顺序插入到此空白空间1400中,以使得基本输入输出系统获取此时产生的这些硬件装置的中断向量以进项排序;如果初始化的该些硬件装置不是第一硬件装置10的话,则将这些硬件装置的BIOS启动规格目录依次插入到第一地址空间140中的空白空间1400之外的空间(即地址空间1402)中,以使得第一硬件装置10为多个的话,所述多个第一硬件装置10的BIOS启动规格目录可以按照相对连续的特定顺序排布。
换句话说,本发明的计算机系统1在用以储存所有的硬件装置的BIOS启动规格目录的地址空间1402之前预留多个空白的地址空间(即空白空间1400),而所有的硬件装置的BIOS启动规格目录都是在第一地址空间142中进行排序。当计算机系统1初始化到第一硬件装置10时,则将对应于第一硬件装置10的启动规格目录的内容插到上述的空白空间1400中,据以使得第一硬件装置10的中断(例如INT13h)的入口地址(entry address)会最先被调用,进而使第一硬件装置10于预先启动执行环境中会第一个被识别(抓取)到。
更详细来说,基本输入输出系统会根据BIOS启动规格目录中的中断的入口地址来调用此中断,并将第一硬件装置10的主启动记录(master bootstraprecord,MBR)复制到记忆体14的第二地址空间(未绘示于图式),以使此主启动记录内部的第一阶段引导程式(master bootstrap loader,MBL)得到控制权并寻找现用分区(active partition),当此第一阶段引导程式寻找到上述的现用分区时,第一阶段引导程式会将控制权转交给现用分区内部的第二阶段引导程式,以启动计算机系统1的操作系统。于实务上,上述的第二地址空间系为记忆体14的地址空间中的0000h:7C00h。
此外,本发明在此不加以限制空白空间1400中所能储存的硬件装置的启动规格目录的内容的数目,换句话说,空白空间1400可储存至少一硬件装置的启动规格目录的内容。此外,上述的中断系为INT13,是基本输入输出系统提供的硬盘基本输入输出中断,一般来说,INT13h用以提供硬盘读写及格式化等服务。
接着,基本输入输出系统将除了这些硬件装置中的第二硬件装置12之外的其他硬件装置进行启动项禁能,以使得在基本输入输出系统的设置(setup)接口中的启动选项中只保留第二硬件装置,则计算机系统1固定只能从第二硬件装置12启动,如图4所示。图4为根据本发明一实施例的主机装置的启动选单的设定示意图。图4中的基本输入输出系统的接口的启动选单20包括有启动项的优先顺序(Boot Option Priorities)以及表示启动顺序的第一启动项(Boot Option#1)、第二启动项(Boot Option#2)与第三启动项(Boot Option#3),其中第二启动项与第三启动项皆被设定为禁能(disabled),而仅保留第一启动项。换句话说,基本输入输出系统将除了第二硬件装置12之外的其他硬件装置进行禁能的过程,是采用通过在每一个硬件装置提供的可扩展固件接口载入选项(EFI_LOAD_OPTION)中的属性(Attributes)设置为0来实现,此设置是在基本输入输出系统的固件代码内执行。此外,第一启动项中的“IBA XESlot0400v2196”仅表示具有预先启动执行环境的网络卡(即第二硬件装置12)的型号,但并非用以限制第二硬件装置12的型号。另外,区块30为基本输入输出系统的接口用以供使用者了解按键的功能的注解。
然后,计算机系统1从第二硬件装置12启动预先启动执行环境,并将远端的操作系统选择安装到计算机系统1的某一个第一硬件装置10上,安装完成之后计算机系统1进行重新启动。最后,计算机系统1重新从该第二硬件装置启动PXE时,在PXE环境下选择从已安装操作系统的某一个第一硬件装置10来启动操作系统,如果操作系统并没有安装到已经排序好的第一个第一硬件装置时,则此重新启动启动到第一个第一硬件装置时会失败并接着按顺序往后寻找其他的第一硬件装置直到寻找到并从已安装操作系统的第一硬件装置启动,以达成无需多次重新启动以及修改启动项顺序,并且在第二硬件装置12启动失败时不会引导(boot)到其他硬件装置以顺利完成操作系统的启动。换句话说,计算机系统1从第二硬件装置12启动预先启动执行环境时,远端的操作系统将被安装到计算机系统1的排布第一的第一硬件装置10上,安装完成之后计算机系统1进行重新启动,计算机系统1重新从第二硬件装置12启动预先启动执行环境时,在预先启动执行环境下从已安装操作系统的排布第一的第一硬件装置10启动操作系统。
藉此,本发明的计算机系统1于执行操作系统或应用程式的安装时仅会启动到具有预先启动执行环境的网络卡(即第二硬件装置12),而又能在预先启动执行环境中识别出对应于空白空间1400的所有硬件装置(包括第一硬件装置10),例如图5所示。图5为根据本发明一实施例的主机装置于磁盘操作系统的接口示意图。换句话说,计算机系统1在预先启动执行环境的磁盘操作系统(disk operating system,DOS)下获取到计算机系统1上所有的第一硬件装置10的资讯以及根据此资讯选择某一个第一硬件装置10来安装操作系统。一般情况下会选择排序第一的第一硬件装置来安装操作系统,并且启动时也从第一个第一硬件装置来启动,此外,图5仅用以表示主机装置于磁盘操作系统的接口中所能抓取到的硬件装置的示意图。
此外,第二硬件装置12于执行预先启动执行环境启动所需的选项只读记忆体是包含在基本输入输出系统中或者第二硬件装置12的韧体(即网络卡固件)中。值得一提的是,基本输入输出系统根据这些硬件装置的BIOS启动规格目录来建立对应的中断的中断向量的顺序的处理程式,是在计算机系统1执行基本输入输出系统的上电检测的DXE(driver execution environment,亦称驱动程式执行环境)阶段;基本输入输出系统将除了第二硬件装置12之外的其他硬件装置进行禁能的处理程式,是在计算机系统1执行基本输入输出系统的上电检测的BDS(boot device selection,亦称启动装置选择)阶段。由于操作系统的启动程序(包括基本输入输出系统的上电检测)已被于所属技术领域具有通常知识者所知悉,故不再特别赘述。
〔计算机系统启动方法的一实施例〕
请一并参照图2至图6,图6为根据本发明一实施例的计算机系统启动方法的步骤流程图。如图6所示,此计算机系统启动方法适用于计算机系统1,此计算机系统包括多个硬件装置(包括第一硬件装置10与第二硬件装置12),每一个硬件装置提供BIOS启动规格目录。
首先,在步骤S600,计算机系统1会根据多个硬件装置的BIOS启动规格目录的顺序来建立对应的中断的中断向量的顺序。其中,上述的中断为INT13,是基本输入输出系统提供的硬盘基本输入输出中断。在步骤S602中,当这些硬件装置进行初始化时,计算机系统1的记忆体14中的用于存放这些硬件装置的BIOS启动规格目录的第一地址空间140将预留多个空白空间1400(如图3所示)。如果初始化的硬件装置是第一硬件装置10的话,则将第一硬件装置10的BIOS启动规格目录按特定顺序插入到此空白空间1400中;如果初始化的硬件装置不是第一硬件装置10的话,则将些硬件装置的BIOS启动规格目录依次插入到第一地址空间中的空白空间1400之外的空间(即地址空间1402)中,以使得第一硬件装置10的BIOS启动规格目录可以按照相对连续的特定顺序排布。
在步骤S604中,基本输入输出系统将除了第二硬件装置12之外的其他硬件装置进行启动项禁能,以使得在基本输入输出系统的设置(setup)接口中的启动选项中只保留第二硬件装置12,则计算机系统1固定只能从第二硬件装置12启动,例如图4所示。在步骤S606中,计算机系统1从第二硬件装置12启动预先启动执行环境(PXE),并将远端的操作系统选择安装到计算机系统1的第一硬件装置10上,并在安装完成之后重新启动计算机系统1。此外,若计算机系统1具有多个第一硬件装置10的话,则用户可选择所述多个第一硬件装置10其中之一来进行远端操作系统的安装。
在步骤S608中,当计算机系统1重新从第二硬件装置12启动PXE时,在PXE环境下选择从已安装操作系统的第一硬件装置10来启动操作系统。值得注意的是,若计算机系统1具有多个硬盘且操作系统没有安装到启动顺序为第一启动项的硬盘时,则在PXE环境下的工具启动第一启动项的硬盘时会失败,直到启动到安装操作系统的那个硬盘时才会开启操作系统。于其中一实施例中,基本输入输出系统根据BIOS启动规格目录中的中断的入口地址调用中断,并将第一硬件装置的主启动记录复制到记忆体14的第二地址空间,以使主启动记录内部的第一阶段引导程式得到控制权并寻找现用分区。当第一阶段引导程式寻找到现用分区时,第一阶段引导程式将控制权转交给现用分区内部的第二阶段引导程式,以启动该计算机系统的操作系统。其中,上述的第二地址空间为记忆体14的地址空间中的0000h:7C00h。
于其中一实施例中,计算机系统1在预先启动执行环境的磁盘操作系统下获取到计算机系统1上所有的第一硬件装置10的资讯以及根据上述资讯选择某一个第一硬件装置10来安装操作系统。于其中一实施例中,基本输入输出系统将除了第二硬件装置12之外的其他硬件装置进行禁能的步骤(即步骤S604),采用通过在每一个硬件装置所提供的可扩展固件接口载入选项(EFI_LOAD_OPTION)中的属性(Attributes)设置为0来实现,此设置是固定在基本输入输出系统的固件代码内。
于其中一实施例中,第一硬件装置10为硬盘,而第二硬件装置12为具有预先启动执行环境的网络卡。于其中一实施例中,第二硬件装置12于执行预先启动执行环境启动所需的选项只读记忆体是包含在基本输入输出系统中或者是在网络卡固件中。于其中一实施例中,计算机系统1从第二硬件装置12启动预先启动执行环境时,远端的操作系统将被安装到计算机系统1的排布第一的第一硬件装置10上,安装完成之后计算机系统1进行重新启动,计算机系统1重新从第二硬件装置12启动预先启动执行环境时,在预先启动执行环境下从已安装操作系统的排布第一的第一硬件装置10启动操作系统。
此外,基本输入输出系统根据这些硬件装置的BIOS启动规格目录来建立对应的中断的中断向量的顺序的步骤(即步骤S600)是在计算机系统1执行基本输入输出系统的上电检测的DXE阶段;基本输入输出系统将除了第二硬件装置12之外的其他硬件装置进行禁能的步骤(即步骤S604)是在计算机系统执行基本输入输出系统的上电检测的BDS阶段。
〔实施例的可能功效〕
综合以上所述,本发明实施例提供一种计算机系统与计算机系统启动方法,其透过预留多个空白空间于第一地址空间之中,并且于初始化到欲第一个被识别到的硬件装置时,将对应于此硬件装置的启动规格目录之内容插入至第一个空白空间中,使得此硬件装置的中断指令的入口地址会最先被调用,进而使此硬件装置于预先启动执行环境中会第一个被识别到。此外,由于在启动选单中禁能了除具有预先启动执行环境的硬件装置之外的其他硬件装置,而仅保留了具有预先启动执行环境的硬件装置,使得主机装置于安装操作系统时只会启动到具有预先启动执行环境的硬件装置,且又能在预先启动执行环境中识别到其他的硬件装置并按照已排布好的顺序启动硬件装置。藉此,本发明的计算机系统与计算机系统启动方法于安装操作系统时无须多次重新启动以及修改启动项的启动顺序,且在预先启动执行环境启动失败的情况下不会启动到其他的硬件装置,而是会一直重复地启动具有预先启动执行环境的硬件装置,以及能更方便地获取主机装置上的所有硬件装置的资讯,十分具有实用性。
Claims (10)
1.一种计算机系统启动方法,适用于一计算机系统,该计算机系统包括多个硬件装置,每一该硬件装置提供一BIOS启动规格目录,其特征在于,该计算机系统启动方法包括:
该计算机系统于执行一基本输入输出系统的上电检测时,根据该些硬件装置的该BIOS启动规格目录的顺序来建立对应的一中断的中断向量的顺序,当该些硬件装置进行初始化时,该计算机系统的一记忆体中的用于存放该些硬件装置的该BIOS启动规格目录的一第一地址空间将预留多个空白空间,该些空白空间为连续或者非连续空间,初始化的该些硬件装置如果是多个第一硬件装置,则将该些第一硬件装置的该BIOS启动规格目录按特定顺序插入到该多个空白空间中,如果不是某一该第一硬件装置,则将该些硬件装置的该BIOS启动规格目录依次插入到该第一地址空间中该些空白空间之外的空间中,以使得该些第一硬件装置的该BIOS启动规格目录按照相对连续的特定顺序排布;
该基本输入输出系统将除了该些硬件装置中的一第二硬件装置之外的其他硬件装置进行启动项禁能以使得在该基本输入输出系统的设置接口中的启动选项中只保留该第二硬件装置,则该计算机系统固定只能从该第二硬件装置启动;
该计算机系统从该第二硬件装置启动预先启动执行环境,将远端的操作系统选择安装到该计算机系统的某一该第一硬件装置上,安装完成之后该计算机系统进行重新启动;以及
该计算机系统重新从该第二硬件装置启动预先启动执行环境时,在预先启动执行环境下选择从已安装操作系统的某一该第一硬件装置启动操作系统。
2.如权利要求1所述的计算机系统启动方法,其特征在于,还包括该基本输入输出系统根据该BIOS启动规格目录中的该中断的入口地址调用该中断,将该第一硬件装置的一主启动记录复制到该记忆体的一第二地址空间,以使该主启动记录内部的一第一阶段引导程式得到控制权并寻找一现用分区,当该第一阶段引导程式寻找到该现用分区时,该第一阶段引导程式将控制权转交给该现用分区内部的一第二阶段引导程式,启动该计算机系统的操作系统。
3.如权利要求1所述的计算机系统启动方法,其特征在于,该计算机系统从该第二硬件装置启动预先启动执行环境,远端的操作系统将被安装到该计算机系统的一排布第一的第一硬件装置上,安装完成之后该计算机系统进行重新启动,该计算机系统重新从该第二硬件装置启动预先启动执行环境时,在预先启动执行环境下从已安装操作系统的该排布第一的第一硬件装置启动操作系统。
4.如权利要求1所述的计算机系统启动方法,其特征在于,该计算机系统在预先启动执行环境的磁盘操作系统下获取到该计算机系统上所有的该第一硬件装置的资讯以及根据该资讯选择某一该第一硬件装置安装操作系统。
5.如权利要求1所述的计算机系统启动方法,其特征在于,该基本输入输出系统将除了该些硬件装置中的一第二硬件装置之外的其他硬件装置进行禁能,采用通过在每一该硬件装置提供的可扩展固件接口载入选项(EFI_LOAD_OPTION)中的属性(Attributes)设置为0来实现,此设置是固定在该基本输入输出系统的固件代码内。
6.如权利要求1所述的计算机系统启动方法,其特征在于,该第一硬件装置为硬盘,该第二硬件装置为具有预先启动执行环境的网络卡。
7.如权利要求1所述的计算机系统启动方法,其特征在于,该第二硬件装置于执行预先启动执行环境启动所需的选项只读记忆体是包含在该基本输入输出系统中或者该网络卡固件中。
8.如权利要求1所述的计算机系统启动方法,其特征在于,该中断是该基本输入输出系统提供的硬盘基本输入输出中断。
9.如权利要求1所述的计算机系统启动方法,其特征在于,该基本输入输出系统根据该些硬件装置的该BIOS启动规格目录来建立对应的该中断的中断向量的顺序的步骤是在该计算机系统执行该基本输入输出系统的上电检测的DXE阶段,该基本输入输出系统将除了该些硬件装置中的该第二硬件装置之外的其他硬件装置进行禁能的步骤是在该计算机系统执行该基本输入输出系统的上电检测的BDS阶段。
10.一种计算机系统,其特征在于,包括:
多个硬件装置,该些硬件装置设置于该计算机系统,且至少包括一第一硬件装置与一第二硬件装置,每一该硬件装置提供一BIOS启动规格目录;
一记忆体,该记忆体中的用于存放该些硬件装置的该BIOS启动规格目录的一第一地址空间预留有多个空白空间;以及
一基本输入输出系统;
其中,该基本输入输出系统在该计算机系统开机并执行上电检测时,根据该些硬件装置的该BIOS启动规格目录的顺序来建立对应的一中断的中断向量的顺序,当该些硬件装置进行初始化时,该记忆体中的该第一地址空间将预留多个空白空间,该些空白空间为连续或者非连续空间,初始化的该些硬件装置如果是该第一硬件装置,则将该第一硬件装置的该BIOS启动规格目录按特定顺序插入到该多个空白空间中,以使得该基本输入输出系统获取此时产生的该些硬件装置的中断向量以进项排序,如果不是该第一硬件装置,则将该些硬件装置的该BIOS启动规格目录依次插入到该第一地址空间中该些空白空间之外的空间中以使得该些第一硬件装置的该BIOS启动规格目录按照相对连续的特定顺序排布,接着,该基本输入输出系统将除了该些硬件装置中的一第二硬件装置之外的其他硬件装置进行启动项禁能以使得在该基本输入输出系统的设置接口中的启动选项中只保留该第二硬件装置,则该计算机系统固定只能从该第二硬件装置启动,然后,该计算机系统从该第二硬件装置启动预先启动执行环境,将远端的操作系统选择安装到该计算机系统的某一该第一硬件装置上,安装完成之后该计算机系统进行重新启动,最后,该计算机系统重新从该第二硬件装置启动预先启动执行环境时,在预先启动执行环境下选择从已安装操作系统的某一该第一硬件装置启动操作系统,以达成无需多次重新启动以及修改启动项顺序,并且该第二硬件装置启动失败时不会引导到其他硬件装置以顺利完成操作系统的启动。
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201310628316.0A CN104679540B (zh) | 2013-11-29 | 2013-11-29 | 计算机系统与计算机系统启动方法 |
US14/172,531 US9239725B2 (en) | 2013-11-29 | 2014-02-04 | System and method for installing an OS via a network card supporting PXE |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201310628316.0A CN104679540B (zh) | 2013-11-29 | 2013-11-29 | 计算机系统与计算机系统启动方法 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN104679540A true CN104679540A (zh) | 2015-06-03 |
CN104679540B CN104679540B (zh) | 2017-12-19 |
Family
ID=53265395
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201310628316.0A Active CN104679540B (zh) | 2013-11-29 | 2013-11-29 | 计算机系统与计算机系统启动方法 |
Country Status (2)
Country | Link |
---|---|
US (1) | US9239725B2 (zh) |
CN (1) | CN104679540B (zh) |
Cited By (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN105607915A (zh) * | 2016-02-02 | 2016-05-25 | 浪潮(北京)电子信息产业有限公司 | 一种服务器双分区开机控制方法 |
CN107273121A (zh) * | 2017-06-07 | 2017-10-20 | 联想(北京)有限公司 | 一种智能设备重启的管理方法及装置 |
CN107368322A (zh) * | 2017-07-28 | 2017-11-21 | 郑州云海信息技术有限公司 | 一种调整操作系统下硬盘启动顺序的方法及装置 |
CN107621997A (zh) * | 2017-09-28 | 2018-01-23 | 联想(北京)有限公司 | 一种处理方法及装置 |
CN108255532A (zh) * | 2018-01-16 | 2018-07-06 | 联想(北京)有限公司 | 一种操作系统迁移方法和装置 |
CN112860330A (zh) * | 2021-02-23 | 2021-05-28 | 浙江大华技术股份有限公司 | 安装操作系统的方法、装置、计算机设备和存储介质 |
CN113489597A (zh) * | 2020-03-16 | 2021-10-08 | 广达电脑股份有限公司 | 用于网络装置的最佳启动路径的方法和系统 |
CN113900872A (zh) * | 2021-10-11 | 2022-01-07 | 江苏欧迈科技有限公司 | 一种硬件故障检测系统、方法及介质 |
Families Citing this family (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2017116401A1 (en) * | 2015-12-28 | 2017-07-06 | Hewlett-Packard Development Company, L.P. | Booting a computer using a wireless network connection |
US10001981B2 (en) | 2016-05-26 | 2018-06-19 | At&T Intellectual Property I, L.P. | Autonomous server installation |
CN107526595B (zh) * | 2017-08-28 | 2020-06-09 | 中南大学 | 一种支持多操作系统远程加载的方法 |
TWI736842B (zh) * | 2019-02-18 | 2021-08-21 | 緯創資通股份有限公司 | 設定組態控制方法及其相關電腦系統 |
US11507421B2 (en) * | 2019-06-11 | 2022-11-22 | Dell Products L.P. | Information handling system and method to allocate peripheral component interconnect express (PCIe) bus resources |
CA3167992A1 (en) * | 2020-02-17 | 2021-08-26 | Arris Enterprises Llc | Systems and methods for narrowing the scope of a problem when a modem is bricked |
US11500647B2 (en) * | 2020-11-02 | 2022-11-15 | Dell Products L.P. | Systems and methods for achieving faster boot times using BIOS attribute mitigation |
Citations (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20030200428A1 (en) * | 2002-04-19 | 2003-10-23 | Sen-Ta Chan | Method and system for booting a client computer system over a network |
US6826710B2 (en) * | 2001-01-25 | 2004-11-30 | Dell Products L.P. | System and method for providing a fault-resilient boot |
US20050108515A1 (en) * | 2003-11-14 | 2005-05-19 | Madhusudhan Rangarajan | System and method for manufacture of information handling systems with selective option ROM executions |
US20050216715A1 (en) * | 2004-03-29 | 2005-09-29 | Matheny David L | System and method for flexible option ROM booting |
US7353376B2 (en) * | 2005-05-19 | 2008-04-01 | Dell Products L.P. | Method and system for implementing full BBS (BIOS boot specification) functionality with a single device list |
CN101427237A (zh) * | 2004-05-07 | 2009-05-06 | 慧智科技公司 | 操作系统与应用程序的集成按需交付系统与方法 |
US20100205598A1 (en) * | 2009-02-09 | 2010-08-12 | Inventec Corporation | Method for installing operating system in computer |
US8352721B1 (en) * | 2007-06-06 | 2013-01-08 | American Megatrends, Inc. | Initiating an operating system boot from firmware |
-
2013
- 2013-11-29 CN CN201310628316.0A patent/CN104679540B/zh active Active
-
2014
- 2014-02-04 US US14/172,531 patent/US9239725B2/en active Active
Patent Citations (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6826710B2 (en) * | 2001-01-25 | 2004-11-30 | Dell Products L.P. | System and method for providing a fault-resilient boot |
US20030200428A1 (en) * | 2002-04-19 | 2003-10-23 | Sen-Ta Chan | Method and system for booting a client computer system over a network |
US20050108515A1 (en) * | 2003-11-14 | 2005-05-19 | Madhusudhan Rangarajan | System and method for manufacture of information handling systems with selective option ROM executions |
US20050216715A1 (en) * | 2004-03-29 | 2005-09-29 | Matheny David L | System and method for flexible option ROM booting |
CN101427237A (zh) * | 2004-05-07 | 2009-05-06 | 慧智科技公司 | 操作系统与应用程序的集成按需交付系统与方法 |
US7353376B2 (en) * | 2005-05-19 | 2008-04-01 | Dell Products L.P. | Method and system for implementing full BBS (BIOS boot specification) functionality with a single device list |
US8352721B1 (en) * | 2007-06-06 | 2013-01-08 | American Megatrends, Inc. | Initiating an operating system boot from firmware |
US20100205598A1 (en) * | 2009-02-09 | 2010-08-12 | Inventec Corporation | Method for installing operating system in computer |
Cited By (13)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN105607915B (zh) * | 2016-02-02 | 2018-10-02 | 浪潮(北京)电子信息产业有限公司 | 一种服务器双分区开机控制方法 |
CN105607915A (zh) * | 2016-02-02 | 2016-05-25 | 浪潮(北京)电子信息产业有限公司 | 一种服务器双分区开机控制方法 |
CN107273121A (zh) * | 2017-06-07 | 2017-10-20 | 联想(北京)有限公司 | 一种智能设备重启的管理方法及装置 |
CN107273121B (zh) * | 2017-06-07 | 2021-07-16 | 联想(北京)有限公司 | 一种智能设备重启的管理方法及装置 |
CN107368322B (zh) * | 2017-07-28 | 2020-11-20 | 苏州浪潮智能科技有限公司 | 一种调整操作系统下硬盘启动顺序的方法及装置 |
CN107368322A (zh) * | 2017-07-28 | 2017-11-21 | 郑州云海信息技术有限公司 | 一种调整操作系统下硬盘启动顺序的方法及装置 |
CN107621997A (zh) * | 2017-09-28 | 2018-01-23 | 联想(北京)有限公司 | 一种处理方法及装置 |
CN107621997B (zh) * | 2017-09-28 | 2021-05-18 | 联想(北京)有限公司 | 一种处理方法及装置 |
CN108255532A (zh) * | 2018-01-16 | 2018-07-06 | 联想(北京)有限公司 | 一种操作系统迁移方法和装置 |
CN113489597A (zh) * | 2020-03-16 | 2021-10-08 | 广达电脑股份有限公司 | 用于网络装置的最佳启动路径的方法和系统 |
CN113489597B (zh) * | 2020-03-16 | 2023-05-02 | 广达电脑股份有限公司 | 用于网络装置的最佳启动路径的方法和系统 |
CN112860330A (zh) * | 2021-02-23 | 2021-05-28 | 浙江大华技术股份有限公司 | 安装操作系统的方法、装置、计算机设备和存储介质 |
CN113900872A (zh) * | 2021-10-11 | 2022-01-07 | 江苏欧迈科技有限公司 | 一种硬件故障检测系统、方法及介质 |
Also Published As
Publication number | Publication date |
---|---|
US20150154033A1 (en) | 2015-06-04 |
CN104679540B (zh) | 2017-12-19 |
US9239725B2 (en) | 2016-01-19 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN104679540A (zh) | 计算机系统与计算机系统启动方法 | |
US9778844B2 (en) | Installation of operating system on host computer using virtual storage of BMC | |
US8352721B1 (en) | Initiating an operating system boot from firmware | |
EP2705422B1 (en) | Dynamically redirecting boot to another operating system | |
US8301814B2 (en) | Management of storage media device connected to a root hub | |
CN106990958A (zh) | 一种扩展组件、电子设备及启动方法 | |
US7921230B2 (en) | USB devices pre-configuration for KVM switch | |
CN109426613B (zh) | 在uefi中检索调试数据的方法及其电脑系统 | |
CN103514015A (zh) | 一种从存储介质中启动操作系统的方法和装置 | |
CN106909362A (zh) | Bmc固件生成的方法和装置、bmc系统启动的方法和装置 | |
CN103593281A (zh) | 测试系统及测试方法 | |
CN109426527B (zh) | 在uefi固件及作业系统间分享蓝牙数据的电脑系统及其方法 | |
US20040049617A1 (en) | Method of firmware update by USB interface | |
CN101853142B (zh) | 一种带虚拟光驱的usb设备的识别方法 | |
CN103294578A (zh) | 取得触发功能的指令的方法 | |
TWI518594B (zh) | 計算機系統與計算機系統啓動方法 | |
CN103176832A (zh) | 一种类unix操作系统运行虚拟操作系统的方法及装置 | |
CN109634690A (zh) | 一种基于WinPE系统的数据清除方法、装置、终端及存储介质 | |
JP7522775B2 (ja) | 不揮発性記憶区画識別子 | |
CN108052337A (zh) | 一种eMMC量产工具的固件升级方法及装置 | |
CN114296810A (zh) | 一种操作系统迁移方法、装置、服务器与存储介质 | |
CN109254800B (zh) | 一种设备信息处理方法、电子设备及服务器 | |
TWI841160B (zh) | 存儲控制器的驅動管理方法及相關設備 | |
CN110928582B (zh) | 信息处理设备和配置信息处理设备的目标装置的方法 | |
US20240160430A1 (en) | Method for managing storage controllers, electronic device, and computer readable storage medium thereof |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
C06 | Publication | ||
PB01 | Publication | ||
C10 | Entry into substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |