kvm设备管理包括:设备的创建、初始化、释放、卸载等。arm上支持的设备类型主要有两种:vfio和中断控制器。所以,用户程序上想要申请的设备也只能是这两种。至于qemu上网卡、串口等IO设备并不属于kvm设备,它们属于virtio部分。kvm使用eventfd机制管理virtio设备。
本文第一部分介绍了kvm设备的数据类型,包括struct kvm_device和struct kvm_device_ops。第二部分简单介绍了用户程序通过hypcall创建一个kvm设备的过程。
1. kvm设备
struct kvm_device是kvm设备的数据结构,其中ops包含着设备的操作,比较重要的可能创建、删除和设备属性的配置。private成员变量是设备的私有属性,比如vfio的private是struct kvm_vfio。
struct kvm_device {
struct kvm_device_ops *ops;
struct kvm *kvm;
void *private;
struct list_head vm_node;
};
strcut kvm_device_ops是关于kvm设备可以进行的操作,它可以设置设备的一些重要属性。比如vfio是通过set_attr将用户程序提供的虚拟地址将其与硬件的物理地址作hyp mapping。这样用户程序就可以直接操作该硬件设备。
/* create, destroy, and name are mandatory */
struct kvm_device_ops {
const char