KVM的API是通过/dev/kvm设备进行访问的。/dev/kvm是一个字符型设备,如下图所示。
KVM所提供的用户控件API从功能上划分,可以分为三种类型,如下面所示。
API类型 | 功能说明 |
system指令 | 针对虚拟化系统的全局性参数设置和用于虚拟机创建等控制操作 |
VM指令 | 针对具体的VM虚拟机进行控制,如进行内存设置、创建VCPU等。注意:VM指令不是进程安全的 |
vcpu指令 | 针对具体的vCPU进行参数设置(MRU寄存器读写、中断控制等) |
用户空间的程序与KVM的交互来查询、管理KVM hypervisor或者guest,是通过使用ioctl函数与一个特殊的设备/dev/kvm的交互来实现的。 KVM API就是一些可以用于控制虚拟机各个方面的ioctl的集合。(The kvm API is a set of ioctls that are issued to control various aspects of a virtual machine.)
用户可以通过KVM API 获得KVM的版本信息、创建虚拟机、创建VCPU、查询KVM的特性支持和性能容量,等等
内核代码中关于KVM API的参考文档在: $Linux-SRC/Documentation/virtual/kvm/api.txt
另外,可以参考代码: virt/kvm/kvm_main.c, arch/x86/kvm/x86.c
下面是一个使用KVM API的示例小程序:
#include <stdio.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <sys/ioctl.h>
#include <fcntl.h>
#include <unistd.h>
#include <linux/kvm.h>
#define KVM_FILE "/dev/kvm"
int main()
{
int dev;
int ret;
dev = open(KVM_FILE,O_RDWR|O_NDELAY);
ret = ioctl(dev,KVM_GET_API_VERSION,0);
printf("----KVM API version is--%d---\n",ret);
ret = ioctl(dev,KVM_CHECK_EXTENSION,KVM_CAP_MAX_VCPUS);
printf("----KVM supports MAX_VCPUS per guest(VM) is %d---\n",ret);
ret = ioctl(dev,KVM_CHECK_EXTENSION,KVM_CAP_IOMMU);
if(ret != 0)
printf("----KVM supports IOMMU (i.e. Intel VT-d or AMD IOMMU).----\n");
else
printf("----KVM doesn't support IOMMU (i.e. Intel VT-d or AMD IOMMU).----\n");
return 0;
}
运行上面的示例程序,如下所示:
[root@jay-linux jay]# vim kvm-api-test.c
[root@jay-linux jay]# gcc kvm-api-test.c -o kvm-api-test
[root@jay-linux jay]# ./kvm-api-test
----KVM API version is--12---
----KVM supports MAX_VCPUS per guest(VM) is 254---
----KVM supports IOMMU (i.e. Intel VT-d or AMD IOMMU).----