[发明专利]一种对固件进行虚拟化的方法、装置、设备及系统有效
申请号: | 201910872171.6 | 申请日: | 2019-09-16 |
公开(公告)号: | CN110633131B | 公开(公告)日: | 2022-05-31 |
发明(设计)人: | 田宇 | 申请(专利权)人: | 东软集团股份有限公司;东软集团(大连)有限公司 |
主分类号: | G06F9/455 | 分类号: | G06F9/455;G06F8/65 |
代理公司: | 北京集佳知识产权代理有限公司 11227 | 代理人: | 赵晓荣 |
地址: | 110179 辽*** | 国省代码: | 辽宁;21 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 进行 虚拟 方法 装置 设备 系统 | ||
本申请公开了一种对固件进行虚拟化的方法、装置、设备及系统。本申请采集设备固件的固件信息;从固件信息中拆分得到设备的虚拟系统所需的固件信息;利用虚拟系统所需的固件信息生成虚拟系统的虚拟固件,以使虚拟固件启动所述虚拟系统。真实固件虚拟化得到的虚拟固件可用于参与引导虚拟系统启动,从而设备硬件初始化状态或复位状态不稳定的问题,以及硬件出现启动失败、初始化失败以及重启时异常的问题得以解决。虚拟系统的启动使得硬件的初始化成为可能,一旦硬件发生异常后进行重启,虚拟系统利用虚拟固件使硬件初始化恢复到正常的工作状态。可保障虚拟系统的正常工作。相比现有技术,设备硬件及虚拟系统工作的稳定性和可靠性大大提升。
技术领域
本申请涉及虚拟化技术领域,特别是涉及一种对固件进行虚拟化的方法、装置、设备及系统。
背景技术
现有的虚拟化技术方案中,为实现虚拟平台的操作系统(以下简称虚拟系统)启动,通常由物理平台的处理器的虚拟化层(又称虚拟机监视器,英文:Hypervisor)直接引导虚拟系统启动。
参见图1,该图所示为一种现有的实现虚拟系统启动的框架图。在图1 展示的虚拟系统启动方式中,通过人工方式将物理平台的固件信息采录到虚拟化层,虚拟化层再利用这些固件信息直接引导虚拟系统的系统内核启动。此处,物理平台指是某一具有多个硬件的设备,例如电脑。
但是实际应用中上述启动方式存在许多问题。例如,物理平台的硬件初始化状态或复位状态不稳定,部分硬件出现启动失败、初始化失败以及重启时异常的问题。此时,应用这些硬件资源的虚拟系统很难正常工作。
发明内容
基于上述问题,本申请提供一种对固件进行虚拟化的方法、装置、设备及系统,将设备的真实固件虚拟化为虚拟固件,以虚拟固件引导虚拟系统启动,提升硬件工作的稳定性和可靠性,解决虚拟系统无法正常工作的问题。
本申请实施例公开了如下技术方案:
第一方面,本申请提供一种对固件进行虚拟化的方法,应用于对设备的固件进行虚拟化,所述固件包括:UEFI固件或BIOS固件,所述方法包括:
采集所述固件的固件信息;
从所述固件信息中拆分得到所述设备的虚拟系统所需的固件信息;
利用所述虚拟系统所需的固件信息生成所述虚拟系统的虚拟固件,以使所述虚拟固件启动所述虚拟系统。
可选地,所述利用所述虚拟系统所需的固件信息生成所述虚拟系统的虚拟固件,具体包括:
利用所述虚拟系统所需的固件信息和所述固件的源代码生成所述虚拟系统的虚拟固件。
可选地,利用所述虚拟系统所需的固件信息生成所述虚拟系统的虚拟固件,具体包括:
利用默认固件和所述虚拟系统所需的固件信息,对所述虚拟系统进行启动调试得到调试结果;
判断所述调试结果是否满足预设需求,如果是,则根据所述默认固件和所述虚拟系统所需的固件信息生成所述虚拟固件;如果否,则根据所述预设需求对所述虚拟系统所需的固件信息进行更新,并利用所述默认固件和更新后的固件信息对所述虚拟系统进行启动调试,直到所述调试结果满足所述预设需求。
可选地,判断所述调试结果是否满足预设需求,具体为:判断所述设备的硬件的状态信息是否满足所述预设需求;所述固件与所述硬件配合使用。
可选地,预设需求包括:所述硬件的状态信息可见;
所述根据所述预设需求对所述虚拟系统所需的固件信息进行更新,具体包括:
在所述虚拟系统所需的固件信息中添加对所述硬件的描述信息。
可选地,预设需求包括:所述硬件的状态信息为目标状态;
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于东软集团股份有限公司;东软集团(大连)有限公司,未经东软集团股份有限公司;东软集团(大连)有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201910872171.6/2.html,转载请声明来源钻瓜专利网。
- 上一篇:一种基于内存热插拔技术的虚拟内存管理方法和装置
- 下一篇:存储器模块