打开VT-x/VT-d功能

在BIOS中可以打开CPU的VT-x/VT-d功能(这里默认CPU支持VT-x/VT-d虚拟化技术)。
如果不想重启电脑,我们如何判断是否开启了CPU的虚拟化支持呢?在Linux系统,可以通过下面的方法判断。

首先判断CPU是否支持VT-x技术? 如果grep --color vmx /proc/cpuinfo执行结果flags中有 vmx ,那么该CPU支持VT-x技术。
flags中有 vmx 只是说明CPU支持VT-x,如果要使用它,还需要打开CPU的VT-x功能。
Intel的VT-x功能是通过IA32_FEATURE_CONTROL寄存器控制的,我们可以使用rdmsr命令读取寄存器 IA32_FEATURE_CONTROL (address 0x3a)来判断是否开启了VT-x功能。若读出值为3和5表示打开了VT-x功能。

使用rdmsr命令前,先要加载msr驱动。
如果没有rdmsr命令,那么需要安装msr-tools包。

# modprobe msr
# rdmsr 0x3a
5

或者使用 kvm-ok 命令

# kvm-ok
INFO: /dev/kvm exists
KVM acceleration can be used

若没有打开VT-x,会得到如下打印:

INFO: /dev/kvm does not exist
HINT:   sudo modprobe kvm_intel
INFO: Your CPU supports KVM extensions
INFO: KVM (vmx) is disabled by your BIOS
HINT: Enter your BIOS setup and enable Virtualization Technology (VT),
   and then hard poweroff/poweron your system
KVM acceleration can NOT be used

Reference

Activating the Intel VT Virtualization Feature
Understanding VT-d: Intel Virtualization Technology for Directed I/O
Intel® 64 and IA-32 Architectures Developer’s Manual: Vol. 3C

你可能感兴趣的:(虚拟化KVM)