1. KVM创建启动虚机流程
graph TD
A[open /kvm/dev设备]-->B[使用KVM_GET_API_VERSION获取API版本]
B-->C[是否支持KVM_CAP_USER_MEM功能]
C-->D[KVM_CREATE_VM创建虚机vmfd]
D-->E[使用mmap获得一块页对齐初始值为0的内存mem]
E-->F[将要运行的机器码数据使用memcpy复制到mem中]
F-->G[使用KVM_SET_USER_MEMORY_REGION通知虚机vmfd内存地址mem]
G-->H[使用KVM_CREATE_VCPU为虚机vmfd创建虚拟cpu vcpufd]
H-->I[使用KVM_GET_VCPU_MMAP_SIZE获取KVM_RUN和用户空间交互的共享内存区域的大小mmap_size]
I-->J[使用mmap将vcpufd中0-mmap_size的地址映射到kvm_run结构体]
J-->K[使用KVM_GET_SREGS和KVM_SET_SREGS设置vcpufd的cs寄存器的base和selector为0]
K-->L[使用KVM_SET_REGS设置寄存器值]
L-->M[使用KVM_RUN启动虚拟cpu vcpufd]
M-->N[当退出时可由run->exit_reason获得退出原因]
简单流程:
- 创建VM和VCPU
- 使用mmap映射内存,并初始化
- 初始化VCPU寄存器
- 启动VCPU,监控VCPU的退出
2. 代码说明
2.1 测试代码
为测试KVM虚拟机,编写测试代码计算al和bl寄存器的和