kernelry
作者kernelry·2017-09-14 23:44
其它·菠萝

VMware EVC的BIOS中(VT、XD、AES)和Monitor/Mwait功能的关系

字数 1140阅读 8016评论 1赞 7

业务环境

服务器CPUESXi数量
华为RH5885H V3Intel XeonE7-4850v46

客户需求

开启VMware EVC 功能

遇到问题

服务器BIOS设置中的VT、XD、AES三大功能已经开启,为何配置VMware EVC时还有未开启前的报错?
20170914221956.png

20170914221956.png

解决办法

再次进入BIOS设置,将CPU的Monitor/Mwait功能设置为Enabled。
20170914222125.png

20170914222125.png

开机后再次开启EVC功能,则成功。

Monitor/Mwait与VT、XD、AES的关系

-Monitor/Mwait介绍

Monitor指令:MONITOR EAX, ECX, EDX
---设置硬件要监视的线性地址范围,并激活监视器。地址范围应该是写回内存缓存型。
Mwai指令:MwAIT EAX, ECX
---这是一个提示,允许处理器停止指令执行,并进入取决于具体版本的优化状态,直到发生某类事件。
引用自:中国科学院青岛生物能源与过程研究所超级计算中心

--
在以上两个指令的使用方式中,EAX寄存器是在Intel IA32架构中通过执行CPUID命令,把EAX作为输入参数。当EAX=0时,将返回CPU的基本信息和制造商信息;当EAX=1时,会将CPU的版本信息返回给EAX寄存器,将功能信息返回给EDX寄存器。
EDX寄存器中的功能位则将CPU支持的各项功能用1来标识支持,EDX寄存器中存放的功能信息就包括了一些功能,比如超线程、 SSSE3和SSE4.1指令以及NX/XD CPU安全功能,其中XD功能是EVC要求启用的。

-VT介绍
VT全称为Virtualization Technology,是Intel的一项虚拟化技术,有VMX root operation 和 VMX non-root operation两种模式,两种模式都支持Ring 0 ~ Ring 3 这 4 个运行级别。ESXi可以运行在VMX root operation模式下,虚拟机运行在VMX non-root operation模式下。

-XD介绍
XD全称为Excute Disable Bit,是一项数据执行保护技术,当虚拟机需要访问内存区域时,ESXi主机中一部分的内存区域被标识为从不执行,处理器将禁止在该被保护的区域内运行任何代码,这种技术可防止大多数的缓存溢出式攻击。

-AES介绍
AES 是一种针对加密计算的CPU测试,由于不懂,在此不多解释。
其中,启动了Monitor/Mwait指令,CPU才能支持XD功能,在ESXi3.0以后的版本,默认启用了XD功能的支持。
假如你在以后的虚拟化环境中遇到类似的问题,并且使用了Intel的CPU,请尝试开启Monitor/Mwait功能。

如果觉得我的文章对您有用,请点赞。您的支持将鼓励我继续创作!

7

添加新评论1 条评论

noxudunoxudu系统工程师姜为
2017-09-16 22:44
遇到过一样的问题,电话咨询过华为,开了mwait就好了.
Ctrl+Enter 发表

相关文章

相关问题

相关资料

X社区推广