[发明专利]模拟物理TCM芯片的方法、系统、装置及可读存储介质有效
| 申请号: | 201711156805.5 | 申请日: | 2017-11-20 |
| 公开(公告)号: | CN107861795B | 公开(公告)日: | 2022-04-26 |
| 发明(设计)人: | 许鑫 | 申请(专利权)人: | 浪潮(北京)电子信息产业有限公司 |
| 主分类号: | G06F9/455 | 分类号: | G06F9/455;G06F9/52 |
| 代理公司: | 北京集佳知识产权代理有限公司 11227 | 代理人: | 罗满 |
| 地址: | 100085 北京市海*** | 国省代码: | 北京;11 |
| 权利要求书: | 查看更多 | 说明书: | 查看更多 |
| 摘要: | |||
| 搜索关键词: | 模拟 物理 tcm 芯片 方法 系统 装置 可读 存储 介质 | ||
1.一种模拟物理TCM芯片的方法,应用于Qemu构建的虚拟环境,其特征在于,包括:
预先选取一块模拟磁盘设备作为模拟的NV磁盘;
将所述物理可信计算平台TCM芯片的所有TCM功能指令进行封装得到TCM逻辑功能库,其中,所述TCM逻辑功能库实现读写所述NV磁盘的操作;
在Qemu的内存中划分出用于接收虚拟机发送的TCM功能指令的虚拟内存空间,并通过所述虚拟内存空间的访问接口将所述TCM功能指令发送给所述TCM逻辑功能库;
所述TCM逻辑功能库解析并执行所述TCM功能指令,并将执行结果返回给所述虚拟机;
所述将所述物理可信计算平台TCM芯片的所有TCM功能指令进行封装得到TCM逻辑功能库之后,在Qemu的内存中划分出用于接收虚拟机发送的TCM功能指令的虚拟内存空间之前,该方法还包括:
创建一个TCM后端对象;
则通过所述虚拟内存空间的访问接口将所述TCM功能指令发送给所述TCM逻辑功能库的过程具体为:
通过所述虚拟内存空间的访问接口将所述TCM功能指令发送给所述TCM后端对象,然后所述TCM后端对象调用所述TCM逻辑功能库;
则所述TCM逻辑功能库实现读写所述NV磁盘的操作的过程具体为:
所述TCM逻辑功能库通过所述TCM后端对象实现读写所述NV磁盘的操作;
所述预先选取一块模拟磁盘设备作为模拟的NV磁盘之后,将物理TCM芯片的所有TCM功能指令进行封装得到TCM逻辑功能库之前,该方法还包括:
在所述Qemu的BlockBackend机制中添加互斥锁机制,以便所述TCM逻辑功能库实现并发读写所述NV磁盘的操作。
2.根据权利要求1所述的方法,其特征在于,所述模拟磁盘设备为Qemu中的drive参数所指定的文件。
3.一种模拟物理TCM芯片的系统,应用于Qemu构建的虚拟环境,其特征在于,包括:
选取模块,用于预先选取一块模拟磁盘设备作为模拟的NV磁盘;
封装模块,用于将所述物理可信计算平台TCM芯片的所有TCM功能指令进行封装得到TCM逻辑功能库,其中,所述TCM逻辑功能库用于实现读写所述NV磁盘的操作;
虚拟映射模块,用于在Qemu的内存中划分出用于接收虚拟机发送的TCM功能指令的虚拟内存空间,并通过所述虚拟内存空间的访问接口将所述TCM功能指令发送给所述TCM逻辑功能库;
则所述TCM逻辑功能库还用于解析并执行所述TCM功能指令,并将执行结果返回给所述虚拟机;
该系统还包括:
创建模块,用于创建一个TCM后端对象;
则所述虚拟映射模块具体用于:
通过所述虚拟内存空间的访问接口将所述TCM功能指令发送给所述TCM后端对象,然后所述TCM后端对象调用所述TCM逻辑功能库;
则所述TCM逻辑功能库具体用于:
通过所述TCM后端对象实现读写所述NV磁盘的操作;
添加模块,用于在所述Qemu的BlockBackend机制中添加互斥锁机制,以便所述TCM逻辑功能库实现并发读写所述NV磁盘的操作。
4.根据权利要求3所述的系统,其特征在于,所述模拟磁盘设备为Qemu中的drive参数所指定的文件。
5.一种模拟物理TCM芯片的装置,其特征在于,包括:
存储器,用于存储计算机程序;
处理器,用于执行所述计算机程序时实现如权利要求1至2任意一项所述模拟物理TCM芯片方法的步骤。
6.一种可读存储介质,其特征在于,所述可读存储介质上存储有计算机程序,所述计算机程序被处理器执行时实现如权利要求1至2任意一项所述模拟物理TCM芯片方法的步骤。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于浪潮(北京)电子信息产业有限公司,未经浪潮(北京)电子信息产业有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201711156805.5/1.html,转载请声明来源钻瓜专利网。





