• 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。
  • 相关阅读:
    【转载】褪去华衣 裸视学习 探讨系列
    最简单的视频网站(JavaEE+FFmpeg)
    过段时间要换博客了
    计网3
    计网1
    物理层计算题
    计网4
    子网划分与CIDR
    百度=残留在墙后的垃圾
    计网2
  • 原文地址:https://www.cnblogs.com/scu-cjx/p/6878293.html
Copyright © 2020-2023  润新知