QEMU中实现ITS设备模拟在文件hw/intc/arm_gicv3_its_kvm.c中实现。初始化如下:
过程如下:
- 定义ITS设备的具现化接口kvm_arm_its_realize();
- 设备设备的属性;
- 定义ITS设备发送MSI中断接口;
- 定义迁移时提前保存接口,该接口将ITS寄存器保存到内存结构体s中;
- 定义迁移恢复加载接口,该接口将内存结构体s中数据恢复到ITS寄存器中;
1 ITS设备的具现化
ITS设备具现化过程如下:
这里对重要几步作介绍:
- 调用KVM_CREATE_DEVICE在KVM中创建设备,后面在KVM中作详细介绍;
- Kvm_device_access()会调用系统调用SET_ATTR或GET_ATTR,这里不做任何事;
- 调用kvm_arm_register_device() (作用?)
- 将设备添加到s->gitv3中
- 调用gicv3_its_init_mmio()分配ITS MMIO,模拟ITS寄存器,这里分配MMIO,并没有真实物理地址,因此当guest中访问MMIO时会触发异常,在KVM中模拟操作;
- Kvm_device_check_attr()会调用系统调用HAS_ATTR,这里检查KVM中是否定义GITS_CTLR寄存器;
- 其他设置如kvm_msi_use_devid表示该设备需要使用devid等
2 QEMU中MSI中断的产生
QEMU中通过发送系统调KVM_SIGNAL_MSI产生MSI中断,在内核中实现后续再作介绍。
3 ITS设备状态的保存
当系统作迁移或其他操作之前时,需要各设备保存设备状态。ITS设备通过函数kvm_arm_its_pre_save()保存ITS设备状态。它主要是提前保存ITS设备相关的寄存器值到s相结构体中。
4 ITS设备状态的恢复
当系统完成迁移或其他操作之后,需要各设备恢复设备状态。ITS设备通过函数kvm_arm_its_post_load()恢复ITS设备状态。它主要是将s结构体恢复到ITS设备结构体中。