kvm源代码分析
vmx是x86硬件虚拟化层,从代码看,qemu用户态是一层,kernel中KVM通用代码是一层,类似kvm_x86_ops是一层,针对各个不同的硬件架构,而vcpu_vmx则是具体架构的虚拟化方案一层。
在执行vm entry时候将vmm状态保存到vmcs的host area,并加载对应vm的vmcs guest area信息到CPU中,vm exit时候则反之,vmcs具体结构分配由硬件实现,程序员只需要通过VMWRITE和VMREAD指令去访问
在kvm_main.c文件中
创建VM,涉及函数kvm_dev_ioctl_create_vm
该函数中的kvm_create_vm主要有两个函数kvm_arch_init_vm和hardware_enable_all用于初始化虚拟机和对硬件配置的检测(个人理解)
kvm_arch_init_vm:初始化KVM_arch,更新kvmclock
结构体kvm_x86_ops定义在kvm_host.h头文件中,在头文件中定义了关于x86体系结构的kvm相关接口,结构体kvm_x86_ops的成员是一些函数指针变量,这些指针变量在svm.c中被赋值
debugfs是一种用于内核调试的虚拟文件系统,通过其与用户空间交换数据
由于GPA不能直接用于MMU寻址,需要将其转换为HVA,在kvm中利用kvm_memory_slot数据结构记录每一个地址区间(Guest中的物理地址区间)中GPA与HVA的映射关系
kvm内核模块是作为一个设备驱动程序安装的,名称为/dev/kvm,要使用kvm,需要先用open打开/dev/kvm设备 ,得到kvm设备文件描述符fd,然后利用此fd调用ioctl向设备驱动发送命令,kvm驱动解析此种请求的函数是kvm_dev_ioctl(kvm_main.c),如KVM_CREATE_VM。其次是具体的VM。通过KVM_CREATE_VM创建了一个VM后,用户程序需要发送一些命令给VM,如KVM_CREATE_VCPU。这些命令当然也是要通过ioctl来发送,所以VM也需要对应一个文件描述符才行。用户程序中用ioctl发送KVM_CREATE_VM得到的返回值就是新创建VM对应的fd,之后利用此fd发送命令给此VM。kvm驱动解析此种请求的函数是kvm_vm_ioctl。
posted on 2017-05-19 14:39 chenjx_ucs 阅读(3196) 评论(0) 编辑 收藏 举报